summaryrefslogtreecommitdiffstats
path: root/lib/route/link.c
diff options
context:
space:
mode:
authorCong Wang <xiyou.wangcong@gmail.com>2013-12-04 04:16:09 (GMT)
committerThomas Graf <tgraf@suug.ch>2013-12-09 14:28:32 (GMT)
commit8b87ae55161f402c07aa8464d8d6164d46aa84d5 (patch)
tree166c28f587167972687b1935dd6131ead992365e /lib/route/link.c
parentb50a36bf34e7452377ab9bbb4d1873b68c65bf72 (diff)
downloadlibnl-8b87ae55161f402c07aa8464d8d6164d46aa84d5.zip
libnl-8b87ae55161f402c07aa8464d8d6164d46aa84d5.tar.gz
libnl-8b87ae55161f402c07aa8464d8d6164d46aa84d5.tar.bz2
fix rtnl_link_info_parse() and rtnl_link_fill_info()
So that the veth peer could be parsed correctly. Signed-off-by: Cong Wang <xiyou.wangcong@gmail.com> Signed-off-by: Thomas Graf <tgraf@suug.ch>
Diffstat (limited to 'lib/route/link.c')
-rw-r--r--lib/route/link.c30
1 files changed, 18 insertions, 12 deletions
diff --git a/lib/route/link.c b/lib/route/link.c
index 6c99e22..4bcf615 100644
--- a/lib/route/link.c
+++ b/lib/route/link.c
@@ -458,6 +458,16 @@ int rtnl_link_info_parse(struct rtnl_link *link, struct nlattr **tb)
link->ce_mask |= LINK_ATTR_IFALIAS;
}
+ if (tb[IFLA_NET_NS_FD]) {
+ link->l_ns_fd = nla_get_u32(tb[IFLA_NET_NS_FD]);
+ link->ce_mask |= LINK_ATTR_NS_FD;
+ }
+
+ if (tb[IFLA_NET_NS_PID]) {
+ link->l_ns_pid = nla_get_u32(tb[IFLA_NET_NS_PID]);
+ link->ce_mask |= LINK_ATTR_NS_PID;
+ }
+
return 0;
}
@@ -612,16 +622,6 @@ static int link_msg_parser(struct nl_cache_ops *ops, struct sockaddr_nl *who,
link->ce_mask |= LINK_ATTR_GROUP;
}
- if (tb[IFLA_NET_NS_FD]) {
- link->l_ns_fd = nla_get_u32(tb[IFLA_NET_NS_FD]);
- link->ce_mask |= LINK_ATTR_NS_FD;
- }
-
- if (tb[IFLA_NET_NS_FD]) {
- link->l_ns_pid = nla_get_u32(tb[IFLA_NET_NS_PID]);
- link->ce_mask |= LINK_ATTR_NS_PID;
- }
-
if (tb[IFLA_PHYS_PORT_ID]) {
link->l_phys_port_id = nl_data_alloc_attr(tb[IFLA_PHYS_PORT_ID]);
if (link->l_phys_port_id == NULL) {
@@ -1287,8 +1287,11 @@ int rtnl_link_fill_info(struct nl_msg *msg, struct rtnl_link *link)
if (link->ce_mask & LINK_ATTR_NUM_RX_QUEUES)
NLA_PUT_U32(msg, IFLA_NUM_RX_QUEUES, link->l_num_rx_queues);
- if (link->ce_mask & LINK_ATTR_GROUP)
- NLA_PUT_U32(msg, IFLA_GROUP, link->l_group);
+ if (link->ce_mask & LINK_ATTR_NS_FD)
+ NLA_PUT_U32(msg, IFLA_NET_NS_FD, link->l_ns_fd);
+
+ if (link->ce_mask & LINK_ATTR_NS_PID)
+ NLA_PUT_U32(msg, IFLA_NET_NS_PID, link->l_ns_pid);
return 0;
@@ -1312,6 +1315,9 @@ static int build_link_msg(int cmd, struct ifinfomsg *hdr,
if (rtnl_link_fill_info(msg, link))
goto nla_put_failure;
+ if (link->ce_mask & LINK_ATTR_GROUP)
+ NLA_PUT_U32(msg, IFLA_GROUP, link->l_group);
+
if (link->ce_mask & LINK_ATTR_LINKINFO) {
struct nlattr *info;