Suspect all native wrappers during cycle collection (last part, rest already done by Graydon). b=368869 r=graydon sr=jst

This commit is contained in:
dbaron@dbaron.org 2007-06-29 20:03:30 -07:00
Родитель 58244a5a41
Коммит a29935ee62
3 изменённых файлов: 36 добавлений и 9 удалений

Просмотреть файл

@ -573,6 +573,8 @@ nsXPConnect::BeginCycleCollection()
JS_SetGCCallback(cx, gOldJSGCCallback);
gOldJSGCCallback = nsnull;
XPCWrappedNativeScope::SuspectAllWrappers(mRuntime);
#ifndef XPCONNECT_STANDALONE
NS_ASSERTION(mObjRefcounts->mScopes.Count() == 0, "Didn't clear mScopes?");
XPCWrappedNativeScope::TraverseScopes(*mCycleCollectionContext);

Просмотреть файл

@ -1135,6 +1135,9 @@ public:
static void
TraceJS(JSTracer* trc, XPCJSRuntime* rt);
static void
SuspectAllWrappers(XPCJSRuntime* rt);
static void
FinishedMarkPhaseOfGC(JSContext* cx, XPCJSRuntime* rt);

Просмотреть файл

@ -271,15 +271,8 @@ WrappedNativeJSGCThingTracer(JSDHashTable *table, JSDHashEntryHdr *hdr,
JSTracer* trc = (JSTracer *)arg;
JS_CALL_OBJECT_TRACER(trc, wrapper->GetFlatJSObject(),
"XPCWrappedNative::mFlatJSObject");
// FIXME: this call appears to do more harm than good, but
// there is reason to imagine it might clean up some cycles
// formed by a poor order between C++ and JS garbage cycle
// formations. See Bug 368869.
//
// if (JS_IsGCMarkingTracer(trc))
// nsCycleCollector_suspectCurrent(wrapper);
}
return JS_DHASH_NEXT;
}
@ -291,13 +284,42 @@ XPCWrappedNativeScope::TraceJS(JSTracer* trc, XPCJSRuntime* rt)
// access to JS runtime. See bug 380139.
XPCAutoLock lock(rt->GetMapLock());
// Do JS_CallTracer for all wrapperednatives with external references.
// Do JS_CallTracer for all wrapped natives with external references.
for(XPCWrappedNativeScope* cur = gScopes; cur; cur = cur->mNext)
{
cur->mWrappedNativeMap->Enumerate(WrappedNativeJSGCThingTracer, trc);
}
}
JS_STATIC_DLL_CALLBACK(JSDHashOperator)
WrappedNativeSuspecter(JSDHashTable *table, JSDHashEntryHdr *hdr,
uint32 number, void *arg)
{
XPCWrappedNative* wrapper = ((Native2WrappedNativeMap::Entry*)hdr)->value;
XPCWrappedNativeProto* proto = wrapper->GetProto();
if(proto && proto->ClassIsMainThreadOnly())
{
NS_ASSERTION(NS_IsMainThread(),
"Suspecting wrapped natives from non-main thread");
nsCycleCollector_suspectCurrent(wrapper);
}
return JS_DHASH_NEXT;
}
// static
void
XPCWrappedNativeScope::SuspectAllWrappers(XPCJSRuntime* rt)
{
XPCAutoLock lock(rt->GetMapLock());
// Do nsCycleCollector_suspectCurrent for all wrapped natives.
for(XPCWrappedNativeScope* cur = gScopes; cur; cur = cur->mNext)
{
cur->mWrappedNativeMap->Enumerate(WrappedNativeSuspecter, nsnull);
}
}
// static
void
XPCWrappedNativeScope::FinishedMarkPhaseOfGC(JSContext* cx, XPCJSRuntime* rt)