diff options
author | Roberto Ierusalimschy <roberto@inf.puc-rio.br> | 2004-12-13 10:15:11 -0200 |
---|---|---|
committer | Roberto Ierusalimschy <roberto@inf.puc-rio.br> | 2004-12-13 10:15:11 -0200 |
commit | c6254dceffca200e4111f28af4230b6c892ec0d6 (patch) | |
tree | c9a122ae3c1d28cad4d9f8ed5578a8be18d0a27d | |
parent | a56d889f7225a3cfdfa6dfeb55db2b4ae22f1572 (diff) | |
download | lua-c6254dceffca200e4111f28af4230b6c892ec0d6.tar.gz lua-c6254dceffca200e4111f28af4230b6c892ec0d6.tar.bz2 lua-c6254dceffca200e4111f28af4230b6c892ec0d6.zip |
a different option for the GC
-rw-r--r-- | lapi.c | 8 | ||||
-rw-r--r-- | lbaselib.c | 6 | ||||
-rw-r--r-- | lgc.c | 10 | ||||
-rw-r--r-- | llimits.h | 4 | ||||
-rw-r--r-- | lstate.c | 4 | ||||
-rw-r--r-- | lstate.h | 4 | ||||
-rw-r--r-- | lua.h | 4 |
7 files changed, 21 insertions, 19 deletions
@@ -1,5 +1,5 @@ | |||
1 | /* | 1 | /* |
2 | ** $Id: lapi.c,v 2.21 2004/12/03 20:50:25 roberto Exp roberto $ | 2 | ** $Id: lapi.c,v 2.22 2004/12/06 17:53:42 roberto Exp roberto $ |
3 | ** Lua API | 3 | ** Lua API |
4 | ** See Copyright Notice in lua.h | 4 | ** See Copyright Notice in lua.h |
5 | */ | 5 | */ |
@@ -867,9 +867,9 @@ LUA_API int lua_gc (lua_State *L, int what, int data) { | |||
867 | luaC_step(L); | 867 | luaC_step(L); |
868 | break; | 868 | break; |
869 | } | 869 | } |
870 | case LUA_GCSETSTEPMUL: { | 870 | case LUA_GCSETPACE: { |
871 | res = g->stepmul; | 871 | res = g->gcpace; |
872 | g->stepmul = data; | 872 | g->gcpace = data; |
873 | break; | 873 | break; |
874 | } | 874 | } |
875 | case LUA_GCSETINCMODE: { | 875 | case LUA_GCSETINCMODE: { |
@@ -1,5 +1,5 @@ | |||
1 | /* | 1 | /* |
2 | ** $Id: lbaselib.c,v 1.161 2004/12/06 17:53:42 roberto Exp roberto $ | 2 | ** $Id: lbaselib.c,v 1.162 2004/12/07 18:31:34 roberto Exp roberto $ |
3 | ** Basic library | 3 | ** Basic library |
4 | ** See Copyright Notice in lua.h | 4 | ** See Copyright Notice in lua.h |
5 | */ | 5 | */ |
@@ -182,9 +182,9 @@ static int luaB_gcinfo (lua_State *L) { | |||
182 | 182 | ||
183 | static int luaB_collectgarbage (lua_State *L) { | 183 | static int luaB_collectgarbage (lua_State *L) { |
184 | static const char *const opts[] = {"stop", "restart", "collect", | 184 | static const char *const opts[] = {"stop", "restart", "collect", |
185 | "count", "step", "setstepmul", "setincmode", NULL}; | 185 | "count", "step", "setpace", "setincmode", NULL}; |
186 | static const int optsnum[] = {LUA_GCSTOP, LUA_GCRESTART, LUA_GCCOLLECT, | 186 | static const int optsnum[] = {LUA_GCSTOP, LUA_GCRESTART, LUA_GCCOLLECT, |
187 | LUA_GCCOUNT, LUA_GCSTEP, LUA_GCSETSTEPMUL, LUA_GCSETINCMODE}; | 187 | LUA_GCCOUNT, LUA_GCSTEP, LUA_GCSETPACE, LUA_GCSETINCMODE}; |
188 | int o = luaL_findstring(luaL_optstring(L, 1, "collect"), opts); | 188 | int o = luaL_findstring(luaL_optstring(L, 1, "collect"), opts); |
189 | int ex = luaL_optint(L, 2, 0); | 189 | int ex = luaL_optint(L, 2, 0); |
190 | luaL_argcheck(L, o >= 0, 1, "invalid option"); | 190 | luaL_argcheck(L, o >= 0, 1, "invalid option"); |
@@ -1,5 +1,5 @@ | |||
1 | /* | 1 | /* |
2 | ** $Id: lgc.c,v 2.17 2004/11/24 19:20:21 roberto Exp roberto $ | 2 | ** $Id: lgc.c,v 2.18 2004/12/06 17:53:42 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 | */ |
@@ -27,6 +27,7 @@ | |||
27 | #define GCSWEEPMAX 10 | 27 | #define GCSWEEPMAX 10 |
28 | #define GCSWEEPCOST 30 | 28 | #define GCSWEEPCOST 30 |
29 | #define GCFINALIZECOST 100 | 29 | #define GCFINALIZECOST 100 |
30 | #define GCSTEPMUL 8 | ||
30 | 31 | ||
31 | 32 | ||
32 | #define FIXEDMASK bitmask(FIXEDBIT) | 33 | #define FIXEDMASK bitmask(FIXEDBIT) |
@@ -621,18 +622,17 @@ static l_mem singlestep (lua_State *L) { | |||
621 | 622 | ||
622 | void luaC_step (lua_State *L) { | 623 | void luaC_step (lua_State *L) { |
623 | global_State *g = G(L); | 624 | global_State *g = G(L); |
624 | l_mem lim = (g->totalbytes - (g->GCthreshold - GCSTEPSIZE)) * g->stepmul; | 625 | l_mem lim = (g->totalbytes - (g->GCthreshold - GCSTEPSIZE)) * GCSTEPMUL; |
625 | do { | 626 | do { |
626 | lim -= singlestep(L); | 627 | lim -= singlestep(L); |
627 | if (g->gcstate == GCSpause) | 628 | if (g->gcstate == GCSpause) |
628 | break; | 629 | break; |
629 | } while (lim > 0 || !g->incgc); | 630 | } while (lim > 0 || !g->incgc); |
630 | if (g->incgc) | 631 | if (g->gcstate != GCSpause) |
631 | g->GCthreshold = g->totalbytes + GCSTEPSIZE; /* - lim/STEPMUL; */ | 632 | g->GCthreshold = g->totalbytes + GCSTEPSIZE; /* - lim/STEPMUL; */ |
632 | else { | 633 | else { |
633 | lua_assert(g->totalbytes >= g->estimate); | 634 | lua_assert(g->totalbytes >= g->estimate); |
634 | lua_assert(g->gcstate == GCSpause); | 635 | g->GCthreshold = g->estimate + ((g->estimate/GCDIV) * g->gcpace); |
635 | g->GCthreshold = 2*g->estimate; | ||
636 | } | 636 | } |
637 | } | 637 | } |
638 | 638 | ||
@@ -1,5 +1,5 @@ | |||
1 | /* | 1 | /* |
2 | ** $Id: llimits.h,v 1.60 2004/09/10 17:30:46 roberto Exp roberto $ | 2 | ** $Id: llimits.h,v 1.61 2004/11/24 18:55:56 roberto Exp roberto $ |
3 | ** Limits, basic types, and some other `installation-dependent' definitions | 3 | ** Limits, basic types, and some other `installation-dependent' definitions |
4 | ** See Copyright Notice in lua.h | 4 | ** See Copyright Notice in lua.h |
5 | */ | 5 | */ |
@@ -73,6 +73,8 @@ typedef LUA_UACNUMBER l_uacNumber; | |||
73 | typedef lu_int32 Instruction; | 73 | typedef lu_int32 Instruction; |
74 | 74 | ||
75 | 75 | ||
76 | /* divisor for GC pace */ | ||
77 | #define GCDIV 8 | ||
76 | 78 | ||
77 | /* maximum stack for a Lua function */ | 79 | /* maximum stack for a Lua function */ |
78 | #define MAXSTACK 250 | 80 | #define MAXSTACK 250 |
@@ -1,5 +1,5 @@ | |||
1 | /* | 1 | /* |
2 | ** $Id: lstate.c,v 2.17 2004/11/24 19:20:21 roberto Exp roberto $ | 2 | ** $Id: lstate.c,v 2.18 2004/12/06 17:53:42 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 | */ |
@@ -193,7 +193,7 @@ LUA_API lua_State *lua_newstate (lua_Alloc f, void *ud) { | |||
193 | setnilvalue(gval(g->dummynode)); | 193 | setnilvalue(gval(g->dummynode)); |
194 | gnext(g->dummynode) = NULL; | 194 | gnext(g->dummynode) = NULL; |
195 | g->totalbytes = sizeof(LG); | 195 | g->totalbytes = sizeof(LG); |
196 | g->stepmul = STEPMUL; | 196 | g->gcpace = GCDIV; |
197 | g->incgc = 1; | 197 | g->incgc = 1; |
198 | if (luaD_rawrunprotected(L, f_luaopen, NULL) != 0) { | 198 | if (luaD_rawrunprotected(L, f_luaopen, NULL) != 0) { |
199 | /* memory allocation error: free partial state */ | 199 | /* memory allocation error: free partial state */ |
@@ -1,5 +1,5 @@ | |||
1 | /* | 1 | /* |
2 | ** $Id: lstate.h,v 2.8 2004/09/15 20:39:42 roberto Exp roberto $ | 2 | ** $Id: lstate.h,v 2.9 2004/12/06 17:53:42 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 | */ |
@@ -85,7 +85,7 @@ typedef struct global_State { | |||
85 | lu_mem totalbytes; /* number of bytes currently allocated */ | 85 | lu_mem totalbytes; /* number of bytes currently allocated */ |
86 | lu_mem estimate; /* an estimate of number of bytes actually in use */ | 86 | lu_mem estimate; /* an estimate of number of bytes actually in use */ |
87 | lu_mem prevestimate; /* previous estimate */ | 87 | lu_mem prevestimate; /* previous estimate */ |
88 | int stepmul; /* relative `speed' of the GC */ | 88 | int gcpace; /* relative `speed' of the GC */ |
89 | int incgc; /* 0 if GC is done non-incrementally */ | 89 | int incgc; /* 0 if GC is done non-incrementally */ |
90 | lua_CFunction panic; /* to be called in unprotected errors */ | 90 | lua_CFunction panic; /* to be called in unprotected errors */ |
91 | TValue _registry; | 91 | TValue _registry; |
@@ -1,5 +1,5 @@ | |||
1 | /* | 1 | /* |
2 | ** $Id: lua.h,v 1.195 2004/12/01 15:50:18 roberto Exp roberto $ | 2 | ** $Id: lua.h,v 1.196 2004/12/06 17:53:42 roberto Exp roberto $ |
3 | ** Lua - An Extensible Extension Language | 3 | ** Lua - An Extensible Extension Language |
4 | ** Tecgraf: Computer Graphics Technology Group, PUC-Rio, Brazil | 4 | ** Tecgraf: Computer Graphics Technology Group, PUC-Rio, Brazil |
5 | ** http://www.lua.org mailto:info@lua.org | 5 | ** http://www.lua.org mailto:info@lua.org |
@@ -225,7 +225,7 @@ LUA_API int lua_threadstatus (lua_State *L); | |||
225 | #define LUA_GCCOLLECT 2 | 225 | #define LUA_GCCOLLECT 2 |
226 | #define LUA_GCCOUNT 3 | 226 | #define LUA_GCCOUNT 3 |
227 | #define LUA_GCSTEP 4 | 227 | #define LUA_GCSTEP 4 |
228 | #define LUA_GCSETSTEPMUL 5 | 228 | #define LUA_GCSETPACE 5 |
229 | #define LUA_GCSETINCMODE 6 | 229 | #define LUA_GCSETINCMODE 6 |
230 | 230 | ||
231 | LUA_API int lua_gc (lua_State *L, int what, int data); | 231 | LUA_API int lua_gc (lua_State *L, int what, int data); |