diff options
author | Tobias Klauser <tklauser@distanz.ch> | 2016-12-06 11:03:05 (GMT) |
---|---|---|
committer | Tobias Klauser <tklauser@distanz.ch> | 2016-12-06 14:08:01 (GMT) |
commit | 1eb0c1c8dc2c32197ed11b54b37e12ec550b200b (patch) | |
tree | 46745b224983037443329a8058657fbf315dd1c1 /lib | |
parent | 0c4b2ea6d17b3491b23f5ccb450176e05de75545 (diff) | |
download | libnl-1eb0c1c8dc2c32197ed11b54b37e12ec550b200b.zip libnl-1eb0c1c8dc2c32197ed11b54b37e12ec550b200b.tar.gz libnl-1eb0c1c8dc2c32197ed11b54b37e12ec550b200b.tar.bz2 |
link: add support for IFLA_PHYS_PORT_NAME
Signed-off-by: Tobias Klauser <tklauser@distanz.ch>
Diffstat (limited to 'lib')
-rw-r--r-- | lib/route/link.c | 19 |
1 files changed, 19 insertions, 0 deletions
diff --git a/lib/route/link.c b/lib/route/link.c index 287b623..6fd2546 100644 --- a/lib/route/link.c +++ b/lib/route/link.c @@ -67,6 +67,7 @@ #define LINK_ATTR_LINK_NETNSID ((uint64_t) 1 << 32) #define LINK_ATTR_VF_LIST ((uint64_t) 1 << 33) #define LINK_ATTR_CARRIER_CHANGES ((uint64_t) 1 << 34) +#define LINK_ATTR_PHYS_PORT_NAME ((uint64_t) 1 << 35) static struct nl_cache_ops rtnl_link_ops; static struct nl_object_ops link_obj_ops; @@ -351,6 +352,7 @@ struct nla_policy rtln_link_policy[IFLA_MAX+1] = { [IFLA_CARRIER] = { .type = NLA_U8 }, [IFLA_CARRIER_CHANGES] = { .type = NLA_U32 }, [IFLA_PHYS_PORT_ID] = { .type = NLA_UNSPEC }, + [IFLA_PHYS_PORT_NAME] = { .type = NLA_STRING, .maxlen = IFNAMSIZ }, [IFLA_NET_NS_PID] = { .type = NLA_U32 }, [IFLA_NET_NS_FD] = { .type = NLA_U32 }, }; @@ -736,6 +738,11 @@ static int link_msg_parser(struct nl_cache_ops *ops, struct sockaddr_nl *who, link->ce_mask |= LINK_ATTR_PHYS_PORT_ID; } + if (tb[IFLA_PHYS_PORT_NAME]) { + nla_strlcpy(link->l_phys_port_name, tb[IFLA_PHYS_PORT_NAME], IFNAMSIZ); + link->ce_mask |= LINK_ATTR_PHYS_PORT_NAME; + } + err = pp->pp_cb((struct nl_object *) link, pp); errout: rtnl_link_af_ops_put(af_ops); @@ -1129,6 +1136,7 @@ static const struct trans_tbl link_attrs[] = { __ADD(LINK_ATTR_CARRIER, carrier), __ADD(LINK_ATTR_CARRIER_CHANGES, carrier_changes), __ADD(LINK_ATTR_PHYS_PORT_ID, phys_port_id), + __ADD(LINK_ATTR_PHYS_PORT_NAME, phys_port_name), __ADD(LINK_ATTR_NS_FD, ns_fd), __ADD(LINK_ATTR_NS_PID, ns_pid), __ADD(LINK_ATTR_LINK_NETNSID, link_netnsid), @@ -2637,6 +2645,17 @@ struct nl_data *rtnl_link_get_phys_port_id(struct rtnl_link *link) return link->l_phys_port_id; } +/** + * Return physical port name of link object + * @arg link Link object + * + * @return Physical port name or NULL if not set. + */ +char *rtnl_link_get_phys_port_name(struct rtnl_link *link) +{ + return link->l_phys_port_name; +} + void rtnl_link_set_ns_fd(struct rtnl_link *link, int fd) { link->l_ns_fd = fd; |