integer overflow in ReadInFile() in Xrm.c [CVE-2013-1981 7/13]
Called from XrmGetFileDatabase() which gets called from InitDefaults()
which gets the filename from getenv ("XENVIRONMENT")
If file is exactly 0xffffffff bytes long (or longer and truncates to
0xffffffff, on implementations where off_t is larger than an int),
then size may be set to a value which overflows causing less memory
to be allocated than is written to by the following read() call.
size is left limited to an int, because if your Xresources file is
larger than 2gb, you're very definitely doing it wrong.
Reported-by:  Ilja Van Sprundel <ivansprundel@ioactive.com>
Signed-off-by:
Ilja Van Sprundel <ivansprundel@ioactive.com>
Signed-off-by:  Alan Coopersmith <alan.coopersmith@oracle.com>
Reviewed-by:
Alan Coopersmith <alan.coopersmith@oracle.com>
Reviewed-by:  Matthieu Herrb <matthieu.herrb@laas.fr>
Backported-to-NX-by:
Matthieu Herrb <matthieu.herrb@laas.fr>
Backported-to-NX-by:  Ulrich Sibiller <uli42@gmx.de>
Ulrich Sibiller <uli42@gmx.de>
Showing
Please
register
or
sign in
to comment