diff options
author | Natanael Copa <ncopa@alpinelinux.org> | 2015-10-29 13:50:28 +0000 |
---|---|---|
committer | Natanael Copa <ncopa@alpinelinux.org> | 2015-10-29 15:18:02 +0000 |
commit | 1e0864dfc2222c7a623cf8eefa098700e17f304a (patch) | |
tree | 7dcb90c07506d5fd05bb677372277ad1e2791d70 /main/xen/xsa135-qemut-2.patch | |
parent | f3da078305d1ccc488e6948a1c1e9136edc21529 (diff) | |
download | aports-1e0864dfc2222c7a623cf8eefa098700e17f304a.tar.bz2 aports-1e0864dfc2222c7a623cf8eefa098700e17f304a.tar.xz |
main/xen: upgrade to 4.6.0 and fix sec issues
Diffstat (limited to 'main/xen/xsa135-qemut-2.patch')
-rw-r--r-- | main/xen/xsa135-qemut-2.patch | 46 |
1 files changed, 0 insertions, 46 deletions
diff --git a/main/xen/xsa135-qemut-2.patch b/main/xen/xsa135-qemut-2.patch deleted file mode 100644 index 2b0631af7c..0000000000 --- a/main/xen/xsa135-qemut-2.patch +++ /dev/null @@ -1,46 +0,0 @@ -From 2630672ab22255de252f877709851c0557a1c647 Mon Sep 17 00:00:00 2001 -From: Petr Matousek <pmatouse@redhat.com> -Date: Sun, 24 May 2015 10:53:44 +0200 -Subject: [PATCH] pcnet: force the buffer access to be in bounds during tx - -4096 is the maximum length per TMD and it is also currently the size of -the relay buffer pcnet driver uses for sending the packet data to QEMU -for further processing. With packet spanning multiple TMDs it can -happen that the overall packet size will be bigger than sizeof(buffer), -which results in memory corruption. - -Fix this by only allowing to queue maximum sizeof(buffer) bytes. - -This is CVE-2015-3209. - -Signed-off-by: Petr Matousek <pmatouse@redhat.com> -Reported-by: Matt Tait <matttait@google.com> -Reviewed-by: Peter Maydell <peter.maydell@linaro.org> -Reviewed-by: Stefan Hajnoczi <stefanha@redhat.com> ---- - hw/pcnet.c | 8 ++++++++ - 1 file changed, 8 insertions(+) - -diff --git a/hw/pcnet.c b/hw/pcnet.c -index bdfd38f..6d32e4c 100644 ---- a/tools/qemu-xen-traditional/hw/pcnet.c -+++ b/tools/qemu-xen-traditional/hw/pcnet.c -@@ -1241,6 +1241,14 @@ static void pcnet_transmit(PCNetState *s) - } - - bcnt = 4096 - GET_FIELD(tmd.length, TMDL, BCNT); -+ -+ /* if multi-tmd packet outsizes s->buffer then skip it silently. -+ Note: this is not what real hw does */ -+ if (s->xmit_pos + bcnt > sizeof(s->buffer)) { -+ s->xmit_pos = -1; -+ goto txdone; -+ } -+ - s->phys_mem_read(s->dma_opaque, PHYSADDR(s, tmd.tbadr), - s->buffer + s->xmit_pos, bcnt, CSR_BSWP(s)); - s->xmit_pos += bcnt; --- -2.1.0 - - |