Protect against invalid SID values in CFFs.
Problem reported by Tavis Ormandy <taviso@google.com>. * src/cff/cffload.c (cff_charset_load): Reject SID values larger than 64999.
This commit is contained in:
parent
8b819254b9
commit
0545ec1ca3
|
@ -1,3 +1,12 @@
|
||||||
|
2009-03-20 Werner Lemberg <wl@gnu.org>
|
||||||
|
|
||||||
|
Protect against invalid SID values in CFFs.
|
||||||
|
|
||||||
|
Problem reported by Tavis Ormandy <taviso@google.com>.
|
||||||
|
|
||||||
|
* src/cff/cffload.c (cff_charset_load): Reject SID values larger
|
||||||
|
than 64999.
|
||||||
|
|
||||||
2009-03-19 Vincent Richomme <richom.v@free.fr>
|
2009-03-19 Vincent Richomme <richom.v@free.fr>
|
||||||
|
|
||||||
Update WinCE Visual C project files.
|
Update WinCE Visual C project files.
|
||||||
|
|
|
@ -842,7 +842,20 @@
|
||||||
goto Exit;
|
goto Exit;
|
||||||
|
|
||||||
for ( j = 1; j < num_glyphs; j++ )
|
for ( j = 1; j < num_glyphs; j++ )
|
||||||
charset->sids[j] = FT_GET_USHORT();
|
{
|
||||||
|
FT_UShort sid = FT_GET_USHORT();
|
||||||
|
|
||||||
|
|
||||||
|
/* this constant is given in the CFF specification */
|
||||||
|
if ( sid < 65000 )
|
||||||
|
charset->sids[j] = sid;
|
||||||
|
else
|
||||||
|
{
|
||||||
|
FT_ERROR(( "cff_charset_load:"
|
||||||
|
" invalid SID value %d set to zero\n", sid ));
|
||||||
|
charset->sids[j] = 0;
|
||||||
|
}
|
||||||
|
}
|
||||||
|
|
||||||
FT_FRAME_EXIT();
|
FT_FRAME_EXIT();
|
||||||
}
|
}
|
||||||
|
@ -875,6 +888,20 @@
|
||||||
goto Exit;
|
goto Exit;
|
||||||
}
|
}
|
||||||
|
|
||||||
|
/* check whether the range contains at least one valid glyph; */
|
||||||
|
/* the constant is given in the CFF specification */
|
||||||
|
if ( glyph_sid >= 65000 ) {
|
||||||
|
FT_ERROR(( "cff_charset_load: invalid SID range\n" ));
|
||||||
|
error = CFF_Err_Invalid_File_Format;
|
||||||
|
goto Exit;
|
||||||
|
}
|
||||||
|
|
||||||
|
/* try to rescue some of the SIDs if `nleft' is too large */
|
||||||
|
if ( nleft > 65000 - 1 || glyph_sid >= 65000 - nleft ) {
|
||||||
|
FT_ERROR(( "cff_charset_load: invalid SID range trimmed\n" ));
|
||||||
|
nleft = 65000 - 1 - glyph_sid;
|
||||||
|
}
|
||||||
|
|
||||||
/* Fill in the range of sids -- `nleft + 1' glyphs. */
|
/* Fill in the range of sids -- `nleft + 1' glyphs. */
|
||||||
for ( i = 0; j < num_glyphs && i <= nleft; i++, j++, glyph_sid++ )
|
for ( i = 0; j < num_glyphs && i <= nleft; i++, j++, glyph_sid++ )
|
||||||
charset->sids[j] = glyph_sid;
|
charset->sids[j] = glyph_sid;
|
||||||
|
|
Loading…
Reference in New Issue