123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354555657585960616263646566676869707172737475767778798081828384858687888990919293949596979899100101102103104105106107108109110111112113114115116117118119120121122123124125126127128129130131132133134135136137138139140141142143144145146147148149150151152153154155156157158159160161162163164165166167168169170171172173174175176177178179180181182183184185186187188189190191192193 |
- From 3899f0ab62dd307f63f87ec99aaf289e104f4070 Mon Sep 17 00:00:00 2001
- From: erouault <erouault>
- Date: Sun, 27 Dec 2015 16:25:11 +0000
- Subject: [PATCH] * libtiff/tif_luv.c: fix potential out-of-bound writes in
- decode functions in non debug builds by replacing assert()s by regular if
- checks (bugzilla #2522). Fix potential out-of-bound reads in case of short
- input data.
- ---
- ChangeLog | 7 +++++++
- libtiff/tif_luv.c | 57 +++++++++++++++++++++++++++++++++++++++++++------------
- 2 files changed, 52 insertions(+), 12 deletions(-)
- diff --git a/ChangeLog b/ChangeLog
- index 4beb30b..b8aa23c 100644
- --- a/ChangeLog
- +++ b/ChangeLog
- @@ -1,3 +1,10 @@
- +2015-12-27 Even Rouault <even.rouault at spatialys.com>
- +
- + * libtiff/tif_luv.c: fix potential out-of-bound writes in decode
- + functions in non debug builds by replacing assert()s by regular if
- + checks (bugzilla #2522).
- + Fix potential out-of-bound reads in case of short input data.
- +
- 2015-12-26 Even Rouault <even.rouault at spatialys.com>
-
- * libtiff/tif_getimage.c: fix out-of-bound reads in TIFFRGBAImage
- diff --git a/libtiff/tif_luv.c b/libtiff/tif_luv.c
- index 4e328ba..60a174d 100644
- --- a/libtiff/tif_luv.c
- +++ b/libtiff/tif_luv.c
- @@ -1,4 +1,4 @@
- -/* $Id: tif_luv.c,v 1.40 2015-06-21 01:09:09 bfriesen Exp $ */
- +/* $Id: tif_luv.c,v 1.41 2015-12-27 16:25:11 erouault Exp $ */
-
- /*
- * Copyright (c) 1997 Greg Ward Larson
- @@ -202,7 +202,11 @@ LogL16Decode(TIFF* tif, uint8* op, tmsize_t occ, uint16 s)
- if (sp->user_datafmt == SGILOGDATAFMT_16BIT)
- tp = (int16*) op;
- else {
- - assert(sp->tbuflen >= npixels);
- + if(sp->tbuflen < npixels) {
- + TIFFErrorExt(tif->tif_clientdata, module,
- + "Translation buffer too short");
- + return (0);
- + }
- tp = (int16*) sp->tbuf;
- }
- _TIFFmemset((void*) tp, 0, npixels*sizeof (tp[0]));
- @@ -211,9 +215,11 @@ LogL16Decode(TIFF* tif, uint8* op, tmsize_t occ, uint16 s)
- cc = tif->tif_rawcc;
- /* get each byte string */
- for (shft = 2*8; (shft -= 8) >= 0; ) {
- - for (i = 0; i < npixels && cc > 0; )
- + for (i = 0; i < npixels && cc > 0; ) {
- if (*bp >= 128) { /* run */
- - rc = *bp++ + (2-128); /* TODO: potential input buffer overrun when decoding corrupt or truncated data */
- + if( cc < 2 )
- + break;
- + rc = *bp++ + (2-128);
- b = (int16)(*bp++ << shft);
- cc -= 2;
- while (rc-- && i < npixels)
- @@ -223,6 +229,7 @@ LogL16Decode(TIFF* tif, uint8* op, tmsize_t occ, uint16 s)
- while (--cc && rc-- && i < npixels)
- tp[i++] |= (int16)*bp++ << shft;
- }
- + }
- if (i != npixels) {
- #if defined(__WIN32__) && (defined(_MSC_VER) || defined(__MINGW32__))
- TIFFErrorExt(tif->tif_clientdata, module,
- @@ -268,13 +275,17 @@ LogLuvDecode24(TIFF* tif, uint8* op, tmsize_t occ, uint16 s)
- if (sp->user_datafmt == SGILOGDATAFMT_RAW)
- tp = (uint32 *)op;
- else {
- - assert(sp->tbuflen >= npixels);
- + if(sp->tbuflen < npixels) {
- + TIFFErrorExt(tif->tif_clientdata, module,
- + "Translation buffer too short");
- + return (0);
- + }
- tp = (uint32 *) sp->tbuf;
- }
- /* copy to array of uint32 */
- bp = (unsigned char*) tif->tif_rawcp;
- cc = tif->tif_rawcc;
- - for (i = 0; i < npixels && cc > 0; i++) {
- + for (i = 0; i < npixels && cc >= 3; i++) {
- tp[i] = bp[0] << 16 | bp[1] << 8 | bp[2];
- bp += 3;
- cc -= 3;
- @@ -325,7 +336,11 @@ LogLuvDecode32(TIFF* tif, uint8* op, tmsize_t occ, uint16 s)
- if (sp->user_datafmt == SGILOGDATAFMT_RAW)
- tp = (uint32*) op;
- else {
- - assert(sp->tbuflen >= npixels);
- + if(sp->tbuflen < npixels) {
- + TIFFErrorExt(tif->tif_clientdata, module,
- + "Translation buffer too short");
- + return (0);
- + }
- tp = (uint32*) sp->tbuf;
- }
- _TIFFmemset((void*) tp, 0, npixels*sizeof (tp[0]));
- @@ -334,11 +349,13 @@ LogLuvDecode32(TIFF* tif, uint8* op, tmsize_t occ, uint16 s)
- cc = tif->tif_rawcc;
- /* get each byte string */
- for (shft = 4*8; (shft -= 8) >= 0; ) {
- - for (i = 0; i < npixels && cc > 0; )
- + for (i = 0; i < npixels && cc > 0; ) {
- if (*bp >= 128) { /* run */
- + if( cc < 2 )
- + break;
- rc = *bp++ + (2-128);
- b = (uint32)*bp++ << shft;
- - cc -= 2; /* TODO: potential input buffer overrun when decoding corrupt or truncated data */
- + cc -= 2;
- while (rc-- && i < npixels)
- tp[i++] |= b;
- } else { /* non-run */
- @@ -346,6 +363,7 @@ LogLuvDecode32(TIFF* tif, uint8* op, tmsize_t occ, uint16 s)
- while (--cc && rc-- && i < npixels)
- tp[i++] |= (uint32)*bp++ << shft;
- }
- + }
- if (i != npixels) {
- #if defined(__WIN32__) && (defined(_MSC_VER) || defined(__MINGW32__))
- TIFFErrorExt(tif->tif_clientdata, module,
- @@ -413,6 +431,7 @@ LogLuvDecodeTile(TIFF* tif, uint8* bp, tmsize_t cc, uint16 s)
- static int
- LogL16Encode(TIFF* tif, uint8* bp, tmsize_t cc, uint16 s)
- {
- + static const char module[] = "LogL16Encode";
- LogLuvState* sp = EncoderState(tif);
- int shft;
- tmsize_t i;
- @@ -433,7 +452,11 @@ LogL16Encode(TIFF* tif, uint8* bp, tmsize_t cc, uint16 s)
- tp = (int16*) bp;
- else {
- tp = (int16*) sp->tbuf;
- - assert(sp->tbuflen >= npixels);
- + if(sp->tbuflen < npixels) {
- + TIFFErrorExt(tif->tif_clientdata, module,
- + "Translation buffer too short");
- + return (0);
- + }
- (*sp->tfunc)(sp, bp, npixels);
- }
- /* compress each byte string */
- @@ -506,6 +529,7 @@ LogL16Encode(TIFF* tif, uint8* bp, tmsize_t cc, uint16 s)
- static int
- LogLuvEncode24(TIFF* tif, uint8* bp, tmsize_t cc, uint16 s)
- {
- + static const char module[] = "LogLuvEncode24";
- LogLuvState* sp = EncoderState(tif);
- tmsize_t i;
- tmsize_t npixels;
- @@ -521,7 +545,11 @@ LogLuvEncode24(TIFF* tif, uint8* bp, tmsize_t cc, uint16 s)
- tp = (uint32*) bp;
- else {
- tp = (uint32*) sp->tbuf;
- - assert(sp->tbuflen >= npixels);
- + if(sp->tbuflen < npixels) {
- + TIFFErrorExt(tif->tif_clientdata, module,
- + "Translation buffer too short");
- + return (0);
- + }
- (*sp->tfunc)(sp, bp, npixels);
- }
- /* write out encoded pixels */
- @@ -553,6 +581,7 @@ LogLuvEncode24(TIFF* tif, uint8* bp, tmsize_t cc, uint16 s)
- static int
- LogLuvEncode32(TIFF* tif, uint8* bp, tmsize_t cc, uint16 s)
- {
- + static const char module[] = "LogLuvEncode32";
- LogLuvState* sp = EncoderState(tif);
- int shft;
- tmsize_t i;
- @@ -574,7 +603,11 @@ LogLuvEncode32(TIFF* tif, uint8* bp, tmsize_t cc, uint16 s)
- tp = (uint32*) bp;
- else {
- tp = (uint32*) sp->tbuf;
- - assert(sp->tbuflen >= npixels);
- + if(sp->tbuflen < npixels) {
- + TIFFErrorExt(tif->tif_clientdata, module,
- + "Translation buffer too short");
- + return (0);
- + }
- (*sp->tfunc)(sp, bp, npixels);
- }
- /* compress each byte string */
|