DUALNUM: Fix recording of loops broken by previous change.
Thanks to Nicholas Davies. #1432 #1433 #1438
This commit is contained in:
@@ -527,9 +527,9 @@ static LoopEvent rec_for(jit_State *J, const BCIns *fori, int isforl)
|
||||
TRef stop;
|
||||
IRType t;
|
||||
/* Avoid semantic mismatches and always failing guards. */
|
||||
if (tvisnan(&tv[FORL_IDX]) ||
|
||||
tvisnan(&tv[FORL_STOP]) ||
|
||||
tvisnan(&tv[FORL_STEP]) ||
|
||||
if ((tvisnum(&tv[FORL_IDX]) && tvisnan(&tv[FORL_IDX])) ||
|
||||
(tvisnum(&tv[FORL_STOP]) && tvisnan(&tv[FORL_STOP])) ||
|
||||
(tvisnum(&tv[FORL_STEP]) && tvisnan(&tv[FORL_STEP])) ||
|
||||
tvismzero(&tv[FORL_STEP]))
|
||||
lj_trace_err(J, LJ_TRERR_GFAIL);
|
||||
if (isforl) { /* Handle FORL/JFORL opcodes. */
|
||||
|
||||
Reference in New Issue
Block a user