diff options
author | Prasad J Pandit <pjp@fedoraproject.org> | 2016-04-07 15:56:02 +0530 |
---|---|---|
committer | Jason Wang <jasowang@redhat.com> | 2016-05-25 15:46:07 +0800 |
commit | 3af9187fc6caaf415ab9c0c6d92c9678f65cb17f (patch) | |
tree | 25d97e4e95fe277643d573806fa58126768df212 /hw/net | |
parent | 11196e95f0521fa6ba689c15f874ad9a2d99e158 (diff) | |
download | qemu-3af9187fc6caaf415ab9c0c6d92c9678f65cb17f.zip qemu-3af9187fc6caaf415ab9c0c6d92c9678f65cb17f.tar.gz qemu-3af9187fc6caaf415ab9c0c6d92c9678f65cb17f.tar.bz2 |
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 <oleksandr.bazhaniuk@intel.com>
Signed-off-by: Prasad J Pandit <pjp@fedoraproject.org>
Signed-off-by: Jason Wang <jasowang@redhat.com>
Diffstat (limited to 'hw/net')
-rw-r--r-- | hw/net/mipsnet.c | 3 |
1 files changed, 3 insertions, 0 deletions
diff --git a/hw/net/mipsnet.c b/hw/net/mipsnet.c index 740cd98..cf8b823 100644 --- a/hw/net/mipsnet.c +++ b/hw/net/mipsnet.c @@ -83,6 +83,9 @@ static ssize_t mipsnet_receive(NetClientState *nc, const uint8_t *buf, size_t si if (!mipsnet_can_receive(nc)) return 0; + if (size >= sizeof(s->rx_buffer)) { + return 0; + } s->busy = 1; /* Just accept everything. */ |