mirror of
https://github.com/lua/lua.git
synced 2025-01-14 05:43:00 +08:00
macro 'checkGC' takes care of setting 'top' to limit stack live values
This commit is contained in:
parent
edfa9e007d
commit
5654763797
25
lvm.c
25
lvm.c
@ -1,5 +1,5 @@
|
|||||||
/*
|
/*
|
||||||
** $Id: lvm.c,v 2.149 2012/01/25 21:05:40 roberto Exp roberto $
|
** $Id: lvm.c,v 2.150 2012/05/08 13:53:33 roberto Exp roberto $
|
||||||
** Lua virtual machine
|
** Lua virtual machine
|
||||||
** See Copyright Notice in lua.h
|
** See Copyright Notice in lua.h
|
||||||
*/
|
*/
|
||||||
@ -502,7 +502,11 @@ void luaV_finishOp (lua_State *L) {
|
|||||||
|
|
||||||
#define Protect(x) { {x;}; base = ci->u.l.base; }
|
#define Protect(x) { {x;}; base = ci->u.l.base; }
|
||||||
|
|
||||||
#define checkGC(L,c) Protect(luaC_condGC(L, c); luai_threadyield(L);)
|
#define checkGC(L,c) \
|
||||||
|
Protect( luaC_condGC(L,{L->top = (c); /* limit of live values */ \
|
||||||
|
luaC_step(L); \
|
||||||
|
L->top = ci->top;}) /* restore top */ \
|
||||||
|
luai_threadyield(L); )
|
||||||
|
|
||||||
|
|
||||||
#define arith_op(op,tm) { \
|
#define arith_op(op,tm) { \
|
||||||
@ -595,11 +599,7 @@ void luaV_execute (lua_State *L) {
|
|||||||
sethvalue(L, ra, t);
|
sethvalue(L, ra, t);
|
||||||
if (b != 0 || c != 0)
|
if (b != 0 || c != 0)
|
||||||
luaH_resize(L, t, luaO_fb2int(b), luaO_fb2int(c));
|
luaH_resize(L, t, luaO_fb2int(b), luaO_fb2int(c));
|
||||||
checkGC(L,
|
checkGC(L, ra + 1);
|
||||||
L->top = ra + 1; /* limit of live values */
|
|
||||||
luaC_step(L);
|
|
||||||
L->top = ci->top; /* restore top */
|
|
||||||
)
|
|
||||||
)
|
)
|
||||||
vmcase(OP_SELF,
|
vmcase(OP_SELF,
|
||||||
StkId rb = RB(i);
|
StkId rb = RB(i);
|
||||||
@ -651,10 +651,7 @@ void luaV_execute (lua_State *L) {
|
|||||||
ra = RA(i); /* 'luav_concat' may invoke TMs and move the stack */
|
ra = RA(i); /* 'luav_concat' may invoke TMs and move the stack */
|
||||||
rb = b + base;
|
rb = b + base;
|
||||||
setobjs2s(L, ra, rb);
|
setobjs2s(L, ra, rb);
|
||||||
checkGC(L,
|
checkGC(L, (ra >= rb ? ra + 1 : rb));
|
||||||
L->top = (ra >= rb ? ra + 1 : rb); /* limit of live values */
|
|
||||||
luaC_step(L);
|
|
||||||
)
|
|
||||||
L->top = ci->top; /* restore top */
|
L->top = ci->top; /* restore top */
|
||||||
)
|
)
|
||||||
vmcase(OP_JMP,
|
vmcase(OP_JMP,
|
||||||
@ -832,11 +829,7 @@ void luaV_execute (lua_State *L) {
|
|||||||
pushclosure(L, p, cl->upvals, base, ra); /* create a new one */
|
pushclosure(L, p, cl->upvals, base, ra); /* create a new one */
|
||||||
else
|
else
|
||||||
setclLvalue(L, ra, ncl); /* push cashed closure */
|
setclLvalue(L, ra, ncl); /* push cashed closure */
|
||||||
checkGC(L,
|
checkGC(L, ra + 1);
|
||||||
L->top = ra + 1; /* limit of live values */
|
|
||||||
luaC_step(L);
|
|
||||||
L->top = ci->top; /* restore top */
|
|
||||||
)
|
|
||||||
)
|
)
|
||||||
vmcase(OP_VARARG,
|
vmcase(OP_VARARG,
|
||||||
int b = GETARG_B(i) - 1;
|
int b = GETARG_B(i) - 1;
|
||||||
|
Loading…
x
Reference in New Issue
Block a user