mirror of
https://github.com/LuaJIT/LuaJIT.git
synced 2025-02-07 15:14:08 +00:00
Different fix for partial snapshot restore due to stack overflow.
Reported by Junlong Li. Fixed by Peter Cawley. #1196
This commit is contained in:
parent
7369eff67d
commit
86e7123bb1
@ -873,7 +873,8 @@ const BCIns *lj_snap_restore(jit_State *J, void *exptr)
|
|||||||
lua_State *L = J->L;
|
lua_State *L = J->L;
|
||||||
|
|
||||||
/* Set interpreter PC to the next PC to get correct error messages. */
|
/* Set interpreter PC to the next PC to get correct error messages. */
|
||||||
setcframe_pc(cframe_raw(L->cframe), pc+1);
|
setcframe_pc(L->cframe, pc+1);
|
||||||
|
setcframe_pc(cframe_raw(cframe_prev(L->cframe)), pc);
|
||||||
|
|
||||||
/* Make sure the stack is big enough for the slots from the snapshot. */
|
/* Make sure the stack is big enough for the slots from the snapshot. */
|
||||||
if (LJ_UNLIKELY(L->base + snap->topslot >= tvref(L->maxstack))) {
|
if (LJ_UNLIKELY(L->base + snap->topslot >= tvref(L->maxstack))) {
|
||||||
|
@ -788,10 +788,8 @@ int LJ_FASTCALL lj_trace_exit(jit_State *J, void *exptr)
|
|||||||
exd.J = J;
|
exd.J = J;
|
||||||
exd.exptr = exptr;
|
exd.exptr = exptr;
|
||||||
errcode = lj_vm_cpcall(L, NULL, &exd, trace_exit_cp);
|
errcode = lj_vm_cpcall(L, NULL, &exd, trace_exit_cp);
|
||||||
if (errcode) {
|
if (errcode)
|
||||||
setcframe_pc(cframe_raw(L->cframe), L); /* Point to any valid memory. */
|
|
||||||
return -errcode; /* Return negated error code. */
|
return -errcode; /* Return negated error code. */
|
||||||
}
|
|
||||||
|
|
||||||
lj_vmevent_send(L, TEXIT,
|
lj_vmevent_send(L, TEXIT,
|
||||||
lj_state_checkstack(L, 4+RID_NUM_GPR+RID_NUM_FPR+LUA_MINSTACK);
|
lj_state_checkstack(L, 4+RID_NUM_GPR+RID_NUM_FPR+LUA_MINSTACK);
|
||||||
|
Loading…
Reference in New Issue
Block a user