diff options
| -rw-r--r-- | meta/recipes-multimedia/libtiff/files/CVE-2018-8905.patch | 61 | ||||
| -rw-r--r-- | meta/recipes-multimedia/libtiff/tiff_4.0.9.bb | 1 | 
2 files changed, 62 insertions, 0 deletions
| diff --git a/meta/recipes-multimedia/libtiff/files/CVE-2018-8905.patch b/meta/recipes-multimedia/libtiff/files/CVE-2018-8905.patch new file mode 100644 index 0000000000..962646dbe0 --- /dev/null +++ b/meta/recipes-multimedia/libtiff/files/CVE-2018-8905.patch @@ -0,0 +1,61 @@ +From 58a898cb4459055bb488ca815c23b880c242a27d Mon Sep 17 00:00:00 2001 +From: Even Rouault <even.rouault@spatialys.com> +Date: Sat, 12 May 2018 15:32:31 +0200 +Subject: [PATCH] LZWDecodeCompat(): fix potential index-out-of-bounds write. + Fixes http://bugzilla.maptools.org/show_bug.cgi?id=2780 / + CVE-2018-8905 + +The fix consists in using the similar code LZWDecode() to validate we +don't write outside of the output buffer. + +--- +CVE: CVE-2018-8905 + +Upstream-Status: Backport [gitlab.com/libtiff/libtiff/commit/58a898...] + +Signed-off-by: Joe Slater <joe.slater@windriver.com> + +--- + libtiff/tif_lzw.c |   18 ++++++++++++------ + 1 file changed, 12 insertions(+), 6 deletions(-) + +diff --git a/libtiff/tif_lzw.c b/libtiff/tif_lzw.c +index 4ccb443..94d85e3 100644 +--- a/libtiff/tif_lzw.c ++++ b/libtiff/tif_lzw.c +@@ -602,6 +602,7 @@ LZWDecodeCompat(TIFF* tif, uint8* op0, tmsize_t occ0, uint16 s) + 	char *tp; + 	unsigned char *bp; + 	int code, nbits; ++	int len; + 	long nextbits, nextdata, nbitsmask; + 	code_t *codep, *free_entp, *maxcodep, *oldcodep; +  +@@ -753,13 +754,18 @@ LZWDecodeCompat(TIFF* tif, uint8* op0, tmsize_t occ0, uint16 s) + 				}  while (--occ); + 				break; + 			} +-			assert(occ >= codep->length); +-			op += codep->length; +-			occ -= codep->length; +-			tp = op; ++			len = codep->length; ++			tp = op + len; + 			do { +-				*--tp = codep->value; +-			} while( (codep = codep->next) != NULL ); ++				int t; ++				--tp; ++				t = codep->value; ++				codep = codep->next; ++				*tp = (char)t; ++			} while (codep && tp > op); ++			assert(occ >= len); ++			op += len; ++			occ -= len; + 		} else { + 			*op++ = (char)code; + 			occ--; +--  +1.7.9.5 + diff --git a/meta/recipes-multimedia/libtiff/tiff_4.0.9.bb b/meta/recipes-multimedia/libtiff/tiff_4.0.9.bb index e8e2a119f1..53b2b81ec2 100644 --- a/meta/recipes-multimedia/libtiff/tiff_4.0.9.bb +++ b/meta/recipes-multimedia/libtiff/tiff_4.0.9.bb @@ -10,6 +10,7 @@ SRC_URI = "http://download.osgeo.org/libtiff/tiff-${PV}.tar.gz \             file://CVE-2017-18013.patch \             file://CVE-2018-5784.patch \             file://CVE-2018-10963.patch \ +           file://CVE-2018-8905.patch \            "  SRC_URI[md5sum] = "54bad211279cc93eb4fca31ba9bfdc79" | 
