aboutsummaryrefslogtreecommitdiff
diff options
context:
space:
mode:
authorMike Pall <mike>2021-07-23 21:36:17 +0200
committerMike Pall <mike>2021-07-23 21:36:17 +0200
commit89a6740ffd1ba4e1412b820912510e10d91c7af6 (patch)
treecd9fa745275e990a6df603033d122cd15d19c34d
parentdbb6c39f7c69691f6bd9a8b5d6bf7c97b3dbe268 (diff)
parent0e66fc96377853d898390f1a02723c54ec3a42f7 (diff)
downloadluajit-89a6740ffd1ba4e1412b820912510e10d91c7af6.tar.gz
luajit-89a6740ffd1ba4e1412b820912510e10d91c7af6.tar.bz2
luajit-89a6740ffd1ba4e1412b820912510e10d91c7af6.zip
Merge branch 'master' into v2.1
-rw-r--r--src/lj_snap.c7
1 files changed, 6 insertions, 1 deletions
diff --git a/src/lj_snap.c b/src/lj_snap.c
index b6a02f6f..b2b8450c 100644
--- a/src/lj_snap.c
+++ b/src/lj_snap.c
@@ -252,7 +252,12 @@ static BCReg snap_usedef(jit_State *J, uint8_t *udf,
252 BCReg minslot = bc_a(ins); 252 BCReg minslot = bc_a(ins);
253 if (op >= BC_FORI && op <= BC_JFORL) minslot += FORL_EXT; 253 if (op >= BC_FORI && op <= BC_JFORL) minslot += FORL_EXT;
254 else if (op >= BC_ITERL && op <= BC_JITERL) minslot += bc_b(pc[-2])-1; 254 else if (op >= BC_ITERL && op <= BC_JITERL) minslot += bc_b(pc[-2])-1;
255 else if (op == BC_UCLO) { pc += bc_j(ins); break; } 255 else if (op == BC_UCLO) {
256 ptrdiff_t delta = bc_j(ins);
257 if (delta < 0) return maxslot; /* Prevent loop. */
258 pc += delta;
259 break;
260 }
256 for (s = minslot; s < maxslot; s++) DEF_SLOT(s); 261 for (s = minslot; s < maxslot; s++) DEF_SLOT(s);
257 return minslot < maxslot ? minslot : maxslot; 262 return minslot < maxslot ? minslot : maxslot;
258 } 263 }