diff options
author | Simon Marlow <simonmarhaskell@gmail.com> | 2008-04-24 20:58:13 +0000 |
---|---|---|
committer | Simon Marlow <simonmarhaskell@gmail.com> | 2008-04-24 20:58:13 +0000 |
commit | 01ccdeea34b4853750326126f3bff9b2bdfa9a32 (patch) | |
tree | 386283d5e2e14a9e2396fe854b5950abb8883b9f /rts/Capability.c | |
parent | 1d0e86e6cd96ce49f478c91fc01de565416ecc22 (diff) | |
download | haskell-01ccdeea34b4853750326126f3bff9b2bdfa9a32.tar.gz |
FIX #2185: sparks should not be treated as roots by the GC
Diffstat (limited to 'rts/Capability.c')
-rw-r--r-- | rts/Capability.c | 32 |
1 files changed, 28 insertions, 4 deletions
diff --git a/rts/Capability.c b/rts/Capability.c index 4950df63bb..fa7f63069f 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) { |