[PATCH 03/27] netlink: add basic attribute parser of ifaddrmsg of NETLINK_ROUTE
JingPiao Chen
chenjingpiao at gmail.com
Tue Aug 15 04:41:11 UTC 2017
* rtnl_addr.c: Include "nlattr.h" and "xlat/rtnl_addr_attrs.h".
(decode_ifaddrmsg): Call decode_nlattr.
* xlat/rtnl_addr_attrs.in: New file.
Co-authored-by: Fabien Siron <fabien.siron at epita.fr>
---
rtnl_addr.c | 13 ++++++++++++-
xlat/rtnl_addr_attrs.in | 9 +++++++++
2 files changed, 21 insertions(+), 1 deletion(-)
create mode 100644 xlat/rtnl_addr_attrs.in
diff --git a/rtnl_addr.c b/rtnl_addr.c
index 905bc14..c7e37ea 100644
--- a/rtnl_addr.c
+++ b/rtnl_addr.c
@@ -29,6 +29,7 @@
#include "defs.h"
#include "netlink_route.h"
+#include "nlattr.h"
#include "print_fields.h"
#include "netlink.h"
@@ -39,11 +40,13 @@
#include "xlat/ifaddrflags.h"
#include "xlat/routing_scopes.h"
+#include "xlat/rtnl_addr_attrs.h"
DECL_NETLINK_ROUTE_DECODER(decode_ifaddrmsg)
{
struct ifaddrmsg ifaddr = { .ifa_family = family };
- const size_t offset = sizeof(ifaddr.ifa_family);
+ size_t offset = sizeof(ifaddr.ifa_family);
+ bool decode_nla = false;
PRINT_FIELD_XVAL("{", ifaddr, ifa_family, addrfams, "AF_???");
@@ -58,8 +61,16 @@ DECL_NETLINK_ROUTE_DECODER(decode_ifaddrmsg)
PRINT_FIELD_XVAL(", ", ifaddr, ifa_scope,
routing_scopes, NULL);
PRINT_FIELD_IFINDEX(", ", ifaddr, ifa_index);
+ decode_nla = true;
}
} else
tprints("...");
tprints("}");
+
+ offset = NLMSG_ALIGN(sizeof(ifaddr));
+ if (decode_nla && len > offset) {
+ tprints(", ");
+ decode_nlattr(tcp, addr + offset, len - offset,
+ rtnl_addr_attrs, "IFA_???", NULL, 0, NULL);
+ }
}
diff --git a/xlat/rtnl_addr_attrs.in b/xlat/rtnl_addr_attrs.in
new file mode 100644
index 0000000..df65905
--- /dev/null
+++ b/xlat/rtnl_addr_attrs.in
@@ -0,0 +1,9 @@
+IFA_UNSPEC 0
+IFA_ADDRESS 1
+IFA_LOCAL 2
+IFA_LABEL 3
+IFA_BROADCAST 4
+IFA_ANYCAST 5
+IFA_CACHEINFO 6
+IFA_MULTICAST 7
+IFA_FLAGS 8
--
2.7.4
More information about the Strace-devel
mailing list