]> git.proxmox.com Git - mirror_iproute2.git/commitdiff
ipmonitor: decode DELNETCONF message
authorStephen Hemminger <sthemmin@microsoft.com>
Wed, 15 Aug 2018 21:29:42 +0000 (14:29 -0700)
committerStephen Hemminger <stephen@networkplumber.org>
Thu, 16 Aug 2018 16:50:34 +0000 (09:50 -0700)
When device is deleted DELNETCONF is sent, but ipmonitor
was unable to decode it.

Signed-off-by: Stephen Hemminger <stephen@networkplumber.org>
ip/ipmonitor.c
ip/ipnetconf.c

index 5552d98ee9e521b9aca0b83a5df07692c18f0571..a93b62cd6624cc0ee88046321cd887274678f59b 100644 (file)
@@ -133,6 +133,7 @@ static int accept_msg(const struct sockaddr_nl *who,
                return 0;
 
        case RTM_NEWNETCONF:
+       case RTM_DELNETCONF:
                print_headers(fp, "[NETCONF]", ctrl);
                print_netconf(who, ctrl, n, arg);
                return 0;
index 03f98ace91450fb1c5260a9fcac73169321a76a3..04c4d60807b15301b896679ac90881c89f1499dd 100644 (file)
@@ -66,8 +66,10 @@ int print_netconf(const struct sockaddr_nl *who, struct rtnl_ctrl_data *ctrl,
 
        if (n->nlmsg_type == NLMSG_ERROR)
                return -1;
-       if (n->nlmsg_type != RTM_NEWNETCONF) {
-               fprintf(stderr, "Not RTM_NEWNETCONF: %08x %08x %08x\n",
+
+       if (n->nlmsg_type != RTM_NEWNETCONF &&
+           n->nlmsg_type != RTM_DELNETCONF) {
+               fprintf(stderr, "Not a netconf message: %08x %08x %08x\n",
                        n->nlmsg_len, n->nlmsg_type, n->nlmsg_flags);
 
                return -1;
@@ -91,6 +93,9 @@ int print_netconf(const struct sockaddr_nl *who, struct rtnl_ctrl_data *ctrl,
                return 0;
 
        open_json_object(NULL);
+       if (n->nlmsg_type == RTM_DELNETCONF)
+               print_bool(PRINT_ANY, "deleted", "Deleted ", true);
+
        print_string(PRINT_ANY, "family",
                     "%s ", family_name(ncm->ncm_family));