mirror of
https://github.com/LuaJIT/LuaJIT.git
synced 2025-02-08 07:34:07 +00:00
Merge branch 'master' into v2.1
This commit is contained in:
commit
2c0748f691
@ -1167,11 +1167,16 @@ LJFOLDF(simplify_conv_flt_num)
|
|||||||
LJFOLD(TOBIT CONV KNUM)
|
LJFOLD(TOBIT CONV KNUM)
|
||||||
LJFOLDF(simplify_tobit_conv)
|
LJFOLDF(simplify_tobit_conv)
|
||||||
{
|
{
|
||||||
if ((fleft->op2 & IRCONV_SRCMASK) == IRT_INT ||
|
|
||||||
(fleft->op2 & IRCONV_SRCMASK) == IRT_U32) {
|
|
||||||
/* Fold even across PHI to avoid expensive num->int conversions in loop. */
|
/* Fold even across PHI to avoid expensive num->int conversions in loop. */
|
||||||
|
if ((fleft->op2 & IRCONV_SRCMASK) == IRT_INT) {
|
||||||
lua_assert(irt_isnum(fleft->t));
|
lua_assert(irt_isnum(fleft->t));
|
||||||
return fleft->op1;
|
return fleft->op1;
|
||||||
|
} else if ((fleft->op2 & IRCONV_SRCMASK) == IRT_U32) {
|
||||||
|
lua_assert(irt_isnum(fleft->t));
|
||||||
|
fins->o = IR_CONV;
|
||||||
|
fins->op1 = fleft->op1;
|
||||||
|
fins->op2 = (IRT_INT<<5)|IRT_U32;
|
||||||
|
return RETRYFOLD;
|
||||||
}
|
}
|
||||||
return NEXTFOLD;
|
return NEXTFOLD;
|
||||||
}
|
}
|
||||||
|
Loading…
Reference in New Issue
Block a user