summaryrefslogtreecommitdiff
diff options
context:
space:
mode:
authorMike Pall <mike>2022-06-02 13:18:10 +0200
committerMike Pall <mike>2022-06-02 13:18:10 +0200
commitd4b6bb80ea3b26c4c65b568c1b808ee848f19221 (patch)
treeec095bd89178cc03dc4c169ea2cdaafae370fe93
parent1b8d8cabdcc4f1977dc8c51a82074653078d870b (diff)
downloadluajit2-d4b6bb80ea3b26c4c65b568c1b808ee848f19221.tar.gz
Fix ITERN loop detection when hook checks are enabled.
Reported by Myria.
-rw-r--r--src/lj_record.c15
1 files changed, 10 insertions, 5 deletions
diff --git a/src/lj_record.c b/src/lj_record.c
index 533f4995..faa9a508 100644
--- a/src/lj_record.c
+++ b/src/lj_record.c
@@ -664,12 +664,17 @@ static LoopEvent rec_itern(jit_State *J, BCReg ra, BCReg rb)
RecordIndex ix;
/* Since ITERN is recorded at the start, we need our own loop detection. */
if (J->pc == J->startpc &&
- (J->cur.nins > REF_FIRST+1 ||
- (J->cur.nins == REF_FIRST+1 && J->cur.ir[REF_FIRST].o != IR_PROF)) &&
J->framedepth + J->retdepth == 0 && J->parent == 0 && J->exitno == 0) {
- J->instunroll = 0; /* Cannot continue unrolling across an ITERN. */
- lj_record_stop(J, LJ_TRLINK_LOOP, J->cur.traceno); /* Looping trace. */
- return LOOPEV_ENTER;
+ IRRef ref = REF_FIRST + LJ_HASPROFILE;
+#ifdef LUAJIT_ENABLE_CHECKHOOK
+ ref += 3;
+#endif
+ if (J->cur.nins > ref ||
+ (LJ_HASPROFILE && J->cur.nins == ref && J->cur.ir[ref-1].o != IR_PROF)) {
+ J->instunroll = 0; /* Cannot continue unrolling across an ITERN. */
+ lj_record_stop(J, LJ_TRLINK_LOOP, J->cur.traceno); /* Looping trace. */
+ return LOOPEV_ENTER;
+ }
}
J->maxslot = ra;
lj_snap_add(J); /* Required to make JLOOP the first ins in a side-trace. */