diff options
Diffstat (limited to 'freetype-2.4.11-CVE-2014-9669.patch')
-rw-r--r-- | freetype-2.4.11-CVE-2014-9669.patch | 117 |
1 files changed, 0 insertions, 117 deletions
diff --git a/freetype-2.4.11-CVE-2014-9669.patch b/freetype-2.4.11-CVE-2014-9669.patch deleted file mode 100644 index 59fe8c3b67cd..000000000000 --- a/freetype-2.4.11-CVE-2014-9669.patch +++ /dev/null @@ -1,117 +0,0 @@ -From 602040b1112c9f94d68e200be59ea7ac3d104565 Mon Sep 17 00:00:00 2001 -From: Werner Lemberg <wl@gnu.org> -Date: Wed, 12 Nov 2014 19:51:20 +0000 -Subject: [sfnt] Fix Savannah bug #43588. - -* src/sfnt/ttcmap.c (tt_cmap8_validate, tt_cmap10_validate, -tt_cmap12_validate, tt_cmap13_validate, tt_cmap14_validate): Protect -against overflow in additions and multiplications. ---- -diff --git a/src/sfnt/ttcmap.c b/src/sfnt/ttcmap.c -index f9acf5d..712bd4f 100644 ---- a/src/sfnt/ttcmap.c -+++ b/src/sfnt/ttcmap.c -@@ -1647,7 +1647,8 @@ - p = is32 + 8192; /* skip `is32' array */ - num_groups = TT_NEXT_ULONG( p ); - -- if ( p + num_groups * 12 > valid->limit ) -+ /* p + num_groups * 12 > valid->limit ? */ -+ if ( num_groups > (FT_UInt32)( valid->limit - p ) / 12 ) - FT_INVALID_TOO_SHORT; - - /* check groups, they must be in increasing order */ -@@ -1672,7 +1673,12 @@ - - if ( valid->level >= FT_VALIDATE_TIGHT ) - { -- if ( start_id + end - start >= TT_VALID_GLYPH_COUNT( valid ) ) -+ FT_UInt32 d = end - start; -+ -+ -+ /* start_id + end - start >= TT_VALID_GLYPH_COUNT( valid ) ? */ -+ if ( d > TT_VALID_GLYPH_COUNT( valid ) || -+ start_id >= TT_VALID_GLYPH_COUNT( valid ) - d ) - FT_INVALID_GLYPH_ID; - - count = (FT_UInt32)( end - start + 1 ); -@@ -1870,7 +1876,9 @@ - count = TT_NEXT_ULONG( p ); - - if ( length > (FT_ULong)( valid->limit - table ) || -- length < 20 + count * 2 ) -+ /* length < 20 + count * 2 ? */ -+ length < 20 || -+ ( length - 20 ) / 2 < count ) - FT_INVALID_TOO_SHORT; - - /* check glyph indices */ -@@ -2057,7 +2065,9 @@ - num_groups = TT_NEXT_ULONG( p ); - - if ( length > (FT_ULong)( valid->limit - table ) || -- length < 16 + 12 * num_groups ) -+ /* length < 16 + 12 * num_groups ? */ -+ length < 16 || -+ ( length - 16 ) / 12 < num_groups ) - FT_INVALID_TOO_SHORT; - - /* check groups, they must be in increasing order */ -@@ -2079,7 +2089,12 @@ - - if ( valid->level >= FT_VALIDATE_TIGHT ) - { -- if ( start_id + end - start >= TT_VALID_GLYPH_COUNT( valid ) ) -+ FT_UInt32 d = end - start; -+ -+ -+ /* start_id + end - start >= TT_VALID_GLYPH_COUNT( valid ) ? */ -+ if ( d > TT_VALID_GLYPH_COUNT( valid ) || -+ start_id >= TT_VALID_GLYPH_COUNT( valid ) - d ) - FT_INVALID_GLYPH_ID; - } - -@@ -2381,7 +2396,9 @@ - num_groups = TT_NEXT_ULONG( p ); - - if ( length > (FT_ULong)( valid->limit - table ) || -- length < 16 + 12 * num_groups ) -+ /* length < 16 + 12 * num_groups ? */ -+ length < 16 || -+ ( length - 16 ) / 12 < num_groups ) - FT_INVALID_TOO_SHORT; - - /* check groups, they must be in increasing order */ -@@ -2762,7 +2779,9 @@ - - - if ( length > (FT_ULong)( valid->limit - table ) || -- length < 10 + 11 * num_selectors ) -+ /* length < 10 + 11 * num_selectors ? */ -+ length < 10 || -+ ( length - 10 ) / 11 < num_selectors ) - FT_INVALID_TOO_SHORT; - - /* check selectors, they must be in increasing order */ -@@ -2798,7 +2817,8 @@ - FT_ULong lastBase = 0; - - -- if ( defp + numRanges * 4 > valid->limit ) -+ /* defp + numRanges * 4 > valid->limit ? */ -+ if ( numRanges > (FT_ULong)( valid->limit - defp ) / 4 ) - FT_INVALID_TOO_SHORT; - - for ( i = 0; i < numRanges; ++i ) -@@ -2825,7 +2845,8 @@ - FT_ULong i, lastUni = 0; - - -- if ( numMappings * 4 > (FT_ULong)( valid->limit - ndp ) ) -+ /* numMappings * 4 > (FT_ULong)( valid->limit - ndp ) ? */ -+ if ( numMappings > ( (FT_ULong)( valid->limit - ndp ) ) / 4 ) - FT_INVALID_TOO_SHORT; - - for ( i = 0; i < numMappings; ++i ) --- -cgit v0.9.0.2 |