|
|
- commit 40448d58fbfad52d2dde5bd18daa30b17fe35fcd
- Author: erouault <erouault>
- Date: Thu Jun 1 12:44:04 2017 +0000
-
- * libtiff/tif_dirinfo.c, tif_dirread.c: add _TIFFCheckFieldIsValidForCodec(),
- and use it in TIFFReadDirectory() so as to ignore fields whose tag is a
- codec-specified tag but this codec is not enabled. This avoids TIFFGetField()
- to behave differently depending on whether the codec is enabled or not, and
- thus can avoid stack based buffer overflows in a number of TIFF utilities
- such as tiffsplit, tiffcmp, thumbnail, etc.
- Patch derived from 0063-Handle-properly-CODEC-specific-tags.patch
- (http://bugzilla.maptools.org/show_bug.cgi?id=2580) by Raphaël Hertzog.
- Fixes:
- http://bugzilla.maptools.org/show_bug.cgi?id=2580
- http://bugzilla.maptools.org/show_bug.cgi?id=2693
- http://bugzilla.maptools.org/show_bug.cgi?id=2625 (CVE-2016-10095)
- http://bugzilla.maptools.org/show_bug.cgi?id=2564 (CVE-2015-7554)
- http://bugzilla.maptools.org/show_bug.cgi?id=2561 (CVE-2016-5318)
- http://bugzilla.maptools.org/show_bug.cgi?id=2499 (CVE-2014-8128)
- http://bugzilla.maptools.org/show_bug.cgi?id=2441
- http://bugzilla.maptools.org/show_bug.cgi?id=2433
-
- diff --git a/ChangeLog b/ChangeLog
- index 04881ba7..ebd1a3c0 100644
- --- a/ChangeLog
- +++ b/ChangeLog
- @@ -1,3 +1,23 @@
- +2017-06-01 Even Rouault <even.rouault at spatialys.com>
- +
- + * libtiff/tif_dirinfo.c, tif_dirread.c: add _TIFFCheckFieldIsValidForCodec(),
- + and use it in TIFFReadDirectory() so as to ignore fields whose tag is a
- + codec-specified tag but this codec is not enabled. This avoids TIFFGetField()
- + to behave differently depending on whether the codec is enabled or not, and
- + thus can avoid stack based buffer overflows in a number of TIFF utilities
- + such as tiffsplit, tiffcmp, thumbnail, etc.
- + Patch derived from 0063-Handle-properly-CODEC-specific-tags.patch
- + (http://bugzilla.maptools.org/show_bug.cgi?id=2580) by Raphaël Hertzog.
- + Fixes:
- + http://bugzilla.maptools.org/show_bug.cgi?id=2580
- + http://bugzilla.maptools.org/show_bug.cgi?id=2693
- + http://bugzilla.maptools.org/show_bug.cgi?id=2625 (CVE-2016-10095)
- + http://bugzilla.maptools.org/show_bug.cgi?id=2564 (CVE-2015-7554)
- + http://bugzilla.maptools.org/show_bug.cgi?id=2561 (CVE-2016-5318)
- + http://bugzilla.maptools.org/show_bug.cgi?id=2499 (CVE-2014-8128)
- + http://bugzilla.maptools.org/show_bug.cgi?id=2441
- + http://bugzilla.maptools.org/show_bug.cgi?id=2433
- +
- 2017-05-29 Even Rouault <even.rouault at spatialys.com>
-
- * libtiff/tif_getimage.c: initYCbCrConversion(): stricter validation for
- diff --git a/libtiff/tif_dir.h b/libtiff/tif_dir.h
- index 6af5f3dc..5a380767 100644
- --- a/libtiff/tif_dir.h
- +++ b/libtiff/tif_dir.h
- @@ -1,4 +1,4 @@
- -/* $Id: tif_dir.h,v 1.54 2011-02-18 20:53:05 fwarmerdam Exp $ */
- +/* $Id: tif_dir.h,v 1.55 2017-06-01 12:44:04 erouault Exp $ */
-
- /*
- * Copyright (c) 1988-1997 Sam Leffler
- @@ -291,6 +291,7 @@ struct _TIFFField {
- extern int _TIFFMergeFields(TIFF*, const TIFFField[], uint32);
- extern const TIFFField* _TIFFFindOrRegisterField(TIFF *, uint32, TIFFDataType);
- extern TIFFField* _TIFFCreateAnonField(TIFF *, uint32, TIFFDataType);
- +extern int _TIFFCheckFieldIsValidForCodec(TIFF *tif, ttag_t tag);
-
- #if defined(__cplusplus)
- }
- diff --git a/libtiff/tif_dirinfo.c b/libtiff/tif_dirinfo.c
- index 23ad0020..4904f540 100644
- --- a/libtiff/tif_dirinfo.c
- +++ b/libtiff/tif_dirinfo.c
- @@ -1,4 +1,4 @@
- -/* $Id: tif_dirinfo.c,v 1.126 2016-11-18 02:52:13 bfriesen Exp $ */
- +/* $Id: tif_dirinfo.c,v 1.127 2017-06-01 12:44:04 erouault Exp $ */
-
- /*
- * Copyright (c) 1988-1997 Sam Leffler
- @@ -956,6 +956,109 @@ TIFFMergeFieldInfo(TIFF* tif, const TIFFFieldInfo info[], uint32 n)
- return 0;
- }
-
- +int
- +_TIFFCheckFieldIsValidForCodec(TIFF *tif, ttag_t tag)
- +{
- + /* Filter out non-codec specific tags */
- + switch (tag) {
- + /* Shared tags */
- + case TIFFTAG_PREDICTOR:
- + /* JPEG tags */
- + case TIFFTAG_JPEGTABLES:
- + /* OJPEG tags */
- + case TIFFTAG_JPEGIFOFFSET:
- + case TIFFTAG_JPEGIFBYTECOUNT:
- + case TIFFTAG_JPEGQTABLES:
- + case TIFFTAG_JPEGDCTABLES:
- + case TIFFTAG_JPEGACTABLES:
- + case TIFFTAG_JPEGPROC:
- + case TIFFTAG_JPEGRESTARTINTERVAL:
- + /* CCITT* */
- + case TIFFTAG_BADFAXLINES:
- + case TIFFTAG_CLEANFAXDATA:
- + case TIFFTAG_CONSECUTIVEBADFAXLINES:
- + case TIFFTAG_GROUP3OPTIONS:
- + case TIFFTAG_GROUP4OPTIONS:
- + break;
- + default:
- + return 1;
- + }
- + /* Check if codec specific tags are allowed for the current
- + * compression scheme (codec) */
- + switch (tif->tif_dir.td_compression) {
- + case COMPRESSION_LZW:
- + if (tag == TIFFTAG_PREDICTOR)
- + return 1;
- + break;
- + case COMPRESSION_PACKBITS:
- + /* No codec-specific tags */
- + break;
- + case COMPRESSION_THUNDERSCAN:
- + /* No codec-specific tags */
- + break;
- + case COMPRESSION_NEXT:
- + /* No codec-specific tags */
- + break;
- + case COMPRESSION_JPEG:
- + if (tag == TIFFTAG_JPEGTABLES)
- + return 1;
- + break;
- + case COMPRESSION_OJPEG:
- + switch (tag) {
- + case TIFFTAG_JPEGIFOFFSET:
- + case TIFFTAG_JPEGIFBYTECOUNT:
- + case TIFFTAG_JPEGQTABLES:
- + case TIFFTAG_JPEGDCTABLES:
- + case TIFFTAG_JPEGACTABLES:
- + case TIFFTAG_JPEGPROC:
- + case TIFFTAG_JPEGRESTARTINTERVAL:
- + return 1;
- + }
- + break;
- + case COMPRESSION_CCITTRLE:
- + case COMPRESSION_CCITTRLEW:
- + case COMPRESSION_CCITTFAX3:
- + case COMPRESSION_CCITTFAX4:
- + switch (tag) {
- + case TIFFTAG_BADFAXLINES:
- + case TIFFTAG_CLEANFAXDATA:
- + case TIFFTAG_CONSECUTIVEBADFAXLINES:
- + return 1;
- + case TIFFTAG_GROUP3OPTIONS:
- + if (tif->tif_dir.td_compression == COMPRESSION_CCITTFAX3)
- + return 1;
- + break;
- + case TIFFTAG_GROUP4OPTIONS:
- + if (tif->tif_dir.td_compression == COMPRESSION_CCITTFAX4)
- + return 1;
- + break;
- + }
- + break;
- + case COMPRESSION_JBIG:
- + /* No codec-specific tags */
- + break;
- + case COMPRESSION_DEFLATE:
- + case COMPRESSION_ADOBE_DEFLATE:
- + if (tag == TIFFTAG_PREDICTOR)
- + return 1;
- + break;
- + case COMPRESSION_PIXARLOG:
- + if (tag == TIFFTAG_PREDICTOR)
- + return 1;
- + break;
- + case COMPRESSION_SGILOG:
- + case COMPRESSION_SGILOG24:
- + /* No codec-specific tags */
- + break;
- + case COMPRESSION_LZMA:
- + if (tag == TIFFTAG_PREDICTOR)
- + return 1;
- + break;
- +
- + }
- + return 0;
- +}
- +
- /* vim: set ts=8 sts=8 sw=8 noet: */
-
- /*
- diff --git a/libtiff/tif_dirread.c b/libtiff/tif_dirread.c
- index 772ebaf7..acde78b5 100644
- --- a/libtiff/tif_dirread.c
- +++ b/libtiff/tif_dirread.c
- @@ -1,4 +1,4 @@
- -/* $Id: tif_dirread.c,v 1.208 2017-04-27 15:46:22 erouault Exp $ */
- +/* $Id: tif_dirread.c,v 1.209 2017-06-01 12:44:04 erouault Exp $ */
-
- /*
- * Copyright (c) 1988-1997 Sam Leffler
- @@ -3580,6 +3580,10 @@ TIFFReadDirectory(TIFF* tif)
- goto bad;
- dp->tdir_tag=IGNORE;
- break;
- + default:
- + if( !_TIFFCheckFieldIsValidForCodec(tif, dp->tdir_tag) )
- + dp->tdir_tag=IGNORE;
- + break;
- }
- }
- }
|