aboutsummaryrefslogtreecommitdiff
path: root/lgc.c
diff options
context:
space:
mode:
Diffstat (limited to 'lgc.c')
-rw-r--r--lgc.c33
1 files changed, 25 insertions, 8 deletions
diff --git a/lgc.c b/lgc.c
index b0e3c363..fb02f015 100644
--- a/lgc.c
+++ b/lgc.c
@@ -1,5 +1,5 @@
1/* 1/*
2** $Id: lgc.c,v 2.253 2018/03/16 14:22:09 roberto Exp roberto $ 2** $Id$
3** Garbage Collector 3** Garbage Collector
4** See Copyright Notice in lua.h 4** See Copyright Notice in lua.h
5*/ 5*/
@@ -12,6 +12,7 @@
12#include <stdio.h> 12#include <stdio.h>
13#include <string.h> 13#include <string.h>
14 14
15
15#include "lua.h" 16#include "lua.h"
16 17
17#include "ldebug.h" 18#include "ldebug.h"
@@ -1004,6 +1005,8 @@ void luaC_checkfinalizer (lua_State *L, GCObject *o, Table *mt) {
1004** ======================================================= 1005** =======================================================
1005*/ 1006*/
1006 1007
1008static void setpause (global_State *g);
1009
1007 1010
1008/* mask to erase all color bits, not changing gen-related stuff */ 1011/* mask to erase all color bits, not changing gen-related stuff */
1009#define maskgencolors (~(bitmask(BLACKBIT) | WHITEBITS)) 1012#define maskgencolors (~(bitmask(BLACKBIT) | WHITEBITS))
@@ -1275,21 +1278,35 @@ static void fullgen (lua_State *L, global_State *g) {
1275** than last major collection (kept in 'g->GCestimate'), does a major 1278** than last major collection (kept in 'g->GCestimate'), does a major
1276** collection. Otherwise, does a minor collection and set debt to make 1279** collection. Otherwise, does a minor collection and set debt to make
1277** another collection when memory grows 'genminormul'% larger. 1280** another collection when memory grows 'genminormul'% larger.
1281** When it does a major collection, it then checks whether it could
1282** reclaim at least ?? memory. If not, it sets a long pause for the
1283** next collection. (Therefore, the next collection will be a major
1284** one, too.)
1278** 'GCdebt <= 0' means an explicit call to GC step with "size" zero; 1285** 'GCdebt <= 0' means an explicit call to GC step with "size" zero;
1279** in that case, always do a minor collection. 1286** in that case, always do a minor collection.
1280*/ 1287*/
1281static void genstep (lua_State *L, global_State *g) { 1288static void genstep (lua_State *L, global_State *g) {
1282 lu_mem majorbase = g->GCestimate; 1289 lu_mem majorbase = g->GCestimate; /* memory after last major collection */
1283 int majormul = getgcparam(g->genmajormul); 1290 lu_mem majorinc = (majorbase / 100) * getgcparam(g->genmajormul);
1284 if (g->GCdebt > 0 && 1291 lu_mem memnew = gettotalbytes(g);
1285 gettotalbytes(g) > (majorbase / 100) * (100 + majormul)) { 1292 if (g->GCdebt > 0 && memnew > majorbase + majorinc) {
1286 fullgen(L, g); 1293 fullgen(L, g);
1294 memnew = gettotalbytes(g);
1295 if (memnew < majorbase + (majorinc / 2)) {
1296 /* collected at least half of memory growth since last major
1297 collection; go back to minor collections */
1298 luaE_setdebt(g, -(cast(l_mem, (memnew / 100)) * g->genminormul));
1299 }
1300 else {
1301 /* memory seems to be growing; do a long wait for next (major)
1302 collection */
1303 setpause(g);
1304 }
1287 } 1305 }
1288 else { 1306 else {
1289 lu_mem mem;
1290 youngcollection(L, g); 1307 youngcollection(L, g);
1291 mem = gettotalbytes(g); 1308 memnew = gettotalbytes(g);
1292 luaE_setdebt(g, -(cast(l_mem, (mem / 100)) * g->genminormul)); 1309 luaE_setdebt(g, -(cast(l_mem, (memnew / 100)) * g->genminormul));
1293 g->GCestimate = majorbase; /* preserve base value */ 1310 g->GCestimate = majorbase; /* preserve base value */
1294 } 1311 }
1295} 1312}