Explorar el Código

added counters for total and individual CallInfo entries (to allow
better syncronization between CallInfo size and stack size)

Roberto Ierusalimschy hace 9 años
padre
commit
33b366ec32
Se han modificado 2 ficheros con 19 adiciones y 9 borrados
  1. 16 8
      lstate.c
  2. 3 1
      lstate.h

+ 16 - 8
lstate.c

@@ -1,5 +1,5 @@
 /*
 /*
-** $Id: lstate.c,v 2.130 2015/09/08 15:41:05 roberto Exp roberto $
+** $Id: lstate.c,v 2.131 2015/10/20 13:11:05 roberto Exp roberto $
 ** Global State
 ** Global State
 ** See Copyright Notice in lua.h
 ** See Copyright Notice in lua.h
 */
 */
@@ -111,6 +111,7 @@ CallInfo *luaE_extendCI (lua_State *L) {
   L->ci->next = ci;
   L->ci->next = ci;
   ci->previous = L->ci;
   ci->previous = L->ci;
   ci->next = NULL;
   ci->next = NULL;
+  ci->n = ++L->nci;
   return ci;
   return ci;
 }
 }
 
 
@@ -126,6 +127,7 @@ void luaE_freeCI (lua_State *L) {
     next = ci->next;
     next = ci->next;
     luaM_free(L, ci);
     luaM_free(L, ci);
   }
   }
+  L->nci = L->ci->n;
 }
 }
 
 
 
 
@@ -134,14 +136,17 @@ void luaE_freeCI (lua_State *L) {
 */
 */
 void luaE_shrinkCI (lua_State *L) {
 void luaE_shrinkCI (lua_State *L) {
   CallInfo *ci = L->ci;
   CallInfo *ci = L->ci;
-  while (ci->next != NULL) {  /* while there is 'next' */
-    CallInfo *next2 = ci->next->next;  /* next's next */
-    if (next2 == NULL) break;
-    luaM_free(L, ci->next);  /* remove next */
-    ci->next = next2;  /* remove 'next' from the list */
-    next2->previous = ci;
-    ci = next2;
+  CallInfo *next;
+  int n = (L->nci - ci->n + 1)/2;  /* number of entries to be preserved */
+  for (; n > 0; n--)
+    ci = ci->next;  /* skip items to be preserved */
+  lua_assert(n == 0);
+  while ((next = ci->next) != NULL) {  /* remove all other items */
+    ci->next = next->next;
+    luaM_free(L, next);  /* remove item */
+    n++;  /* count number of removed items */
   }
   }
+  L->nci -= n;
 }
 }
 
 
 
 
@@ -156,6 +161,7 @@ static void stack_init (lua_State *L1, lua_State *L) {
   L1->stack_last = L1->stack + L1->stacksize - EXTRA_STACK;
   L1->stack_last = L1->stack + L1->stacksize - EXTRA_STACK;
   /* initialize first ci */
   /* initialize first ci */
   ci = &L1->base_ci;
   ci = &L1->base_ci;
+  ci->n = 0;
   ci->next = ci->previous = NULL;
   ci->next = ci->previous = NULL;
   ci->callstatus = 0;
   ci->callstatus = 0;
   ci->func = L1->top;
   ci->func = L1->top;
@@ -170,6 +176,7 @@ static void freestack (lua_State *L) {
     return;  /* stack not completely built yet */
     return;  /* stack not completely built yet */
   L->ci = &L->base_ci;  /* free the entire 'ci' list */
   L->ci = &L->base_ci;  /* free the entire 'ci' list */
   luaE_freeCI(L);
   luaE_freeCI(L);
+  lua_assert(L->nci == 0);
   luaM_freearray(L, L->stack, L->stacksize);  /* free stack array */
   luaM_freearray(L, L->stack, L->stacksize);  /* free stack array */
 }
 }
 
 
@@ -218,6 +225,7 @@ static void preinit_thread (lua_State *L, global_State *g) {
   G(L) = g;
   G(L) = g;
   L->stack = NULL;
   L->stack = NULL;
   L->ci = NULL;
   L->ci = NULL;
+  L->nci = 0;
   L->stacksize = 0;
   L->stacksize = 0;
   L->twups = L;  /* thread has no upvalues */
   L->twups = L;  /* thread has no upvalues */
   L->errorJmp = NULL;
   L->errorJmp = NULL;

+ 3 - 1
lstate.h

@@ -1,5 +1,5 @@
 /*
 /*
-** $Id: lstate.h,v 2.125 2015/09/22 14:18:24 roberto Exp roberto $
+** $Id: lstate.h,v 2.126 2015/11/02 11:43:17 roberto Exp roberto $
 ** Global State
 ** Global State
 ** See Copyright Notice in lua.h
 ** See Copyright Notice in lua.h
 */
 */
@@ -78,6 +78,7 @@ typedef struct CallInfo {
     } c;
     } c;
   } u;
   } u;
   ptrdiff_t extra;
   ptrdiff_t extra;
+  unsigned short n;  /* ordinal number in call list */
   short nresults;  /* expected number of results from this function */
   short nresults;  /* expected number of results from this function */
   lu_byte callstatus;
   lu_byte callstatus;
 } CallInfo;
 } CallInfo;
@@ -149,6 +150,7 @@ typedef struct global_State {
 */
 */
 struct lua_State {
 struct lua_State {
   CommonHeader;
   CommonHeader;
+  unsigned short nci;  /* number of items in 'ci' list */
   lu_byte status;
   lu_byte status;
   StkId top;  /* first free slot in the stack */
   StkId top;  /* first free slot in the stack */
   global_State *l_G;
   global_State *l_G;