[gnome-continuous-yocto/gnomeostree-3.28-rocko: 5536/8267] busybox: Security fix BUG9071



commit 104dac10f2c0fd60734157e974de3acbd0eb9a09
Author: Martin Balik <martin balik siemens com>
Date:   Wed Apr 5 12:38:57 2017 +0200

    busybox: Security fix BUG9071
    
    (From OE-Core rev: 0354a9b7adad27b012bcd6bb6cab54dfe0297bcd)
    
    Signed-off-by: Martin Balik <martin balik siemens com>
    Signed-off-by: Pascal Bach <pascal bach siemens com>
    Signed-off-by: Richard Purdie <richard purdie linuxfoundation org>

 .../busybox/BUG9071_buffer_overflow_arp.patch      |   53 ++++++++++++++++++++
 meta/recipes-core/busybox/busybox_1.24.1.bb        |    1 +
 2 files changed, 54 insertions(+), 0 deletions(-)
---
diff --git a/meta/recipes-core/busybox/busybox/BUG9071_buffer_overflow_arp.patch 
b/meta/recipes-core/busybox/busybox/BUG9071_buffer_overflow_arp.patch
new file mode 100644
index 0000000..828694c
--- /dev/null
+++ b/meta/recipes-core/busybox/busybox/BUG9071_buffer_overflow_arp.patch
@@ -0,0 +1,53 @@
+busybox1.24.1: Fix busybox - (local) cmdline stack buffer overwrite 
+
+[No upstream tracking] -- https://bugs.busybox.net/show_bug.cgi?id=9071
+
+busybox - (local) cmdline stack buffer overwrite 
+
+Busybox provides an `arp` applet which is missing an array bounds check for 
+command-line parameter `IFNAME`. It is therefore vulnerable to a command-line 
+based local stack buffer overwrite effectively allowing local users to write 
+past a 16 bytes fixed stack buffer. This leads to two scenarios, one (A) where 
+an IOCTL for GET_HW_ADDRESS (`SIOCGIFHWADDR`) fails and results in a corrupted 
+`va_list` being passed to `*printf()` and one (B) where an attacker might provide 
+valid params for the IOCTL and trick the program to proceed and result in a 
+`RET eip overwrite` eventually gaining code execution.
+
+Upstream-Status: Backport 
[https://git.busybox.net/busybox/commit/networking/arp.c?id=88e2b1cb626761b1924305b761a5dfc723613c4e]
+BUG: BUG9071
+Signed-off-by: Martin Balik <martin balik siemens com>
+Signed-off-by: Pascal Bach <pascal bach siemens com>
+
+--
+
+diff --git a/networking/arp.c b/networking/arp.c
+index 0099aa5..87eb327 100644
+--- a/networking/arp.c
++++ b/networking/arp.c
+@@ -176,7 +176,7 @@ static int arp_del(char **args)
+       if (flags == 0)
+               flags = 3;
+ 
+-      strncpy(req.arp_dev, device, sizeof(req.arp_dev));
++      strncpy_IFNAMSIZ(req.arp_dev, device);
+ 
+       err = -1;
+ 
+@@ -217,7 +217,7 @@ static void arp_getdevhw(char *ifname, struct sockaddr *sa)
+       struct ifreq ifr;
+       const struct hwtype *xhw;
+ 
+-      strcpy(ifr.ifr_name, ifname);
++      strncpy_IFNAMSIZ(ifr.ifr_name, ifname);
+       ioctl_or_perror_and_die(sockfd, SIOCGIFHWADDR, &ifr,
+                                       "can't get HW-Address for '%s'", ifname);
+       if (hw_set && (ifr.ifr_hwaddr.sa_family != hw->type)) {
+@@ -330,7 +330,7 @@ static int arp_set(char **args)
+       /* Fill in the remainder of the request. */
+       req.arp_flags = flags;
+ 
+-      strncpy(req.arp_dev, device, sizeof(req.arp_dev));
++      strncpy_IFNAMSIZ(req.arp_dev, device);
+ 
+       /* Call the kernel. */
+       if (option_mask32 & ARP_OPT_v)
diff --git a/meta/recipes-core/busybox/busybox_1.24.1.bb b/meta/recipes-core/busybox/busybox_1.24.1.bb
index 6013ec9..e26dfff 100644
--- a/meta/recipes-core/busybox/busybox_1.24.1.bb
+++ b/meta/recipes-core/busybox/busybox_1.24.1.bb
@@ -56,6 +56,7 @@ SRC_URI = "http://www.busybox.net/downloads/busybox-${PV}.tar.bz2;name=tarball \
            file://makefile-libbb-race.patch \
            file://0001-libiproute-handle-table-ids-larger-than-255.patch \
            file://ifupdown-pass-interface-device-name-for-ipv6-route-c.patch \
+           file://BUG9071_buffer_overflow_arp.patch \
 "
 SRC_URI_append_libc-musl = " file://musl.cfg "
 


[Date Prev][Date Next]   [Thread Prev][Thread Next]   [Thread Index] [Date Index] [Author Index]