fadd50c
------------------------------------------------------------------------
fadd50c
*From*: 	Gerd Hoffmann
fadd50c
*Subject*: 	[Qemu-devel] [PATCH 2/4] vmsvga: add more fifo checks
fadd50c
*Date*: 	Mon, 30 May 2016 09:09:19 +0200
fadd50c
fadd50c
------------------------------------------------------------------------
fadd50c
fadd50c
Make sure all fifo ptrs are within range.
fadd50c
fadd50c
Fixes: CVE-2016-4454
fadd50c
Cc: P J P <address@hidden>
fadd50c
Reported-by: 李强 <address@hidden>
fadd50c
Signed-off-by: Gerd Hoffmann <address@hidden>
fadd50c
---
fadd50c
 hw/display/vmware_vga.c | 5 ++++-
fadd50c
 1 file changed, 4 insertions(+), 1 deletion(-)
fadd50c
fadd50c
diff --git a/tools/qemu-xen/hw/display/vmware_vga.c b/hw/display/vmware_vga.c
fadd50c
index 63a7c05..a26e62e 100644
fadd50c
--- a/tools/qemu-xen/hw/display/vmware_vga.c
fadd50c
+++ b/tools/qemu-xen/hw/display/vmware_vga.c
fadd50c
@@ -563,7 +563,10 @@ static inline int vmsvga_fifo_length(struct vmsvga_state_s *s)
fadd50c
     if (CMD(min) < (uint8_t *) s->cmd->fifo - (uint8_t *) s->fifo) {
fadd50c
         return 0;
fadd50c
     }
fadd50c
-    if (CMD(max) > SVGA_FIFO_SIZE) {
fadd50c
+    if (CMD(max) > SVGA_FIFO_SIZE ||
fadd50c
+        CMD(min) >= SVGA_FIFO_SIZE ||
fadd50c
+        CMD(stop) >= SVGA_FIFO_SIZE ||
fadd50c
+        CMD(next_cmd) >= SVGA_FIFO_SIZE) {
fadd50c
         return 0;
fadd50c
     }
fadd50c
     if (CMD(max) < CMD(min) + 10 * 1024) {
fadd50c
-- 
fadd50c
1.8.3.1
fadd50c