X-Git-Url: http://git.megacz.com/?a=blobdiff_plain;f=rts%2FCapability.c;h=fa7f63069f0b909f758ea18db0beacc207ef08de;hb=6c48b36634d407bffc72a764d302f54da6748824;hp=4950df63bb1b199ff4c15382e854ee2eddf08961;hpb=f86e7206ea94b48b94fb61007a1c5d55b8c60f45;p=ghc-hetmet.git diff --git a/rts/Capability.c b/rts/Capability.c index 4950df6..fa7f630 100644 --- a/rts/Capability.c +++ b/rts/Capability.c @@ -791,10 +791,6 @@ markSomeCapabilities (evac_fn evac, void *user, nat i0, nat delta) "evac'ing suspended TSO %lu", (unsigned long)task->suspended_tso->id); evac(user, (StgClosure **)(void *)&task->suspended_tso); } - -#if defined(THREADED_RTS) - markSparkQueue (evac, user, cap); -#endif } #if !defined(THREADED_RTS) @@ -804,6 +800,34 @@ markSomeCapabilities (evac_fn evac, void *user, nat i0, nat delta) #endif } +// Sparks are not roots for GC, so we don't mark them in +// markSomeCapabilities(). Instead, we traverse the spark queues +// after GC and throw away any that are unreachable. +void +updateCapabilitiesPostGC (void) +{ +#if defined(THREADED_RTS) + nat i; + for (i = 0; i < n_capabilities; i++) { + updateSparkQueue (&capabilities[i]); + } +#endif // THREADED_RTS +} + +// This function is used by the compacting GC to thread all the +// pointers from spark queues. +void +traverseSparkQueues (evac_fn evac USED_IF_THREADS, void *user USED_IF_THREADS) +{ +#if defined(THREADED_RTS) + nat i; + for (i = 0; i < n_capabilities; i++) { + traverseSparkQueue (evac, user, &capabilities[i]); + } +#endif // THREADED_RTS + +} + void markCapabilities (evac_fn evac, void *user) {