X-Git-Url: http://www.chiark.greenend.org.uk/ucgi/~ianmdlvl/git?p=elogind.git;a=blobdiff_plain;f=src%2Fshared%2Fnet-util.c;h=50cfa2c3f3a5a791f903859167523ebda43da131;hp=ba21ae437f3da968aae980c584a32c07a0ffca1c;hb=bf175aafd20c9ef974709ef12c5acf836121af33;hpb=ba91431154ad7bac82ddf0a540ec1b40db62d782 diff --git a/src/shared/net-util.c b/src/shared/net-util.c index ba21ae437..50cfa2c3f 100644 --- a/src/shared/net-util.c +++ b/src/shared/net-util.c @@ -22,37 +22,60 @@ #include #include #include +#include #include "net-util.h" #include "log.h" #include "utf8.h" #include "util.h" #include "conf-parser.h" +#include "condition.h" bool net_match_config(const struct ether_addr *match_mac, const char *match_path, const char *match_driver, const char *match_type, const char *match_name, + Condition *match_host, + Condition *match_virt, + Condition *match_kernel, + Condition *match_arch, const char *dev_mac, const char *dev_path, + const char *dev_parent_driver, const char *dev_driver, const char *dev_type, const char *dev_name) { - if (match_mac && (!dev_mac || memcmp(match_mac, ether_aton(dev_mac), ETH_ALEN))) + if (match_host && !condition_test_host(match_host)) + return 0; + + if (match_virt && !condition_test_virtualization(match_virt)) return 0; - if (match_path && !streq_ptr(match_path, dev_path)) + if (match_kernel && !condition_test_kernel_command_line(match_kernel)) return 0; - if (match_driver && !streq_ptr(match_driver, dev_driver)) + if (match_arch && !condition_test_architecture(match_arch)) return 0; + if (match_mac && (!dev_mac || memcmp(match_mac, ether_aton(dev_mac), ETH_ALEN))) + return 0; + + if (match_path && (!dev_path || fnmatch(match_path, dev_path, 0))) + return 0; + + if (match_driver) { + if (dev_parent_driver && !streq(match_driver, dev_parent_driver)) + return 0; + else if (!streq_ptr(match_driver, dev_driver)) + return 0; + } + if (match_type && !streq_ptr(match_type, dev_type)) return 0; - if (match_name && !streq_ptr(match_name, dev_name)) + if (match_name && (!dev_name || fnmatch(match_name, dev_name, 0))) return 0; return 1; @@ -64,6 +87,47 @@ unsigned net_netmask_to_prefixlen(const struct in_addr *addr) { return 32 - u32ctz(be32toh(addr->s_addr)); } +int config_parse_net_condition(const char *unit, + const char *filename, + unsigned line, + const char *section, + unsigned section_line, + const char *lvalue, + int ltype, + const char *rvalue, + void *data, + void *userdata) { + + ConditionType cond = ltype; + Condition **ret = data; + bool negate; + Condition *c; + _cleanup_free_ char *s = NULL; + + assert(filename); + assert(lvalue); + assert(rvalue); + assert(data); + + negate = rvalue[0] == '!'; + if (negate) + rvalue++; + + s = strdup(rvalue); + if (!s) + return log_oom(); + + c = condition_new(cond, s, false, negate); + if (!c) + return log_oom(); + + if (*ret) + condition_free(*ret); + + *ret = c; + return 0; +} + int config_parse_ifname(const char *unit, const char *filename, unsigned line,