[base] Tighten the overflow check in `FT_MulFix'.
* src/base/ftcalc.c (FT_MulFix) [!FT_LONG64]: Updated.
This commit is contained in:
parent
125c3ca8f0
commit
3212852cce
|
@ -1,3 +1,9 @@
|
||||||
|
2014-09-03 Alexei Podtelezhnikov <apodtele@gmail.com>
|
||||||
|
|
||||||
|
[base] Tighten the overflow check in `FT_MulFix'.
|
||||||
|
|
||||||
|
* src/base/ftcalc.c (FT_MulFix) [!FT_LONG64]: Updated.
|
||||||
|
|
||||||
2014-09-02 Alexei Podtelezhnikov <apodtele@gmail.com>
|
2014-09-02 Alexei Podtelezhnikov <apodtele@gmail.com>
|
||||||
|
|
||||||
[truetype] Shortcut ppem calculations for square pixels.
|
[truetype] Shortcut ppem calculations for square pixels.
|
||||||
|
|
|
@ -394,7 +394,8 @@
|
||||||
/* */
|
/* */
|
||||||
/* a + (b >> 8) <= (131071 >> 4) */
|
/* a + (b >> 8) <= (131071 >> 4) */
|
||||||
/* */
|
/* */
|
||||||
/* should work well to avoid the overflow. */
|
/* covers the practical range of use. The actual test below is a bit */
|
||||||
|
/* tighter to avoid the border case overflows. */
|
||||||
/* */
|
/* */
|
||||||
|
|
||||||
/* documentation is in freetype.h */
|
/* documentation is in freetype.h */
|
||||||
|
@ -524,7 +525,7 @@
|
||||||
ua = (FT_ULong)a;
|
ua = (FT_ULong)a;
|
||||||
ub = (FT_ULong)b;
|
ub = (FT_ULong)b;
|
||||||
|
|
||||||
if ( ua + ( ub >> 8 ) <= 8191UL )
|
if ( ua + ( ub >> 8 ) <= 8190UL )
|
||||||
ua = ( ua * ub + 0x8000U ) >> 16;
|
ua = ( ua * ub + 0x8000U ) >> 16;
|
||||||
else
|
else
|
||||||
{
|
{
|
||||||
|
@ -555,7 +556,7 @@
|
||||||
ua = (FT_ULong)a;
|
ua = (FT_ULong)a;
|
||||||
ub = (FT_ULong)b;
|
ub = (FT_ULong)b;
|
||||||
|
|
||||||
if ( ua + ( ub >> 8 ) <= 8191UL )
|
if ( ua + ( ub >> 8 ) <= 8190UL )
|
||||||
ua = ( ua * ub + 0x8000UL ) >> 16;
|
ua = ( ua * ub + 0x8000UL ) >> 16;
|
||||||
else
|
else
|
||||||
{
|
{
|
||||||
|
|
Loading…
Reference in New Issue