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
--- 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); \
}
--- 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;
--- 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);
--- 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)
--- 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;
}
--- 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);
--- 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);
--- 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) +
--- 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);
--- 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)));
}
--- 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);
--- 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)
--- 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
--- 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)
--- 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();
--- 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 */
--- 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;
--- 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;
--- 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 +
--- 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;
--- 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;
}
--- 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);
--- 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;
--- 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
--- 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);