]> git.ipfire.org Git - thirdparty/iproute2.git/commit
netns: Fix an off-by-one strcpy() in netns_map_add().
authorNicolas Cavallari <nicolas.cavallari@green-communications.fr>
Fri, 12 Feb 2016 13:47:39 +0000 (14:47 +0100)
committerStephen Hemminger <stephen@networkplumber.org>
Thu, 18 Feb 2016 01:35:31 +0000 (17:35 -0800)
commita1b4a274d4917be06b3060d3c8e95aba5c92a9a9
tree5d489c1722487e1a4fbf17e2fa103efa3f5faab4
parent385caeb13b4be08a2a142f28a836e0d535a3d8b9
netns: Fix an off-by-one strcpy() in netns_map_add().

netns_map_add() does a malloc of (sizeof (struct nsid_cache) +
strlen(name)) and then proceed with strcpy() of name into the
zero-length member at the end of the nsid_cache structure.  The
nul-terminator is written outside of the allocated memory and may
overwrite the allocator's internal structure.

This can trigger a segmentation fault on i386 uclibc with names of size 8:
after the corruption occurs, the call to closedir() on netns_map_init()
crashes while freeing the DIR structure.

Here is the relevant valgrind output:

==1251== Memcheck, a memory error detector
==1251== Copyright (C) 2002-2015, and GNU GPL'd, by Julian Seward et al.
==1251== Using Valgrind-3.11.0 and LibVEX; rerun with -h for copyright
info
==1251== Command: ./ip netns
==1251==
==1251== Invalid write of size 1
==1251==    at 0x4011975: strcpy (in
/usr/lib/valgrind/vgpreload_memcheck-x86-linux.so)
==1251==    by 0x8058B00: netns_map_add (ipnetns.c:181)
==1251==    by 0x8058E2A: netns_map_init (ipnetns.c:226)
==1251==    by 0x8058E79: do_netns (ipnetns.c:776)
==1251==    by 0x804D9FF: do_cmd (ip.c:110)
==1251==    by 0x804D814: main (ip.c:300)
ip/ipnetns.c