small improvement in lua_checkmemory (only allow dead objects in

part of the sweep list not yet sweeped)
This commit is contained in:
Roberto Ierusalimschy 2012-05-31 17:25:42 -03:00
parent 69c775de21
commit 01e5f358bd
1 changed files with 12 additions and 7 deletions

View File

@ -1,5 +1,5 @@
/* /*
** $Id: ltests.c,v 2.127 2012/05/08 13:53:33 roberto Exp roberto $ ** $Id: ltests.c,v 2.128 2012/05/30 16:40:29 roberto Exp $
** Internal Module for Debugging of the Lua Implementation ** Internal Module for Debugging of the Lua Implementation
** See Copyright Notice in lua.h ** See Copyright Notice in lua.h
*/ */
@ -198,7 +198,7 @@ static void printobj (global_State *g, GCObject *o) {
if (p == NULL) i = 0; /* zero means 'not found' */ if (p == NULL) i = 0; /* zero means 'not found' */
else i = -i; /* negative means 'found in findobj list */ else i = -i; /* negative means 'found in findobj list */
} }
printf("%d:%s(%p)-%c(%02X)", i, ttypename(gch(o)->tt), (void *)o, printf("||%d:%s(%p)-%c(%02X)||", i, ttypename(gch(o)->tt), (void *)o,
isdead(g,o)?'d':isblack(o)?'b':iswhite(o)?'w':'g', gch(o)->marked); isdead(g,o)?'d':isblack(o)?'b':iswhite(o)?'w':'g', gch(o)->marked);
} }
@ -325,9 +325,9 @@ static void checkstack (global_State *g, lua_State *L1) {
} }
static void checkobject (global_State *g, GCObject *o) { static void checkobject (global_State *g, GCObject *o, int maybedead) {
if (isdead(g, o)) if (isdead(g, o))
lua_assert(issweepphase(g)); lua_assert(maybedead);
else { else {
if (g->gcstate == GCSpause && !isgenerational(g)) if (g->gcstate == GCSpause && !isgenerational(g))
lua_assert(iswhite(o)); lua_assert(iswhite(o));
@ -427,6 +427,7 @@ int lua_checkmemory (lua_State *L) {
global_State *g = G(L); global_State *g = G(L);
GCObject *o; GCObject *o;
UpVal *uv; UpVal *uv;
int maybedead;
if (keepinvariant(g)) { if (keepinvariant(g)) {
lua_assert(!iswhite(obj2gco(g->mainthread))); lua_assert(!iswhite(obj2gco(g->mainthread)));
lua_assert(!iswhite(gcvalue(&g->l_registry))); lua_assert(!iswhite(gcvalue(&g->l_registry)));
@ -437,17 +438,21 @@ int lua_checkmemory (lua_State *L) {
/* check 'allgc' list */ /* check 'allgc' list */
markgrays(g); markgrays(g);
checkold(g, g->allgc); checkold(g, g->allgc);
lua_assert(g->sweepgc == NULL || issweepphase(g));
maybedead = 0;
for (o = g->allgc; o != NULL; o = gch(o)->next) { for (o = g->allgc; o != NULL; o = gch(o)->next) {
checkobject(g, o); if (g->sweepgc && o == *g->sweepgc)
maybedead = 1; /* part of the list not yet sweeped */
checkobject(g, o, maybedead);
lua_assert(!testbit(o->gch.marked, SEPARATED)); lua_assert(!testbit(o->gch.marked, SEPARATED));
} }
/* check 'finobj' list */ /* check 'finobj' list */
checkold(g, g->finobj); checkold(g, g->finobj);
for (o = g->finobj; o != NULL; o = gch(o)->next) { for (o = g->finobj; o != NULL; o = gch(o)->next) {
lua_assert(!isdead(g, o) && testbit(o->gch.marked, SEPARATED)); lua_assert(testbit(o->gch.marked, SEPARATED));
lua_assert(gch(o)->tt == LUA_TUSERDATA || lua_assert(gch(o)->tt == LUA_TUSERDATA ||
gch(o)->tt == LUA_TTABLE); gch(o)->tt == LUA_TTABLE);
checkobject(g, o); checkobject(g, o, 0);
} }
/* check 'tobefnz' list */ /* check 'tobefnz' list */
checkold(g, g->tobefnz); checkold(g, g->tobefnz);