1ae438b
--- xen-4.5.1/tools/qemu-xen-traditional/hw/ne2000.c.orig	2015-06-09 16:32:24.000000000 +0100
1ae438b
+++ xen-4.5.1/tools/qemu-xen-traditional/hw/ne2000.c	2015-09-26 17:27:49.494334726 +0100
1ae438b
@@ -304,6 +304,9 @@
1ae438b
     }
1ae438b
 
1ae438b
     index = s->curpag << 8;
1ae438b
+    if (index >= NE2000_PMEM_END) {
1ae438b
+        index = s->start;
1ae438b
+    }
1ae438b
     /* 4 bytes for header */
1ae438b
     total_len = size + 4;
1ae438b
     /* address for next packet (4 bytes for CRC) */
1ae438b
@@ -387,15 +390,21 @@
1ae438b
         offset = addr | (page << 4);
1ae438b
         switch(offset) {
1ae438b
         case EN0_STARTPG:
1ae438b
-            s->start = val << 8;
1ae438b
+            if (val << 8 <= NE2000_PMEM_END) {
1ae438b
+                s->start = val << 8;
1ae438b
+            }
1ae438b
             s->tainted = 1;
1ae438b
             break;
1ae438b
         case EN0_STOPPG:
1ae438b
-            s->stop = val << 8;
1ae438b
+            if (val << 8 <= NE2000_PMEM_END) {
1ae438b
+                s->stop = val << 8;
1ae438b
+            }
1ae438b
             s->tainted = 1;
1ae438b
             break;
1ae438b
         case EN0_BOUNDARY:
1ae438b
-            s->boundary = val;
1ae438b
+            if (val << 8 < NE2000_PMEM_END) {
1ae438b
+                s->boundary = val;
1ae438b
+            }
1ae438b
             break;
1ae438b
         case EN0_IMR:
1ae438b
             s->imr = val;
1ae438b
@@ -436,7 +445,9 @@
1ae438b
             s->phys[offset - EN1_PHYS] = val;
1ae438b
             break;
1ae438b
         case EN1_CURPAG:
1ae438b
-            s->curpag = val;
1ae438b
+            if (val << 8 < NE2000_PMEM_END) {
1ae438b
+                s->curpag = val;
1ae438b
+            }
1ae438b
             s->tainted = 1;
1ae438b
             break;
1ae438b
         case EN1_MULT ... EN1_MULT + 7: