From 7a2c32ec06533c54ddaf70136bfbd89eeaf6db16 Mon Sep 17 00:00:00 2001 From: Prasad J Pandit Date: Thu, 7 Apr 2016 15:56:02 +0530 Subject: [PATCH] net: mipsnet: check packet length against buffer When receiving packets over MIPSnet network device, it uses receive buffer of size 1514 bytes. In case the controller accepts large(MTU) packets, it could lead to memory corruption. Add check to avoid it. Reported by: Oleksandr Bazhaniuk Signed-off-by: Prasad J Pandit Signed-off-by: Jason Wang (cherry picked from commit 3af9187fc6caaf415ab9c0c6d92c9678f65cb17f) Signed-off-by: Michael Roth Upstream-Status: Backport CVE: CVE-2016-4002 Signed-off-by: Armin Kuster --- hw/net/mipsnet.c | 3 +++ 1 file changed, 3 insertions(+) Index: qemu-2.4.0/hw/net/mipsnet.c =================================================================== --- qemu-2.4.0.orig/hw/net/mipsnet.c +++ qemu-2.4.0/hw/net/mipsnet.c @@ -82,6 +82,9 @@ static ssize_t mipsnet_receive(NetClient if (!mipsnet_can_receive(nc)) return 0; + if (size >= sizeof(s->rx_buffer)) { + return 0; + } s->busy = 1; /* Just accept everything. */