summaryrefslogtreecommitdiff
diff options
context:
space:
mode:
authorRoberto Ierusalimschy <roberto@inf.puc-rio.br>2016-09-08 13:36:26 -0300
committerRoberto Ierusalimschy <roberto@inf.puc-rio.br>2016-09-08 13:36:26 -0300
commit7fe1a4cff3998bf019144924f39aec3f76a5cf32 (patch)
tree3f1c3984ae7093b3cdc3659a6db3d6565507f159
parentdbb6f11e8ee1eaa496215da5c04af80ec19b4df1 (diff)
downloadlua-7fe1a4cff3998bf019144924f39aec3f76a5cf32.tar.gz
lua-7fe1a4cff3998bf019144924f39aec3f76a5cf32.tar.bz2
lua-7fe1a4cff3998bf019144924f39aec3f76a5cf32.zip
cleaner and more correct code for 'luaD_shrinkstack' (the old
test "inuse <= LUAI_MAXSTACK" for stack overflow is not correct, as the real maximum usable size is "LUAI_MAXSTACK - EXTRA_STACK")
-rw-r--r--ldo.c13
1 files changed, 8 insertions, 5 deletions
diff --git a/ldo.c b/ldo.c
index 87f95bbd..cc5be57b 100644
--- a/ldo.c
+++ b/ldo.c
@@ -221,14 +221,17 @@ static int stackinuse (lua_State *L) {
221void luaD_shrinkstack (lua_State *L) { 221void luaD_shrinkstack (lua_State *L) {
222 int inuse = stackinuse(L); 222 int inuse = stackinuse(L);
223 int goodsize = inuse + (inuse / 8) + 2*EXTRA_STACK; 223 int goodsize = inuse + (inuse / 8) + 2*EXTRA_STACK;
224 if (goodsize > LUAI_MAXSTACK) goodsize = LUAI_MAXSTACK; 224 if (goodsize > LUAI_MAXSTACK)
225 if (L->stacksize > LUAI_MAXSTACK) /* was handling stack overflow? */ 225 goodsize = LUAI_MAXSTACK; /* respect stack limit */
226 if (L->stacksize > LUAI_MAXSTACK) /* had been handling stack overflow? */
226 luaE_freeCI(L); /* free all CIs (list grew because of an error) */ 227 luaE_freeCI(L); /* free all CIs (list grew because of an error) */
227 else 228 else
228 luaE_shrinkCI(L); /* shrink list */ 229 luaE_shrinkCI(L); /* shrink list */
229 if (inuse <= LUAI_MAXSTACK && /* not handling stack overflow? */ 230 /* if thread is currently not handling a stack overflow and its
230 goodsize < L->stacksize) /* trying to shrink? */ 231 good size is smaller than current size, shrink its stack */
231 luaD_reallocstack(L, goodsize); /* shrink it */ 232 if (inuse <= (LUAI_MAXSTACK - EXTRA_STACK) &&
233 goodsize < L->stacksize)
234 luaD_reallocstack(L, goodsize);
232 else 235 else
233 condmovestack(L,,); /* don't change stack (change only for debugging) */ 236 condmovestack(L,,); /* don't change stack (change only for debugging) */
234} 237}