diff options
author | Tom Gundersen <teg@jklm.no> | 2013-10-28 20:59:56 +0100 |
---|---|---|
committer | Tom Gundersen <teg@jklm.no> | 2013-10-29 14:17:57 +0100 |
commit | 5fde13d748749f0e06e2e6cdd15f0980a79ea82c (patch) | |
tree | a10f8106048135d1f84b3dbe6c1ec9d8827afd1f /src/udev/net/link-config.h | |
parent | conf-parser: add macro for ENUMV (diff) | |
download | systemd-5fde13d748749f0e06e2e6cdd15f0980a79ea82c.tar.xz systemd-5fde13d748749f0e06e2e6cdd15f0980a79ea82c.zip |
udev: link-config - add proper parsing
Diffstat (limited to '')
-rw-r--r-- | src/udev/net/link-config.h | 42 |
1 files changed, 35 insertions, 7 deletions
diff --git a/src/udev/net/link-config.h b/src/udev/net/link-config.h index d0a81f8bc2..f5dee5a274 100644 --- a/src/udev/net/link-config.h +++ b/src/udev/net/link-config.h @@ -21,31 +21,48 @@ #pragma once +#include "ethtool-util.h" + #include "libudev.h" #include "util.h" #include "list.h" - typedef struct link_config_ctx link_config_ctx; typedef struct link_config link_config; +typedef enum MACPolicy { + MACPOLICY_PERSISTENT, + MACPOLICY_RANDOM, + _MACPOLICY_MAX, + _MACPOLICY_INVALID = -1 +} MACPolicy; + +typedef enum NamePolicy { + NAMEPOLICY_ONBOARD, + NAMEPOLICY_SLOT, + NAMEPOLICY_PATH, + NAMEPOLICY_MAC, + _NAMEPOLICY_MAX, + _NAMEPOLICY_INVALID = -1 +} NamePolicy; + struct link_config { char *filename; - char *match_mac; + struct ether_addr *match_mac; char *match_path; char *match_driver; char *match_type; char *description; - char *mac; - char *mac_policy; - char **name_policy; + struct ether_addr *mac; + MACPolicy mac_policy; + NamePolicy *name_policy; char *name; unsigned int mtu; unsigned int speed; - char *duplex; - char *wol; + Duplex duplex; + WakeOnLan wol; LIST_FIELDS(link_config, links); }; @@ -59,5 +76,16 @@ bool link_config_should_reload(link_config_ctx *ctx); int link_config_get(link_config_ctx *ctx, struct udev_device *device, struct link_config **ret); int link_config_apply(link_config_ctx *ctx, struct link_config *config, struct udev_device *device); +const char *name_policy_to_string(NamePolicy p) _const_; +NamePolicy name_policy_from_string(const char *p) _pure_; + +const char *mac_policy_to_string(MACPolicy p) _const_; +MACPolicy mac_policy_from_string(const char *p) _pure_; + /* gperf lookup function */ const struct ConfigPerfItem* link_config_gperf_lookup(const char *key, unsigned length); + +int config_parse_hwaddr(const char *unit, const char *filename, unsigned line, const char *section, const char *lvalue, int ltype, const char *rvalue, void *data, void *userdata); +int config_parse_ifname(const char *unit, const char *filename, unsigned line, const char *section, const char *lvalue, int ltype, const char *rvalue, void *data, void *userdata); +int config_parse_mac_policy(const char *unit, const char *filename, unsigned line, const char *section, const char *lvalue, int ltype, const char *rvalue, void *data, void *userdata); +int config_parse_name_policy(const char *unit, const char *filename, unsigned line, const char *section, const char *lvalue, int ltype, const char *rvalue, void *data, void *userdata); |