]> git.ipfire.org Git - thirdparty/iproute2.git/commitdiff
iplink: check for message truncation in iplink_get()
authorMichal Kubecek <mkubecek@suse.cz>
Fri, 1 Sep 2017 16:39:11 +0000 (18:39 +0200)
committerStephen Hemminger <stephen@networkplumber.org>
Fri, 1 Sep 2017 21:15:00 +0000 (14:15 -0700)
If message length exceeds maxlen argument of rtnl_talk(), it is truncated
to maxlen but unlike in the case of truncation to the length of local
buffer in rtnl_talk(), the caller doesn't get any indication of a problem.

In particular, iplink_get() passes the truncated message on and parsing it
results in various warnings and sometimes even a segfault (observed with
"ip link show dev ..." for a NIC with 125 VFs).

Handle message truncation in iplink_get() the same way as truncation in
rtnl_talk() would be handled: return an error.

Signed-off-by: Michal Kubecek <mkubecek@suse.cz>
ip/iplink.c

index 5aff2fde38dae1526cdbcd39f68b40dc9c18e555..790e3a138bb04c1baaf4ecf3664349fa411165cd 100644 (file)
@@ -1040,6 +1040,11 @@ int iplink_get(unsigned int flags, char *name, __u32 filt_mask)
 
        if (rtnl_talk(&rth, &req.n, &answer.n, sizeof(answer)) < 0)
                return -2;
+       if (answer.n.nlmsg_len > sizeof(answer.buf)) {
+               fprintf(stderr, "Message truncated from %u to %lu\n",
+                       answer.n.nlmsg_len, sizeof(answer.buf));
+               return -2;
+       }
 
        if (brief)
                print_linkinfo_brief(NULL, &answer.n, stdout, NULL);