Wed Oct 5 10:47:18 2016 UTC ()
Apply patch, requested my mrg in ticket 1410:
	xsrc/external/mit/libX11/dist/include/X11/Xlibint.h	patch
	xsrc/external/mit/libX11/dist/src/FontNames.c		patch
	xsrc/external/mit/libX11/dist/src/GetImage.c		patch
	xsrc/external/mit/libX11/dist/src/ListExt.c		patch
	xsrc/external/mit/libX11/dist/src/ModMap.c		patch
	xsrc/external/mit/libXfixes/dist/src/Region.c		patch
	xsrc/external/mit/libXi/dist/src/XGMotion.c		patch
	xsrc/external/mit/libXi/dist/src/XGetBMap.c		patch
	xsrc/external/mit/libXi/dist/src/XGetDCtl.c		patch
	xsrc/external/mit/libXi/dist/src/XGetFCtl.c		patch
	xsrc/external/mit/libXi/dist/src/XGetKMap.c		patch
	xsrc/external/mit/libXi/dist/src/XGetMMap.c		patch
	xsrc/external/mit/libXi/dist/src/XIQueryDevice.c	patch
	xsrc/external/mit/libXi/dist/src/XListDev.c		patch
	xsrc/external/mit/libXi/dist/src/XOpenDev.c		patch
	xsrc/external/mit/libXi/dist/src/XQueryDv.c		patch
	xsrc/external/mit/libXrandr/dist/src/XrrConfig.c	patch
	xsrc/external/mit/libXrandr/dist/src/XrrCrtc.c		patch
	xsrc/external/mit/libXrandr/dist/src/XrrOutput.c	patch
	xsrc/external/mit/libXrandr/dist/src/XrrProvider.c	patch
	xsrc/external/mit/libXrandr/dist/src/XrrScreen.c	patch
	xsrc/external/mit/libXrender/dist/src/Filter.c		patch
	xsrc/external/mit/libXrender/dist/src/Xrender.c		patch
	xsrc/external/mit/libXtst/dist/src/XRecord.c		patch
	xsrc/external/mit/libXv/dist/src/Xv.c			patch
	xsrc/external/mit/libXvMC/dist/src/XvMC.c		patch

Fix (backported from upstream) the following issues in X client
libraries:
libX11 - insufficient validation of data from the X server
	 can cause out of boundary memory read (XGetImage())
	 or write (XListFonts()).
	 Affected versions libX11 <= 1.6.3

libXfixes - insufficient validation of data from the X server
	can cause an integer overflow on 32 bit architectures.
	Affected versions : libXfixes <= 5.0.2

libXi - insufficient validation of data from the X server
	can cause out of boundary memory access or
	endless loops (Denial of Service).
	Affected versions libXi <= 1.7.6

libXrandr - insufficient validation of data from the X server
	can cause out of boundary memory writes.
	Affected versions: libXrandr <= 1.5.0

libXrender - insufficient validation of data from the X server
	can cause out of boundary memory writes.
	Affected version: libXrender <= 0.9.9

XRecord - insufficient validation of data from the X server
	can cause out of boundary memory access or
	endless loops (Denial of Service).
	 Affected version libXtst <= 1.2.2

libXv - insufficient validation of data from the X server
	can cause out of boundary memory and memory corruption.
	CVE-2016-5407
	affected versions libXv <= 1.0.10

libXvMC - insufficient validation of data from the X server
	can cause a one byte buffer read underrun.
	Affected versions: libXvMC <= 1.0.9


(bouyer)
diff -r1.1.1.7.2.1 -r1.1.1.7.2.2 xsrc/external/mit/libX11/dist/include/X11/Xlibint.h
diff -r1.1.1.4.2.1 -r1.1.1.4.2.2 xsrc/external/mit/libX11/dist/src/FontNames.c
diff -r1.1.1.4.2.1 -r1.1.1.4.2.2 xsrc/external/mit/libX11/dist/src/GetImage.c
diff -r1.1.1.4.2.1 -r1.1.1.4.2.2 xsrc/external/mit/libX11/dist/src/ModMap.c
diff -r1.1.1.3.2.1 -r1.1.1.3.2.2 xsrc/external/mit/libX11/dist/src/ListExt.c
diff -r1.1.1.2 -r1.1.1.2.2.1 xsrc/external/mit/libXfixes/dist/src/Region.c
diff -r1.1.1.3.2.1 -r1.1.1.3.2.2 xsrc/external/mit/libXi/dist/src/XGMotion.c
diff -r1.1.1.3.2.1 -r1.1.1.3.2.2 xsrc/external/mit/libXi/dist/src/XGetFCtl.c
diff -r1.1.1.3.2.1 -r1.1.1.3.2.2 xsrc/external/mit/libXi/dist/src/XListDev.c
diff -r1.1.1.3.2.1 -r1.1.1.3.2.2 xsrc/external/mit/libXi/dist/src/XQueryDv.c
diff -r1.1.1.2.2.1 -r1.1.1.2.2.2 xsrc/external/mit/libXi/dist/src/XGetBMap.c
diff -r1.1.1.4.2.1 -r1.1.1.4.2.2 xsrc/external/mit/libXi/dist/src/XGetDCtl.c
diff -r1.1.1.2 -r1.1.1.2.2.1 xsrc/external/mit/libXi/dist/src/XGetKMap.c
diff -r1.1.1.2 -r1.1.1.2.2.1 xsrc/external/mit/libXi/dist/src/XGetMMap.c
diff -r1.1.1.2 -r1.1.1.2.2.1 xsrc/external/mit/libXi/dist/src/XIQueryDevice.c
diff -r1.1.1.2 -r1.1.1.2.2.1 xsrc/external/mit/libXi/dist/src/XOpenDev.c
diff -r1.1.1.3 -r1.1.1.3.2.1 xsrc/external/mit/libXrandr/dist/src/XrrConfig.c
diff -r1.1.1.3 -r1.1.1.3.2.1 xsrc/external/mit/libXrandr/dist/src/XrrCrtc.c
diff -r1.1.1.2 -r1.1.1.2.2.1 xsrc/external/mit/libXrandr/dist/src/XrrOutput.c
diff -r1.1.1.2 -r1.1.1.2.2.1 xsrc/external/mit/libXrandr/dist/src/XrrScreen.c
diff -r1.1.1.3.2.1 -r1.1.1.3.2.2 xsrc/external/mit/libXrender/dist/src/Filter.c
diff -r1.1.1.2.2.1 -r1.1.1.2.2.2 xsrc/external/mit/libXrender/dist/src/Xrender.c
diff -r1.1.1.3 -r1.1.1.3.2.1 xsrc/external/mit/libXtst/dist/src/XRecord.c
diff -r1.1.1.2.2.1 -r1.1.1.2.2.2 xsrc/external/mit/libXv/dist/src/Xv.c
diff -r1.1.1.2.2.1 -r1.1.1.2.2.2 xsrc/external/mit/libXvMC/dist/src/XvMC.c

cvs diff -r1.1.1.7.2.1 -r1.1.1.7.2.2 xsrc/external/mit/libX11/dist/include/X11/Xlibint.h (expand / switch to context diff)
--- xsrc/external/mit/libX11/dist/include/X11/Xlibint.h 2015/04/19 05:48:29 1.1.1.7.2.1
+++ xsrc/external/mit/libX11/dist/include/X11/Xlibint.h 2016/10/05 10:47:17 1.1.1.7.2.2
@@ -550,7 +550,7 @@
     unsigned long _BRlen = req->length - 1; \
     req->length = 0; \
     memcpy(_BRdat, ((char *)req) + (_BRlen << 2), 4); \
-    memmove(((char *)req) + 8, ((char *)req) + 4, _BRlen << 2); \
+    memmove(((char *)req) + 8, ((char *)req) + 4, (_BRlen - 1) << 2); \
     memcpy(((char *)req) + 4, _BRdat, 4); \
     Data32(dpy, (long *)&_BRdat, 4); \
     }

cvs diff -r1.1.1.4.2.1 -r1.1.1.4.2.2 xsrc/external/mit/libX11/dist/src/FontNames.c (expand / switch to context diff)
--- xsrc/external/mit/libX11/dist/src/FontNames.c 2013/06/06 03:44:25 1.1.1.4.2.1
+++ xsrc/external/mit/libX11/dist/src/FontNames.c 2016/10/05 10:47:17 1.1.1.4.2.2
@@ -66,7 +66,7 @@
 
     if (rep.nFonts) {
 	flist = Xmalloc (rep.nFonts * sizeof(char *));
-	if (rep.length < (LONG_MAX >> 2)) {
+	if (rep.length > 0 && rep.length < (INT_MAX >> 2)) {
 	    rlen = rep.length << 2;
 	    ch = Xmalloc(rlen + 1);
 	    /* +1 to leave room for last null-terminator */
@@ -93,11 +93,22 @@
 	    if (ch + length < chend) {
 		flist[i] = ch + 1;  /* skip over length */
 		ch += length + 1;  /* find next length ... */
-		length = *(unsigned char *)ch;
-		*ch = '\0';  /* and replace with null-termination */
-		count++;
-	    } else
-		flist[i] = NULL;
+		if (ch <= chend) {
+		    length = *(unsigned char *)ch;
+		    *ch = '\0';  /* and replace with null-termination */
+		    count++;
+		} else {
+                    Xfree(flist);
+                    flist = NULL;
+                    count = 0;
+                    break;
+		}
+	    } else {
+                Xfree(flist);
+                flist = NULL;
+                count = 0;
+                break;
+            }
 	}
     }
     *actualCount = count;

cvs diff -r1.1.1.4.2.1 -r1.1.1.4.2.2 xsrc/external/mit/libX11/dist/src/GetImage.c (expand / switch to context diff)
--- xsrc/external/mit/libX11/dist/src/GetImage.c 2013/06/06 03:44:25 1.1.1.4.2.1
+++ xsrc/external/mit/libX11/dist/src/GetImage.c 2016/10/05 10:47:17 1.1.1.4.2.2
@@ -59,6 +59,7 @@
 	char *data;
 	unsigned long nbytes;
 	XImage *image;
+	int planes;
 	LockDisplay(dpy);
 	GetReq (GetImage, req);
 	/*
@@ -91,18 +92,28 @@
 	    return (XImage *) NULL;
 	}
         _XReadPad (dpy, data, nbytes);
-        if (format == XYPixmap)
-	   image = XCreateImage(dpy, _XVIDtoVisual(dpy, rep.visual),
-		  Ones (plane_mask &
-			(((unsigned long)0xFFFFFFFF) >> (32 - rep.depth))),
-		  format, 0, data, width, height, dpy->bitmap_pad, 0);
-	else /* format == ZPixmap */
-           image = XCreateImage (dpy, _XVIDtoVisual(dpy, rep.visual),
-		 rep.depth, ZPixmap, 0, data, width, height,
-		  _XGetScanlinePad(dpy, (int) rep.depth), 0);
+        if (format == XYPixmap) {
+	    image = XCreateImage(dpy, _XVIDtoVisual(dpy, rep.visual),
+		Ones (plane_mask &
+		    (((unsigned long)0xFFFFFFFF) >> (32 - rep.depth))),
+		format, 0, data, width, height, dpy->bitmap_pad, 0);
+	    planes = image->depth;
+	} else { /* format == ZPixmap */
+            image = XCreateImage (dpy, _XVIDtoVisual(dpy, rep.visual),
+		rep.depth, ZPixmap, 0, data, width, height,
+		    _XGetScanlinePad(dpy, (int) rep.depth), 0);
+	    planes = 1;
+	}
 
 	if (!image)
 	    Xfree(data);
+	if (planes < 1 || image->height < 1 || image->bytes_per_line < 1 ||
+	    INT_MAX / image->height <= image->bytes_per_line ||
+	    INT_MAX / planes <= image->height * image->bytes_per_line ||
+	    nbytes < planes * image->height * image->bytes_per_line) {
+	    XDestroyImage(image);
+	    image = NULL;
+	}
 	UnlockDisplay(dpy);
 	SyncHandle();
 	return (image);

cvs diff -r1.1.1.4.2.1 -r1.1.1.4.2.2 xsrc/external/mit/libX11/dist/src/ModMap.c (expand / switch to context diff)
--- xsrc/external/mit/libX11/dist/src/ModMap.c 2013/06/06 03:44:25 1.1.1.4.2.1
+++ xsrc/external/mit/libX11/dist/src/ModMap.c 2016/10/05 10:47:17 1.1.1.4.2.2
@@ -42,7 +42,8 @@
     GetEmptyReq(GetModifierMapping, req);
     (void) _XReply (dpy, (xReply *)&rep, 0, xFalse);
 
-    if (rep.length < (LONG_MAX >> 2)) {
+    if (rep.length < (INT_MAX >> 2) &&
+	(rep.length >> 1) == rep.numKeyPerModifier) {
 	nbytes = (unsigned long)rep.length << 2;
 	res = Xmalloc(sizeof (XModifierKeymap));
 	if (res)

cvs diff -r1.1.1.3.2.1 -r1.1.1.3.2.2 xsrc/external/mit/libX11/dist/src/ListExt.c (expand / switch to context diff)
--- xsrc/external/mit/libX11/dist/src/ListExt.c 2013/06/06 03:44:25 1.1.1.3.2.1
+++ xsrc/external/mit/libX11/dist/src/ListExt.c 2016/10/05 10:47:17 1.1.1.3.2.2
@@ -55,7 +55,7 @@
 
 	if (rep.nExtensions) {
 	    list = Xmalloc (rep.nExtensions * sizeof (char *));
-	    if (rep.length < (LONG_MAX >> 2)) {
+	    if (rep.length > 0 && rep.length < (INT_MAX >> 2)) {
 		rlen = rep.length << 2;
 		ch = Xmalloc (rlen + 1);
                 /* +1 to leave room for last null-terminator */
@@ -80,9 +80,13 @@
 		if (ch + length < chend) {
 		    list[i] = ch+1;  /* skip over length */
 		    ch += length + 1; /* find next length ... */
-		    length = *ch;
-		    *ch = '\0'; /* and replace with null-termination */
-		    count++;
+		    if (ch <= chend) {
+			length = *ch;
+			*ch = '\0'; /* and replace with null-termination */
+			count++;
+		    } else {
+			list[i] = NULL;
+		    }
 		} else
 		    list[i] = NULL;
 	    }

cvs diff -r1.1.1.2 -r1.1.1.2.2.1 xsrc/external/mit/libXfixes/dist/src/Region.c (expand / switch to context diff)
--- xsrc/external/mit/libXfixes/dist/src/Region.c 2009/11/08 09:43:06 1.1.1.2
+++ xsrc/external/mit/libXfixes/dist/src/Region.c 2016/10/05 10:47:17 1.1.1.2.2.1
@@ -23,6 +23,7 @@
 #ifdef HAVE_CONFIG_H
 #include <config.h>
 #endif
+#include <limits.h>
 #include "Xfixesint.h"
 
 XserverRegion
@@ -333,10 +334,17 @@
     bounds->y = rep.y;
     bounds->width = rep.width;
     bounds->height = rep.height;
-    nbytes = (long) rep.length << 2;
-    nrects = rep.length >> 1;
-    nread = nrects << 3;
-    rects = Xmalloc (nrects * sizeof (XRectangle));
+    if (rep.length < (INT_MAX >> 2)) {
+	nbytes = (long) rep.length << 2;
+	nrects = rep.length >> 1;
+	nread = nrects << 3;
+	rects = Xmalloc (nrects * sizeof (XRectangle));
+    } else {
+	nbytes = 0;
+	nrects = 0;
+	nread = 0;
+	rects = NULL;
+    }
     if (!rects)
     {
 	_XEatData (dpy, nbytes);

cvs diff -r1.1.1.3.2.1 -r1.1.1.3.2.2 xsrc/external/mit/libXi/dist/src/XGMotion.c (expand / switch to context diff)
--- xsrc/external/mit/libXi/dist/src/XGMotion.c 2013/06/06 03:44:25 1.1.1.3.2.1
+++ xsrc/external/mit/libXi/dist/src/XGMotion.c 2016/10/05 10:47:17 1.1.1.3.2.2
@@ -111,7 +111,8 @@
     }
     /* rep.axes is a CARD8, so assume max number of axes for bounds check */
     if (rep.nEvents <
-	(INT_MAX / (sizeof(XDeviceTimeCoord) + (UCHAR_MAX * sizeof(int))))) {
+	(INT_MAX / (sizeof(XDeviceTimeCoord) + (UCHAR_MAX * sizeof(int)))) &&
+	rep.nEvents * (rep.axes + 1) <= rep.length) {
 	size_t bsize = rep.nEvents *
 	    (sizeof(XDeviceTimeCoord) + (rep.axes * sizeof(int)));
 	bufp = Xmalloc(bsize);

cvs diff -r1.1.1.3.2.1 -r1.1.1.3.2.2 xsrc/external/mit/libXi/dist/src/XGetFCtl.c (expand / switch to context diff)
--- xsrc/external/mit/libXi/dist/src/XGetFCtl.c 2013/06/06 03:44:25 1.1.1.3.2.1
+++ xsrc/external/mit/libXi/dist/src/XGetFCtl.c 2016/10/05 10:47:17 1.1.1.3.2.2
@@ -69,6 +69,7 @@
     XFeedbackState *Sav = NULL;
     xFeedbackState *f = NULL;
     xFeedbackState *sav = NULL;
+    char *end = NULL;
     xGetFeedbackControlReq *req;
     xGetFeedbackControlReply rep;
     XExtDisplayInfo *info = XInput_find_display(dpy);
@@ -101,10 +102,12 @@
 	    goto out;
 	}
 	sav = f;
+	end = (char *)f + nbytes;
 	_XRead(dpy, (char *)f, nbytes);
 
 	for (i = 0; i < *num_feedbacks; i++) {
-	    if (f->length > nbytes)
+	    if ((char *)f + sizeof(*f) > end ||
+	        f->length == 0 || f->length > nbytes)
 		goto out;
 	    nbytes -= f->length;
 
@@ -122,6 +125,8 @@
 	    {
 		xStringFeedbackState *strf = (xStringFeedbackState *) f;
 
+		if ((char *)f + sizeof(*strf) > end)
+		    goto out;
 		if (strf->num_syms_supported >= (INT_MAX / sizeof(KeySym)))
 		    goto out;
 		size += sizeof(XStringFeedbackState) +

cvs diff -r1.1.1.3.2.1 -r1.1.1.3.2.2 xsrc/external/mit/libXi/dist/src/XListDev.c (expand / switch to context diff)
--- xsrc/external/mit/libXi/dist/src/XListDev.c 2013/06/06 03:44:25 1.1.1.3.2.1
+++ xsrc/external/mit/libXi/dist/src/XListDev.c 2016/10/05 10:47:17 1.1.1.3.2.2
@@ -60,7 +60,7 @@
 #include <limits.h>
 
 static size_t
-SizeClassInfo(xAnyClassPtr *any, int num_classes)
+SizeClassInfo(xAnyClassPtr *any, size_t len, int num_classes)
 {
     int size = 0;
     int j;
@@ -76,6 +76,8 @@
                 {
                     xValuatorInfoPtr v;
 
+                    if (len < sizeof(v))
+                        return 0;
                     v = (xValuatorInfoPtr) *any;
                     size += sizeof(XValuatorInfo) +
                         (v->num_axes * sizeof(XAxisInfo));
@@ -84,6 +86,8 @@
             default:
                 break;
         }
+        if ((*any)->length > len)
+            return 0;
         *any = (xAnyClassPtr) ((char *)(*any) + (*any)->length);
     }
 
@@ -155,7 +159,7 @@
     register Display	*dpy,
     int			*ndevices)
 {
-    size_t size;
+    size_t s, size;
     xListInputDevicesReq *req;
     xListInputDevicesReply rep;
     xDeviceInfo *list, *slist = NULL;
@@ -163,6 +167,7 @@
     XDeviceInfo *clist = NULL;
     xAnyClassPtr any, sav_any;
     XAnyClassPtr Any;
+    char *end = NULL;
     unsigned char *nptr, *Nptr;
     int i;
     unsigned long rlen;
@@ -198,16 +203,20 @@
 
 	any = (xAnyClassPtr) ((char *)list + (*ndevices * sizeof(xDeviceInfo)));
 	sav_any = any;
+	end = (char *)list + rlen;
 	for (i = 0; i < *ndevices; i++, list++) {
-            size += SizeClassInfo(&any, (int)list->num_classes);
+            s = SizeClassInfo(&any, end - (char *)any, (int)list->num_classes);
+            if (!s)
+                goto out;
+            size += s;
 	}
 
-	Nptr = ((unsigned char *)list) + rlen + 1;
+	Nptr = ((unsigned char *)list) + rlen;
 	for (i = 0, nptr = (unsigned char *)any; i < *ndevices; i++) {
+	    if (nptr >= Nptr)
+		goto out;
 	    size += *nptr + 1;
 	    nptr += (*nptr + 1);
-	    if (nptr > Nptr)
-		goto out;
 	}
 
 	clist = (XDeviceInfoPtr) Xmalloc(size);

cvs diff -r1.1.1.3.2.1 -r1.1.1.3.2.2 xsrc/external/mit/libXi/dist/src/XQueryDv.c (expand / switch to context diff)
--- xsrc/external/mit/libXi/dist/src/XQueryDv.c 2013/06/06 03:44:25 1.1.1.3.2.1
+++ xsrc/external/mit/libXi/dist/src/XQueryDv.c 2016/10/05 10:47:17 1.1.1.3.2.2
@@ -70,7 +70,7 @@
     xQueryDeviceStateReply rep;
     XDeviceState *state = NULL;
     XInputClass *any, *Any;
-    char *data = NULL;
+    char *data = NULL, *end = NULL;
     XExtDisplayInfo *info = XInput_find_display(dpy);
 
     LockDisplay(dpy);
@@ -89,6 +89,7 @@
 	if (rep.length < (INT_MAX >> 2)) {
 	    rlen = (unsigned long) rep.length << 2;
 	    data = Xmalloc(rlen);
+	    end = data + rlen;
 	}
 	if (!data) {
 	    _XEatData(dpy, (unsigned long)rlen);
@@ -97,7 +98,8 @@
 	_XRead(dpy, data, rlen);
 
 	for (i = 0, any = (XInputClass *) data; i < (int)rep.num_classes; i++) {
-	    if (any->length > rlen)
+	    if ((char *)any + sizeof(XInputClass) > end ||
+		any->length == 0 || any->length > rlen)
 		goto out;
 	    rlen -= any->length;
 
@@ -111,6 +113,8 @@
 	    case ValuatorClass:
 	    {
 		xValuatorState *v = (xValuatorState *) any;
+		if ((char *)any + sizeof(xValuatorState) > end)
+		    goto out;
 		size += (sizeof(XValuatorState) +
 			 (v->num_valuators * sizeof(int)));
 	    }

cvs diff -r1.1.1.2.2.1 -r1.1.1.2.2.2 xsrc/external/mit/libXi/dist/src/XGetBMap.c (expand / switch to context diff)
--- xsrc/external/mit/libXi/dist/src/XGetBMap.c 2013/06/06 03:44:25 1.1.1.2.2.1
+++ xsrc/external/mit/libXi/dist/src/XGetBMap.c 2016/10/05 10:47:17 1.1.1.2.2.2
@@ -88,7 +88,8 @@
 
     status = _XReply(dpy, (xReply *) & rep, 0, xFalse);
     if (status == 1) {
-	if (rep.length <= (sizeof(mapping) >> 2)) {
+	if (rep.length <= (sizeof(mapping) >> 2) &&
+	    rep.nElts <= (rep.length << 2)) {
 	    unsigned long nbytes = rep.length << 2;
 	    _XRead(dpy, (char *)mapping, nbytes);
 

cvs diff -r1.1.1.4.2.1 -r1.1.1.4.2.2 xsrc/external/mit/libXi/dist/src/XGetDCtl.c (expand / switch to context diff)
--- xsrc/external/mit/libXi/dist/src/XGetDCtl.c 2013/06/06 03:44:25 1.1.1.4.2.1
+++ xsrc/external/mit/libXi/dist/src/XGetDCtl.c 2016/10/05 10:47:17 1.1.1.4.2.2
@@ -89,7 +89,8 @@
     if (rep.length > 0) {
 	unsigned long nbytes;
 	size_t size = 0;
-	if (rep.length < (INT_MAX >> 2)) {
+	if (rep.length < (INT_MAX >> 2) &&
+	    (rep.length << 2) >= sizeof(xDeviceState)) {
 	    nbytes = (unsigned long) rep.length << 2;
 	    d = Xmalloc(nbytes);
 	}
@@ -113,7 +114,8 @@
 	    size_t val_size;
 
 	    r = (xDeviceResolutionState *) d;
-	    if (r->num_valuators >= (INT_MAX / (3 * sizeof(int))))
+	    if (sizeof(xDeviceResolutionState) > nbytes ||
+		r->num_valuators >= (INT_MAX / (3 * sizeof(int))))
 		goto out;
 	    val_size = 3 * sizeof(int) * r->num_valuators;
 	    if ((sizeof(xDeviceResolutionState) + val_size) > nbytes)

cvs diff -r1.1.1.2 -r1.1.1.2.2.1 xsrc/external/mit/libXi/dist/src/XGetKMap.c (expand / switch to context diff)
--- xsrc/external/mit/libXi/dist/src/XGetKMap.c 2010/05/22 01:04:37 1.1.1.2
+++ xsrc/external/mit/libXi/dist/src/XGetKMap.c 2016/10/05 10:47:17 1.1.1.2.2.1
@@ -50,6 +50,7 @@
  *
  */
 
+#include <limits.h>
 #include <X11/extensions/XI.h>
 #include <X11/extensions/XIproto.h>
 #include <X11/Xlibint.h>
@@ -89,9 +90,16 @@
 	return (KeySym *) NULL;
     }
     if (rep.length > 0) {
-	*syms_per_code = rep.keySymsPerKeyCode;
-	nbytes = (long)rep.length << 2;
-	mapping = (KeySym *) Xmalloc((unsigned)nbytes);
+	if (rep.length < INT_MAX >> 2 &&
+	    rep.length == rep.keySymsPerKeyCode * keycount) {
+	    *syms_per_code = rep.keySymsPerKeyCode;
+	    nbytes = (long)rep.length << 2;
+	    mapping = (KeySym *) Xmalloc((unsigned)nbytes);
+	} else {
+	    *syms_per_code = 0;
+	    nbytes = 0;
+	    mapping = NULL;
+	}
 	if (mapping)
 	    _XRead(dpy, (char *)mapping, nbytes);
 	else

cvs diff -r1.1.1.2 -r1.1.1.2.2.1 xsrc/external/mit/libXi/dist/src/XGetMMap.c (expand / switch to context diff)
--- xsrc/external/mit/libXi/dist/src/XGetMMap.c 2010/05/22 01:04:37 1.1.1.2
+++ xsrc/external/mit/libXi/dist/src/XGetMMap.c 2016/10/05 10:47:17 1.1.1.2.2.1
@@ -50,6 +50,7 @@
  *
  */
 
+#include <limits.h>
 #include <X11/extensions/XI.h>
 #include <X11/extensions/XIproto.h>
 #include <X11/Xlibint.h>
@@ -82,8 +83,14 @@
 	SyncHandle();
 	return (XModifierKeymap *) NULL;
     }
-    nbytes = (unsigned long)rep.length << 2;
-    res = (XModifierKeymap *) Xmalloc(sizeof(XModifierKeymap));
+    if (rep.length < (INT_MAX >> 2) &&
+	rep.numKeyPerModifier == rep.length >> 1) {
+	nbytes = (unsigned long)rep.length << 2;
+	res = (XModifierKeymap *) Xmalloc(sizeof(XModifierKeymap));
+    } else {
+	nbytes = 0;
+	res = NULL;
+    }
     if (res) {
 	res->modifiermap = (KeyCode *) Xmalloc(nbytes);
 	if (res->modifiermap)

cvs diff -r1.1.1.2 -r1.1.1.2.2.1 xsrc/external/mit/libXi/dist/src/XIQueryDevice.c (expand / switch to context diff)
--- xsrc/external/mit/libXi/dist/src/XIQueryDevice.c 2011/07/23 12:22:26 1.1.1.2
+++ xsrc/external/mit/libXi/dist/src/XIQueryDevice.c 2016/10/05 10:47:17 1.1.1.2.2.1
@@ -22,6 +22,7 @@
  *
  */
 
+#include <limits.h>
 #include <stdint.h>
 #include <X11/Xlibint.h>
 #include <X11/extensions/XI2proto.h>
@@ -39,6 +40,7 @@
     xXIQueryDeviceReq   *req;
     xXIQueryDeviceReply reply;
     char                *ptr;
+    char                *end;
     int                 i;
     char                *buf;
 
@@ -56,14 +58,24 @@
     if (!_XReply(dpy, (xReply*) &reply, 0, xFalse))
         goto error;
 
-    *ndevices_return = reply.num_devices;
-    info = Xmalloc((reply.num_devices + 1) * sizeof(XIDeviceInfo));
+    if (reply.length < INT_MAX / 4)
+    {
+	*ndevices_return = reply.num_devices;
+	info = Xmalloc((reply.num_devices + 1) * sizeof(XIDeviceInfo));
+    }
+    else
+    {
+	*ndevices_return = 0;
+	info = NULL;
+    }
+
     if (!info)
         goto error;
 
     buf = Xmalloc(reply.length * 4);
     _XRead(dpy, buf, reply.length * 4);
     ptr = buf;
+    end = buf + reply.length * 4;
 
     /* info is a null-terminated array */
     info[reply.num_devices].name = NULL;
@@ -73,6 +85,9 @@
         XIDeviceInfo    *lib = &info[i];
         xXIDeviceInfo   *wire = (xXIDeviceInfo*)ptr;
 
+        if (ptr + sizeof(xXIDeviceInfo) > end)
+            goto error_loop;
+
         lib->deviceid    = wire->deviceid;
         lib->use         = wire->use;
         lib->attachment  = wire->attachment;
@@ -82,11 +97,22 @@
 
         ptr += sizeof(xXIDeviceInfo);
 
+        if (ptr + wire->name_len > end)
+            goto error_loop;
+
         lib->name = Xcalloc(wire->name_len + 1, 1);
+        if (lib->name == NULL)
+            goto error_loop;
         strncpy(lib->name, ptr, wire->name_len);
+        lib->name[wire->name_len] = '\0';
         ptr += ((wire->name_len + 3)/4) * 4;
 
         lib->classes = Xmalloc(size_classes((xXIAnyInfo*)ptr, lib->num_classes));
+        if (lib->classes == NULL)
+        {
+            Xfree(lib->name);
+            goto error_loop;
+        }
         ptr += copy_classes(lib, (xXIAnyInfo*)ptr, lib->num_classes);
     }
 
@@ -95,6 +121,12 @@
     SyncHandle();
     return info;
 
+error_loop:
+    while (--i >= 0)
+    {
+        Xfree(info[i].name);
+        Xfree(info[i].classes);
+    }
 error:
     UnlockDisplay(dpy);
     SyncHandle();

cvs diff -r1.1.1.2 -r1.1.1.2.2.1 xsrc/external/mit/libXi/dist/src/XOpenDev.c (expand / switch to context diff)
--- xsrc/external/mit/libXi/dist/src/XOpenDev.c 2010/05/22 01:04:37 1.1.1.2
+++ xsrc/external/mit/libXi/dist/src/XOpenDev.c 2016/10/05 10:47:17 1.1.1.2.2.1
@@ -50,6 +50,7 @@
  *
  */
 
+#include <limits.h>
 #include <X11/extensions/XI.h>
 #include <X11/extensions/XIproto.h>
 #include <X11/Xlibint.h>
@@ -83,9 +84,15 @@
 	return (XDevice *) NULL;
     }
 
-    rlen = rep.length << 2;
-    dev = (XDevice *) Xmalloc(sizeof(XDevice) + rep.num_classes *
-			      sizeof(XInputClassInfo));
+    if (rep.length < INT_MAX >> 2 &&
+	(rep.length << 2) >= rep.num_classes * sizeof(xInputClassInfo)) {
+	rlen = rep.length << 2;
+	dev = (XDevice *) Xmalloc(sizeof(XDevice) + rep.num_classes *
+				  sizeof(XInputClassInfo));
+    } else {
+	rlen = 0;
+	dev = NULL;
+    }
     if (dev) {
 	int dlen;	/* data length */
 

cvs diff -r1.1.1.3 -r1.1.1.3.2.1 xsrc/external/mit/libXrandr/dist/src/XrrConfig.c (expand / switch to context diff)
--- xsrc/external/mit/libXrandr/dist/src/XrrConfig.c 2010/11/21 05:48:25 1.1.1.3
+++ xsrc/external/mit/libXrandr/dist/src/XrrConfig.c 2016/10/05 10:47:17 1.1.1.3.2.1
@@ -29,6 +29,7 @@
 #include <config.h>
 #endif
 
+#include <limits.h>
 #include <stdio.h>
 #include <X11/Xlib.h>
 /* we need to be able to manipulate the Display structure on events */
@@ -273,22 +274,32 @@
 	rep.nrateEnts = 0;
     }
     
-    nbytes = (long) rep.length << 2;
+    if (rep.length < INT_MAX >> 2) {
+	nbytes = (long) rep.length << 2;
 
+	nbytesRead = (long) (rep.nSizes * SIZEOF (xScreenSizes) +
+			    ((rep.nrateEnts + 1)& ~1) * 2 /* SIZEOF(CARD16) */);
+
     nbytesRead = (long) (rep.nSizes * SIZEOF (xScreenSizes) +
 			 ((rep.nrateEnts + 1)& ~1) * 2 /* SIZEOF (CARD16) */);
-    
-    /* 
-     * first we must compute how much space to allocate for 
-     * randr library's use; we'll allocate the structures in a single
-     * allocation, on cleanlyness grounds.
-     */
+	/*
+	 * first we must compute how much space to allocate for
+	 * randr library's use; we'll allocate the structures in a single
+	 * allocation, on cleanlyness grounds.
+	 */
 
-    rbytes = sizeof (XRRScreenConfiguration) +
-      (rep.nSizes * sizeof (XRRScreenSize) +
-       rep.nrateEnts * sizeof (int));
+	rbytes = sizeof (XRRScreenConfiguration) +
+	  (rep.nSizes * sizeof (XRRScreenSize) +
+	   rep.nrateEnts * sizeof (int));
 
-    scp = (struct _XRRScreenConfiguration *) Xmalloc(rbytes);
+	scp = (struct _XRRScreenConfiguration *) Xmalloc(rbytes);
+    } else {
+	nbytes = 0;
+	nbytesRead = 0;
+	rbytes = 0;
+	scp = NULL;
+    }
+    
     if (scp == NULL) {
 	_XEatData (dpy, (unsigned long) nbytes);
 	return NULL;

cvs diff -r1.1.1.3 -r1.1.1.3.2.1 xsrc/external/mit/libXrandr/dist/src/XrrCrtc.c (expand / switch to context diff)
--- xsrc/external/mit/libXrandr/dist/src/XrrCrtc.c 2010/11/21 05:48:25 1.1.1.3
+++ xsrc/external/mit/libXrandr/dist/src/XrrCrtc.c 2016/10/05 10:47:17 1.1.1.3.2.1
@@ -24,6 +24,7 @@
 #include <config.h>
 #endif
 
+#include <limits.h>
 #include <stdio.h>
 #include <X11/Xlib.h>
 /* we need to be able to manipulate the Display structure on events */
@@ -57,22 +58,33 @@
 	return NULL;
     }
 
-    nbytes = (long) rep.length << 2;
+    if (rep.length < INT_MAX >> 2)
+    {
+	nbytes = (long) rep.length << 2;
 
-    nbytesRead = (long) (rep.nOutput * 4 +
-			 rep.nPossibleOutput * 4);
+	nbytesRead = (long) (rep.nOutput * 4 +
+			     rep.nPossibleOutput * 4);
 
-    /* 
-     * first we must compute how much space to allocate for 
-     * randr library's use; we'll allocate the structures in a single
-     * allocation, on cleanlyness grounds.
-     */
+	/* 
+	* first we must compute how much space to allocate for 
+	* randr library's use; we'll allocate the structures in a single
+	* allocation, on cleanlyness grounds.
+	*/
 
-    rbytes = (sizeof (XRRCrtcInfo) +
-	      rep.nOutput * sizeof (RROutput) +
-	      rep.nPossibleOutput * sizeof (RROutput));
+	rbytes = (sizeof (XRRCrtcInfo) +
+		  rep.nOutput * sizeof (RROutput) +
+		  rep.nPossibleOutput * sizeof (RROutput));
 
-    xci = (XRRCrtcInfo *) Xmalloc(rbytes);
+	xci = (XRRCrtcInfo *) Xmalloc(rbytes);
+    }
+    else
+    {
+	nbytes = 0;
+	nbytesRead = 0;
+	rbytes = 0;
+	xci = NULL;
+    }
+
     if (xci == NULL) {
 	_XEatData (dpy, (unsigned long) nbytes);
 	UnlockDisplay (dpy);
@@ -194,12 +206,21 @@
     if (!_XReply (dpy, (xReply *) &rep, 0, xFalse))
 	goto out;
 
-    nbytes = (long) rep.length << 2;
+    if (rep.length < INT_MAX >> 2)
+    {
+	nbytes = (long) rep.length << 2;
     
-    /* three channels of CARD16 data */
-    nbytesRead = (rep.size * 2 * 3);
+	/* three channels of CARD16 data */
+	nbytesRead = (rep.size * 2 * 3);
 
-    crtc_gamma = XRRAllocGamma (rep.size);
+	crtc_gamma = XRRAllocGamma (rep.size);
+    }
+    else
+    {
+	nbytes = 0;
+	nbytesRead = 0;
+	crtc_gamma = NULL;
+    }
     
     if (!crtc_gamma)
     {
@@ -357,7 +378,7 @@
     xRRGetCrtcTransformReq	*req;
     int				major_version, minor_version;
     XRRCrtcTransformAttributes	*attr;
-    char			*extra = NULL, *e;
+    char			*extra = NULL, *end = NULL, *e;
     int				p;
 
     *attributes = NULL;
@@ -395,9 +416,13 @@
 	else
 	{
 	    int extraBytes = rep.length * 4 - CrtcTransformExtra;
-	    extra = Xmalloc (extraBytes);
+	    if (rep.length < INT_MAX / 4 &&
+		rep.length * 4 >= CrtcTransformExtra) {
+		extra = Xmalloc (extraBytes);
+		end = extra + extraBytes;
+	    } else
+		extra = NULL;
 	    if (!extra) {
-		_XEatData (dpy, extraBytes);
 		UnlockDisplay (dpy);
 		SyncHandle ();
 		return False;
@@ -429,22 +454,38 @@
 
     e = extra;
 
+    if (e + rep.pendingNbytesFilter > end) {
+	XFree (extra);
+	return False;
+    }
     memcpy (attr->pendingFilter, e, rep.pendingNbytesFilter);
     attr->pendingFilter[rep.pendingNbytesFilter] = '\0';
     e += (rep.pendingNbytesFilter + 3) & ~3;
     for (p = 0; p < rep.pendingNparamsFilter; p++) {
 	INT32	f;
+	if (e + 4 > end) {
+	    XFree (extra);
+	    return False;
+	}
 	memcpy (&f, e, 4);
 	e += 4;
 	attr->pendingParams[p] = (XFixed) f;
     }
     attr->pendingNparams = rep.pendingNparamsFilter;
 
+    if (e + rep.currentNbytesFilter > end) {
+	XFree (extra);
+	return False;
+    }
     memcpy (attr->currentFilter, e, rep.currentNbytesFilter);
     attr->currentFilter[rep.currentNbytesFilter] = '\0';
     e += (rep.currentNbytesFilter + 3) & ~3;
     for (p = 0; p < rep.currentNparamsFilter; p++) {
 	INT32	f;
+	if (e + 4 > end) {
+	    XFree (extra);
+	    return False;
+	}
 	memcpy (&f, e, 4);
 	e += 4;
 	attr->currentParams[p] = (XFixed) f;

cvs diff -r1.1.1.2 -r1.1.1.2.2.1 xsrc/external/mit/libXrandr/dist/src/XrrOutput.c (expand / switch to context diff)
--- xsrc/external/mit/libXrandr/dist/src/XrrOutput.c 2009/03/10 04:20:44 1.1.1.2
+++ xsrc/external/mit/libXrandr/dist/src/XrrOutput.c 2016/10/05 10:47:17 1.1.1.2.2.1
@@ -25,6 +25,7 @@
 #include <config.h>
 #endif
 
+#include <limits.h>
 #include <stdio.h>
 #include <X11/Xlib.h>
 /* we need to be able to manipulate the Display structure on events */
@@ -60,6 +61,12 @@
 	return NULL;
     }
 
+    if (rep.length > INT_MAX >> 2 || rep.length < (OutputInfoExtra >> 2))
+    {
+	UnlockDisplay (dpy);
+	SyncHandle ();
+	return NULL;
+    }
     nbytes = ((long) (rep.length) << 2) - OutputInfoExtra;
 
     nbytesRead = (long) (rep.nCrtcs * 4 +

cvs diff -r1.1.1.2 -r1.1.1.2.2.1 xsrc/external/mit/libXrandr/dist/src/XrrScreen.c (expand / switch to context diff)
--- xsrc/external/mit/libXrandr/dist/src/XrrScreen.c 2009/03/10 04:20:44 1.1.1.2
+++ xsrc/external/mit/libXrandr/dist/src/XrrScreen.c 2016/10/05 10:47:17 1.1.1.2.2.1
@@ -24,6 +24,7 @@
 #include <config.h>
 #endif
 
+#include <limits.h>
 #include <stdio.h>
 #include <X11/Xlib.h>
 /* we need to be able to manipulate the Display structure on events */
@@ -105,27 +106,36 @@
 	xrri->has_rates = _XRRHasRates (xrri->minor_version, xrri->major_version);
     }
 
-    nbytes = (long) rep.length << 2;
+    if (rep.length < INT_MAX >> 2) {
+	nbytes = (long) rep.length << 2;
 
     nbytesRead = (long) (rep.nCrtcs * 4 +
 			 rep.nOutputs * 4 +
 			 rep.nModes * SIZEOF (xRRModeInfo) +
 			 ((rep.nbytesNames + 3) & ~3));
 
-    /* 
-     * first we must compute how much space to allocate for 
-     * randr library's use; we'll allocate the structures in a single
-     * allocation, on cleanlyness grounds.
-     */
+	/*
+	 * first we must compute how much space to allocate for
+	 * randr library's use; we'll allocate the structures in a single
+	 * allocation, on cleanlyness grounds.
+	 */
 
-    rbytes = (sizeof (XRRScreenResources) +
-	      rep.nCrtcs * sizeof (RRCrtc) +
-	      rep.nOutputs * sizeof (RROutput) +
-	      rep.nModes * sizeof (XRRModeInfo) +
-	      rep.nbytesNames + rep.nModes);	/* '\0' terminate names */
+	rbytes = (sizeof (XRRScreenResources) +
+		  rep.nCrtcs * sizeof (RRCrtc) +
+		  rep.nOutputs * sizeof (RROutput) +
+		  rep.nModes * sizeof (XRRModeInfo) +
+		  rep.nbytesNames + rep.nModes);    /* '\0' terminate names */
 
-    xrsr = (XRRScreenResources *) Xmalloc(rbytes);
-    wire_names = (char *) Xmalloc (rep.nbytesNames);
+	xrsr = (XRRScreenResources *) Xmalloc(rbytes);
+	wire_names = (char *) Xmalloc (rep.nbytesNames);
+    } else {
+	nbytes = 0;
+	nbytesRead = 0;
+	rbytes = 0;
+	xrsr = NULL;
+	wire_names = NULL;
+    }
+
     if (xrsr == NULL || wire_names == NULL) {
 	if (xrsr) Xfree (xrsr);
 	if (wire_names) Xfree (wire_names);
@@ -174,6 +184,14 @@
     wire_name = wire_names;
     for (i = 0; i < rep.nModes; i++)  {
 	xrsr->modes[i].name = names;
+	if (xrsr->modes[i].nameLength > rep.nbytesNames) {
+	    Xfree (xrsr);
+	    Xfree (wire_names);
+	    UnlockDisplay (dpy);
+	    SyncHandle ();
+	    return NULL;
+	}
+	rep.nbytesNames -= xrsr->modes[i].nameLength;
 	memcpy (names, wire_name, xrsr->modes[i].nameLength);
 	names[xrsr->modes[i].nameLength] = '\0';
 	names += xrsr->modes[i].nameLength + 1;

cvs diff -r1.1.1.3.2.1 -r1.1.1.3.2.2 xsrc/external/mit/libXrender/dist/src/Filter.c (expand / switch to context diff)
--- xsrc/external/mit/libXrender/dist/src/Filter.c 2013/06/06 03:44:26 1.1.1.3.2.1
+++ xsrc/external/mit/libXrender/dist/src/Filter.c 2016/10/05 10:47:18 1.1.1.3.2.2
@@ -38,7 +38,7 @@
     char			*name;
     char			len;
     int				i;
-    unsigned long		nbytes, nbytesAlias, nbytesName;
+    unsigned long		nbytes, nbytesAlias, nbytesName, reply_left;
     
     if (!RenderHasExtension (info))
 	return NULL;
@@ -114,6 +114,7 @@
      * Read the filter aliases
      */
     _XRead16Pad (dpy, filters->alias, 2 * rep.numAliases);
+    reply_left = 8 + rep.length - 2 * rep.numAliases;;
 
     /*
      * Read the filter names
@@ -122,9 +123,18 @@
     {
 	int	l;
 	_XRead (dpy, &len, 1);
+	reply_left--;
 	l = len & 0xff;
+	if ((unsigned long)l + 1 > nbytesName) {
+	    Xfree(filters);
+	    UnlockDisplay (dpy);
+	    SyncHandle ();
+	    return NULL;
+	}
+	nbytesName -= l + 1;
 	filters->filter[i] = name;
 	_XRead (dpy, name, l);
+        reply_left -= l;
 	name[l] = '\0';
 	name += l + 1;
     }

cvs diff -r1.1.1.2.2.1 -r1.1.1.2.2.2 xsrc/external/mit/libXrender/dist/src/Xrender.c (expand / switch to context diff)
--- xsrc/external/mit/libXrender/dist/src/Xrender.c 2013/06/06 03:44:26 1.1.1.2.2.1
+++ xsrc/external/mit/libXrender/dist/src/Xrender.c 2016/10/05 10:47:18 1.1.1.2.2.2
@@ -532,12 +532,28 @@
 	screen->fallback = _XRenderFindFormat (xri, xScreen->fallback);
 	screen->subpixel = SubPixelUnknown;
 	xDepth = (xPictDepth *) (xScreen + 1);
+	if (screen->ndepths > rep.numDepths) {
+	    Xfree (xri);
+	    Xfree (xData);
+	    UnlockDisplay (dpy);
+	    SyncHandle ();
+	    return 0;
+	}
+	rep.numDepths -= screen->ndepths;
 	for (nd = 0; nd < screen->ndepths; nd++)
 	{
 	    depth->depth = xDepth->depth;
 	    depth->nvisuals = xDepth->nPictVisuals;
 	    depth->visuals = visual;
 	    xVisual = (xPictVisual *) (xDepth + 1);
+	    if (depth->nvisuals > rep.numVisuals) {
+		Xfree (xri);
+		Xfree (xData);
+		UnlockDisplay (dpy);
+		SyncHandle ();
+		return 0;
+	    }
+	    rep.numVisuals -= depth->nvisuals;
 	    for (nv = 0; nv < depth->nvisuals; nv++)
 	    {
 		visual->visual = _XRenderFindVisual (dpy, xVisual->visual);

cvs diff -r1.1.1.3 -r1.1.1.3.2.1 xsrc/external/mit/libXtst/dist/src/XRecord.c (expand / switch to context diff)
--- xsrc/external/mit/libXtst/dist/src/XRecord.c 2010/11/21 05:48:49 1.1.1.3
+++ xsrc/external/mit/libXtst/dist/src/XRecord.c 2016/10/05 10:47:18 1.1.1.3.2.1
@@ -50,6 +50,7 @@
  */
 
 #include <stdio.h>
+#include <limits.h>
 #include <assert.h>
 #include <X11/Xlibint.h>
 #include <X11/extensions/Xext.h>
@@ -739,15 +740,23 @@
 	switch (rep->category) {
 	case XRecordFromServer:
 	    if (rep->elementHeader&XRecordFromServerTime) {
+		if (current_index + 4 > rep->length << 2)
+		    return Error;
 		EXTRACT_CARD32(rep->clientSwapped,
 			       reply->buf+current_index,
 			       data->server_time);
 		current_index += 4;
 	    }
+	    if (current_index + 1 > rep->length << 2)
+		return Error;
 	    switch (reply->buf[current_index]) {
 	    case X_Reply: /* reply */
+		if (current_index + 8 > rep->length << 2)
+		    return Error;
 		EXTRACT_CARD32(rep->clientSwapped,
 			       reply->buf+current_index+4, datum_bytes);
+		if (datum_bytes < 0 || datum_bytes > ((INT_MAX >> 2) - 8))
+		    return Error;
 		datum_bytes = (datum_bytes+8) << 2;
 		break;
 	    default: /* error or event */
@@ -756,52 +765,73 @@
 	    break;
 	case XRecordFromClient:
 	    if (rep->elementHeader&XRecordFromClientTime) {
+		if (current_index + 4 > rep->length << 2)
+		    return Error;
 		EXTRACT_CARD32(rep->clientSwapped,
 			       reply->buf+current_index,
 			       data->server_time);
 		current_index += 4;
 	    }
 	    if (rep->elementHeader&XRecordFromClientSequence) {
+		if (current_index + 4 > rep->length << 2)
+		    return Error;
 		EXTRACT_CARD32(rep->clientSwapped,
 			       reply->buf+current_index,
 			       data->client_seq);
 		current_index += 4;
 	    }
+	    if (current_index + 4 > rep->length<<2)
+		return Error;
 	    if (reply->buf[current_index+2] == 0
 		&& reply->buf[current_index+3] == 0) /* needn't swap 0 */
 	    {	/* BIG-REQUESTS */
+		if (current_index + 8 > rep->length << 2)
+		    return Error;
 		EXTRACT_CARD32(rep->clientSwapped,
 			       reply->buf+current_index+4, datum_bytes);
 	    } else {
 		EXTRACT_CARD16(rep->clientSwapped,
 			       reply->buf+current_index+2, datum_bytes);
 	    }
+	    if (datum_bytes < 0 || datum_bytes > INT_MAX >> 2)
+		return Error;
 	    datum_bytes <<= 2;
 	    break;
 	case XRecordClientStarted:
+	    if (current_index + 8 > rep->length << 2)
+		return Error;
 	    EXTRACT_CARD16(rep->clientSwapped,
 			   reply->buf+current_index+6, datum_bytes);
 	    datum_bytes = (datum_bytes+2) << 2;
 	    break;
 	case XRecordClientDied:
 	    if (rep->elementHeader&XRecordFromClientSequence) {
+		if (current_index + 4 > rep->length << 2)
+		    return Error;
 		EXTRACT_CARD32(rep->clientSwapped,
 			       reply->buf+current_index,
 			       data->client_seq);
 		current_index += 4;
-	    }
-	    /* fall through */
+	    } else if (current_index < rep->length << 2)
+		return Error;
+	    datum_bytes = 0;
+	    break;
 	case XRecordStartOfData:
 	case XRecordEndOfData:
+	    if (current_index < rep->length << 2)
+		return Error;
 	    datum_bytes = 0;
+	    break;
 	}
 	
 	if (datum_bytes > 0) {
-	    if (current_index + datum_bytes > rep->length << 2)
+	    if (INT_MAX - datum_bytes < (rep->length << 2) - current_index) {
 		fprintf(stderr,
 			"XRecord: %lu-byte reply claims %d-byte element (seq %lu)\n",
-			(long)rep->length << 2, current_index + datum_bytes,
+			(unsigned long)rep->length << 2, current_index + datum_bytes,
 			dpy->last_request_read);
+		return Error;
+	    }
 	    /*
 	     * This assignment (and indeed the whole buffer sharing
 	     * scheme) assumes arbitrary 4-byte boundaries are
@@ -848,6 +878,12 @@
 	/* This code should match that in XRecordEnableContextAsync */
 	if (!_XReply (dpy, (xReply *)&rep, 0, xFalse))
 	{
+	    UnlockDisplay(dpy);
+	    SyncHandle();
+	    return 0;
+	}
+
+	if (rep.length > INT_MAX >> 2) {
 	    UnlockDisplay(dpy);
 	    SyncHandle();
 	    return 0;

cvs diff -r1.1.1.2.2.1 -r1.1.1.2.2.2 xsrc/external/mit/libXv/dist/src/Xv.c (expand / switch to context diff)
--- xsrc/external/mit/libXv/dist/src/Xv.c 2013/06/06 03:44:26 1.1.1.2.2.1
+++ xsrc/external/mit/libXv/dist/src/Xv.c 2016/10/05 10:47:18 1.1.1.2.2.2
@@ -152,9 +152,11 @@
   xvQueryAdaptorsReply rep;
   int size,ii,jj;
   char *name;
+  char *end;
   XvAdaptorInfo *pas, *pa;
   XvFormat *pfs, *pf;
   char *buffer;
+  int status;
   union 
     {
       char *buffer;
@@ -179,14 +181,17 @@
   }
 
   size = rep.length << 2;
-  if ( (buffer = (char *)Xmalloc ((unsigned) size)) == NULL) {
+  if (size > 0) {
+    if ((buffer = Xmalloc(size)) == NULL) {
       UnlockDisplay(dpy);
       SyncHandle();
       return(XvBadAlloc);
+    }
+    _XRead(dpy, buffer, (long) size);
   }
-  _XRead (dpy, buffer, size);
 
   u.buffer = buffer;
+  end = buffer + size;
 
   /* GET INPUT ADAPTORS */
 
@@ -214,6 +219,10 @@
 
   pa = pas;
   for (ii=0; ii<rep.num_adaptors; ii++) {
+      if (u.buffer + sz_xvAdaptorInfo > end) {
+        status = XvBadReply;
+        goto out;
+      }
       pa->type = u.pa->type;
       pa->base_id = u.pa->base_id;
       pa->num_ports = u.pa->num_ports;
@@ -225,6 +234,11 @@
       size = u.pa->name_size;
       u.buffer += (sz_xvAdaptorInfo + 3) & ~3;
 
+      if (u.buffer + size > end) {
+        status = XvBadReply;
+        goto out;
+      }
+
       if ( (name = (char *)Xmalloc(size+1)) == NULL)
 	{
 	  XvFreeAdaptorInfo(pas);
@@ -252,6 +266,11 @@
 
       pf = pfs;
       for (jj=0; jj<pa->num_formats; jj++) {
+          if (u.buffer + sz_xvFormat > end) {
+            Xfree(pfs);
+            status = XvBadReply;
+            goto out;
+          }
 	  pf->depth = u.pf->depth;
 	  pf->visual_id = u.pf->visual;
 	  pf++;
@@ -268,11 +287,14 @@
   *p_nAdaptors = rep.num_adaptors;
   *p_pAdaptors = pas;
 
+  status = Success;
+
+out:
   Xfree(buffer);
   UnlockDisplay(dpy);
   SyncHandle();
 
-  return (Success);
+  return (status);
 }
 
 
@@ -314,6 +336,8 @@
   xvQueryEncodingsReply rep;
   int size, jj;
   char *name;
+  char *end;
+  int status;
   XvEncodingInfo *pes, *pe;
   char *buffer;
   union 
@@ -339,14 +363,17 @@
   }
 
   size = rep.length << 2;
-  if ( (buffer = (char *)Xmalloc ((unsigned) size)) == NULL) {
+  if (size > 0) {
+    if ( (buffer = (char *)Xmalloc ((unsigned) size)) == NULL) {
       UnlockDisplay(dpy);
       SyncHandle();
       return(XvBadAlloc);
+    }
+    _XRead (dpy, buffer, size);
   }
-  _XRead (dpy, buffer, size);
 
   u.buffer = buffer;
+  end = buffer + size;
 
   /* GET ENCODINGS */
 
@@ -369,6 +396,10 @@
 
   pe = pes;
   for (jj=0; jj<rep.num_encodings; jj++) {
+      if (u.buffer + sz_xvEncodingInfo > end) {
+        status = XvBadReply;
+        goto out;
+      }
       pe->encoding_id = u.pe->encoding;
       pe->width = u.pe->width;
       pe->height = u.pe->height;
@@ -379,6 +410,10 @@
       size = u.pe->name_size;
       u.buffer += (sz_xvEncodingInfo + 3) & ~3;
 
+      if (u.buffer + size > end) {
+        status = XvBadReply;
+        goto out;
+      }
       if ( (name = (char *)Xmalloc(size+1)) == NULL) {
 	  XvFreeEncodingInfo(pes);
 	  Xfree(buffer);
@@ -397,11 +432,14 @@
   *p_nEncodings = rep.num_encodings;
   *p_pEncodings = pes;
 
+  status = Success;
+
+out:
   Xfree(buffer);
   UnlockDisplay(dpy);
   SyncHandle();
 
-  return (Success);
+  return (status);
 }
 
 void

cvs diff -r1.1.1.2.2.1 -r1.1.1.2.2.2 xsrc/external/mit/libXvMC/dist/src/XvMC.c (expand / switch to context diff)
--- xsrc/external/mit/libXvMC/dist/src/XvMC.c 2013/06/06 03:44:26 1.1.1.2.2.1
+++ xsrc/external/mit/libXvMC/dist/src/XvMC.c 2016/10/05 10:47:18 1.1.1.2.2.2
@@ -572,9 +572,9 @@
 	if (*name && *busID && tmpBuf) {
 	    _XRead(dpy, tmpBuf, realSize);
 	    strncpy(*name,tmpBuf,rep.nameLen);
-	    name[rep.nameLen - 1] = '\0';
+	    (*name)[rep.nameLen == 0 ? 0 : rep.nameLen - 1] = '\0';
 	    strncpy(*busID,tmpBuf+rep.nameLen,rep.busIDLen);
-	    busID[rep.busIDLen - 1] = '\0';
+	    busID[rep.busIDLen == 0 ? 0 : rep.busIDLen - 1] = '\0';
 	    XFree(tmpBuf);
 	} else {
 	    XFree(*name);