diff options
-rw-r--r-- | src/lj_record.c | 2 |
1 files changed, 1 insertions, 1 deletions
diff --git a/src/lj_record.c b/src/lj_record.c index 47d7115b..12b76bba 100644 --- a/src/lj_record.c +++ b/src/lj_record.c | |||
@@ -1060,7 +1060,7 @@ static void rec_idx_abc(jit_State *J, TRef asizeref, TRef ikey, uint32_t asize) | |||
1060 | lua_assert(irt_isint(J->scev.t) && ir->o == IR_SLOAD); | 1060 | lua_assert(irt_isint(J->scev.t) && ir->o == IR_SLOAD); |
1061 | stop = numberVint(&(J->L->base - J->baseslot)[ir->op1 + FORL_STOP]); | 1061 | stop = numberVint(&(J->L->base - J->baseslot)[ir->op1 + FORL_STOP]); |
1062 | /* Runtime value for stop of loop is within bounds? */ | 1062 | /* Runtime value for stop of loop is within bounds? */ |
1063 | if ((int64_t)stop + ofs < (int64_t)asize) { | 1063 | if ((uint64_t)stop + ofs < (uint64_t)asize) { |
1064 | /* Emit invariant bounds check for stop. */ | 1064 | /* Emit invariant bounds check for stop. */ |
1065 | emitir(IRTG(IR_ABC, IRT_P32), asizeref, ofs == 0 ? J->scev.stop : | 1065 | emitir(IRTG(IR_ABC, IRT_P32), asizeref, ofs == 0 ? J->scev.stop : |
1066 | emitir(IRTI(IR_ADD), J->scev.stop, ofsref)); | 1066 | emitir(IRTI(IR_ADD), J->scev.stop, ofsref)); |