mirror of
https://github.com/systemd/systemd.git
synced 2025-01-11 09:18:07 +03:00
network/link: Match - filter on kernel cmdline, host and virt
This commit is contained in:
parent
b77c08e06b
commit
2cc412b593
@ -20,6 +20,9 @@ Match.Path, config_parse_string, 0, offsetof(Netw
|
||||
Match.Driver, config_parse_string, 0, offsetof(Network, match_driver)
|
||||
Match.Type, config_parse_string, 0, offsetof(Network, match_type)
|
||||
Match.Name, config_parse_ifname, 0, offsetof(Network, match_name)
|
||||
Match.Host, config_parse_net_condition, CONDITION_HOST, offsetof(Network, match_host)
|
||||
Match.Virtualization, config_parse_net_condition, CONDITION_VIRTUALIZATION, offsetof(Network, match_virt)
|
||||
Match.KernelCommandLine, config_parse_net_condition, CONDITION_KERNEL_COMMAND_LINE, offsetof(Network, match_kernel)
|
||||
Network.Description, config_parse_string, 0, offsetof(Network, description)
|
||||
Network.Bridge, config_parse_bridge, 0, offsetof(Network, bridge)
|
||||
Network.Bond, config_parse_bond, 0, offsetof(Network, bond)
|
||||
|
@ -175,7 +175,8 @@ int network_get(Manager *manager, struct udev_device *device, Network **ret) {
|
||||
LIST_FOREACH(networks, network, manager->networks) {
|
||||
if (net_match_config(network->match_mac, network->match_path,
|
||||
network->match_driver, network->match_type,
|
||||
network->match_name,
|
||||
network->match_name, network->match_host,
|
||||
network->match_virt, network->match_kernel,
|
||||
udev_device_get_sysattr_value(device, "address"),
|
||||
udev_device_get_property_value(device, "ID_PATH"),
|
||||
udev_device_get_driver(udev_device_get_parent(device)),
|
||||
|
@ -32,6 +32,7 @@
|
||||
#include "rtnl-util.h"
|
||||
#include "hashmap.h"
|
||||
#include "list.h"
|
||||
#include "condition-util.h"
|
||||
|
||||
typedef struct NetDev NetDev;
|
||||
typedef struct Network Network;
|
||||
@ -92,6 +93,9 @@ struct Network {
|
||||
char *match_driver;
|
||||
char *match_type;
|
||||
char *match_name;
|
||||
Condition *match_host;
|
||||
Condition *match_virt;
|
||||
Condition *match_kernel;
|
||||
|
||||
char *description;
|
||||
NetDev *bridge;
|
||||
|
@ -28,18 +28,31 @@
|
||||
#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,
|
||||
const char *dev_mac,
|
||||
const char *dev_path,
|
||||
const char *dev_driver,
|
||||
const char *dev_type,
|
||||
const char *dev_name) {
|
||||
|
||||
if (match_host && !condition_test_host(match_host))
|
||||
return 0;
|
||||
|
||||
if (match_virt && !condition_test_virtualization(match_virt))
|
||||
return 0;
|
||||
|
||||
if (match_kernel && !condition_test_kernel_command_line(match_kernel))
|
||||
return 0;
|
||||
|
||||
if (match_mac && (!dev_mac || memcmp(match_mac, ether_aton(dev_mac), ETH_ALEN)))
|
||||
return 0;
|
||||
|
||||
@ -64,6 +77,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,
|
||||
|
@ -25,11 +25,16 @@
|
||||
#include <netinet/in.h>
|
||||
#include <stdbool.h>
|
||||
|
||||
#include "condition-util.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,
|
||||
const char *dev_mac,
|
||||
const char *dev_path,
|
||||
const char *dev_driver,
|
||||
@ -38,6 +43,10 @@ bool net_match_config(const struct ether_addr *match_mac,
|
||||
|
||||
unsigned net_netmask_to_prefixlen(const struct in_addr *netmask);
|
||||
|
||||
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);
|
||||
|
||||
int config_parse_hwaddr(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);
|
||||
|
@ -20,6 +20,9 @@ Match.MACAddress, config_parse_hwaddr, 0, offsetof(link
|
||||
Match.Path, config_parse_string, 0, offsetof(link_config, match_path)
|
||||
Match.Driver, config_parse_string, 0, offsetof(link_config, match_driver)
|
||||
Match.Type, config_parse_string, 0, offsetof(link_config, match_type)
|
||||
Match.Host, config_parse_net_condition, CONDITION_HOST, offsetof(link_config, match_host)
|
||||
Match.Virtualization, config_parse_net_condition, CONDITION_VIRTUALIZATION, offsetof(link_config, match_virt)
|
||||
Match.KernelCommandLine, config_parse_net_condition, CONDITION_KERNEL_COMMAND_LINE, offsetof(link_config, match_kernel)
|
||||
Link.Description, config_parse_string, 0, offsetof(link_config, description)
|
||||
Link.MACAddressPolicy, config_parse_mac_policy, 0, offsetof(link_config, mac_policy)
|
||||
Link.MACAddress, config_parse_hwaddr, 0, offsetof(link_config, mac)
|
||||
|
@ -242,6 +242,7 @@ int link_config_get(link_config_ctx *ctx, struct udev_device *device, link_confi
|
||||
|
||||
if (net_match_config(link->match_mac, link->match_path,
|
||||
link->match_driver, link->match_type, NULL,
|
||||
link->match_host, link->match_virt, link->match_kernel,
|
||||
udev_device_get_sysattr_value(device, "address"),
|
||||
udev_device_get_property_value(device, "ID_PATH"),
|
||||
udev_device_get_driver(udev_device_get_parent(device)),
|
||||
|
@ -23,6 +23,7 @@
|
||||
|
||||
#include "ethtool-util.h"
|
||||
|
||||
#include "condition-util.h"
|
||||
#include "libudev.h"
|
||||
#include "util.h"
|
||||
#include "list.h"
|
||||
@ -54,6 +55,9 @@ struct link_config {
|
||||
char *match_path;
|
||||
char *match_driver;
|
||||
char *match_type;
|
||||
Condition *match_host;
|
||||
Condition *match_virt;
|
||||
Condition *match_kernel;
|
||||
|
||||
char *description;
|
||||
struct ether_addr *mac;
|
||||
|
Loading…
Reference in New Issue
Block a user