[HB] Fix invalid access / overflow on x86-64

Bug 591557 – [HB] crash scrolling the evolution message list
Bug 591576 – crashed with SIGSEGV at pango
This commit is contained in:
Behdad Esfahbod 2009-08-12 15:40:04 -04:00
parent 8d70312c7b
commit 0532ed160c
2 changed files with 12 additions and 11 deletions

View File

@ -913,13 +913,14 @@ struct MarkBasePosFormat1
/* now we search backwards for a non-mark glyph */
unsigned int count = buffer->in_pos;
unsigned int i = 1, j = count - 1;
while (_hb_ot_layout_skip_mark (context->face, IN_INFO (j), LookupFlag::IgnoreMarks, &property))
unsigned int i = 0, j = count;
do
{
if (HB_UNLIKELY (i == count))
return false;
i++, j--;
}
} while (_hb_ot_layout_skip_mark (context->face, IN_INFO (j), LookupFlag::IgnoreMarks, &property))
#if 0
/* The following assertion is too strong. */
if (!(property & HB_OT_LAYOUT_GLYPH_CLASS_BASE_GLYPH))
@ -1046,13 +1047,14 @@ struct MarkLigPosFormat1
/* now we search backwards for a non-mark glyph */
unsigned int count = buffer->in_pos;
unsigned int i = 1, j = count - 1;
while (_hb_ot_layout_skip_mark (context->face, IN_INFO (j), LookupFlag::IgnoreMarks, &property))
unsigned int i = 0, j = count;
do
{
if (HB_UNLIKELY (i == count))
return false;
i++, j--;
}
} while (_hb_ot_layout_skip_mark (context->face, IN_INFO (j), LookupFlag::IgnoreMarks, &property));
#if 0
/* The following assertion is too strong. */
if (!(property & HB_OT_LAYOUT_GLYPH_CLASS_LIGATURE))
@ -1203,13 +1205,14 @@ struct MarkMarkPosFormat1
/* now we search backwards for a suitable mark glyph until a non-mark glyph */
unsigned int count = buffer->in_pos;
unsigned int i = 1, j = count - 1;
while (_hb_ot_layout_skip_mark (context->face, IN_INFO (j), lookup_flag, &property))
unsigned int i = 0, j = count;
do
{
if (HB_UNLIKELY (i == count))
return false;
i++, j--;
}
} while (_hb_ot_layout_skip_mark (context->face, IN_INFO (j), lookup_flag, &property));
if (!(property & HB_OT_LAYOUT_GLYPH_CLASS_MARK))
return false;

View File

@ -798,11 +798,9 @@ struct SubstLookup : Lookup
}
if (ret)
_hb_buffer_swap (buffer);
}
else
{
/* in-place backward substitution */
buffer->in_pos = buffer->in_length - 1;
do