aboutsummaryrefslogtreecommitdiff
diff options
context:
space:
mode:
authorRoberto Ierusalimschy <roberto@inf.puc-rio.br>2010-05-03 14:39:48 -0300
committerRoberto Ierusalimschy <roberto@inf.puc-rio.br>2010-05-03 14:39:48 -0300
commitaa73403ba41f7f0992e839e5eb3dd480ef3c01a3 (patch)
treeef416ab2e316d896cc0e0abca789c5902d4b0811
parent0c27de2e7bb93936e9a1ad84ebc1f4d99e845190 (diff)
downloadlua-aa73403ba41f7f0992e839e5eb3dd480ef3c01a3.tar.gz
lua-aa73403ba41f7f0992e839e5eb3dd480ef3c01a3.tar.bz2
lua-aa73403ba41f7f0992e839e5eb3dd480ef3c01a3.zip
no need of a KGC_FORCED collection kind; it has the same behavior of
a normal collection
-rw-r--r--lgc.c9
-rw-r--r--lstate.h7
2 files changed, 7 insertions, 9 deletions
diff --git a/lgc.c b/lgc.c
index ab3d0ace..d49a5f9d 100644
--- a/lgc.c
+++ b/lgc.c
@@ -1,5 +1,5 @@
1/* 1/*
2** $Id: lgc.c,v 2.84 2010/05/03 11:55:40 roberto Exp roberto $ 2** $Id: lgc.c,v 2.85 2010/05/03 17:33:39 roberto Exp roberto $
3** Garbage Collector 3** Garbage Collector
4** See Copyright Notice in lua.h 4** See Copyright Notice in lua.h
5*/ 5*/
@@ -899,7 +899,6 @@ static void generationalcollection (lua_State *L) {
899static void step (lua_State *L) { 899static void step (lua_State *L) {
900 global_State *g = G(L); 900 global_State *g = G(L);
901 l_mem lim = g->gcstepmul; /* how much to work */ 901 l_mem lim = g->gcstepmul; /* how much to work */
902 lua_assert(g->gckind == KGC_NORMAL);
903 do { /* always perform at least one single step */ 902 do { /* always perform at least one single step */
904 lim -= singlestep(L); 903 lim -= singlestep(L);
905 } while (lim > 0 && g->gcstate != GCSpause); 904 } while (lim > 0 && g->gcstate != GCSpause);
@@ -926,10 +925,10 @@ void luaC_step (lua_State *L) {
926void luaC_fullgc (lua_State *L, int isemergency) { 925void luaC_fullgc (lua_State *L, int isemergency) {
927 global_State *g = G(L); 926 global_State *g = G(L);
928 int origkind = g->gckind; 927 int origkind = g->gckind;
929 lua_assert(origkind == KGC_NORMAL || origkind == KGC_GEN); 928 lua_assert(origkind != KGC_EMERGENCY);
930 if (!isemergency) /* do not run finalizers during emergency GC */ 929 if (!isemergency) /* do not run finalizers during emergency GC */
931 callallpendingfinalizers(L, 1); 930 callallpendingfinalizers(L, 1);
932 g->gckind = isemergency ? KGC_EMERGENCY : KGC_FORCED; 931 g->gckind = isemergency ? KGC_EMERGENCY : KGC_NORMAL;
933 if (g->gcstate == GCSpropagate) { /* marking phase? */ 932 if (g->gcstate == GCSpropagate) { /* marking phase? */
934 /* must sweep all objects to turn them back to white 933 /* must sweep all objects to turn them back to white
935 (as white has not changed, nothing will be collected) */ 934 (as white has not changed, nothing will be collected) */
@@ -945,7 +944,7 @@ void luaC_fullgc (lua_State *L, int isemergency) {
945 if (!isemergency) /* do not run finalizers during emergency GC */ 944 if (!isemergency) /* do not run finalizers during emergency GC */
946 callallpendingfinalizers(L, 1); 945 callallpendingfinalizers(L, 1);
947 if (origkind == KGC_GEN) { /* generational mode? */ 946 if (origkind == KGC_GEN) { /* generational mode? */
948 /* collector must be always in propagate phase */ 947 /* generational mode must always start in propagate phase */
949 luaC_runtilstate(L, bitmask(GCSpropagate)); 948 luaC_runtilstate(L, bitmask(GCSpropagate));
950 } 949 }
951 g->GCdebt = stddebt(g); 950 g->GCdebt = stddebt(g);
diff --git a/lstate.h b/lstate.h
index 28fd8d92..452046fb 100644
--- a/lstate.h
+++ b/lstate.h
@@ -1,5 +1,5 @@
1/* 1/*
2** $Id: lstate.h,v 2.63 2010/04/13 20:48:12 roberto Exp roberto $ 2** $Id: lstate.h,v 2.64 2010/04/29 17:31:31 roberto Exp roberto $
3** Global State 3** Global State
4** See Copyright Notice in lua.h 4** See Copyright Notice in lua.h
5*/ 5*/
@@ -54,9 +54,8 @@ struct lua_longjmp; /* defined in ldo.c */
54 54
55/* kinds of Garbage Collection */ 55/* kinds of Garbage Collection */
56#define KGC_NORMAL 0 56#define KGC_NORMAL 0
57#define KGC_FORCED 1 /* gc was forced by the program */ 57#define KGC_EMERGENCY 1 /* gc was forced by an allocation failure */
58#define KGC_EMERGENCY 2 /* gc was forced by an allocation failure */ 58#define KGC_GEN 2 /* generational collection */
59#define KGC_GEN 3 /* generational collection */
60 59
61 60
62typedef struct stringtable { 61typedef struct stringtable {