diff options
author | simonmar@microsoft.com <unknown> | 2007-12-13 16:50:13 +0000 |
---|---|---|
committer | simonmar@microsoft.com <unknown> | 2007-12-13 16:50:13 +0000 |
commit | 313734473b419f55ee39d2df442f93a49b709aa4 (patch) | |
tree | d828da8240fe20fd69d5a934fae101415a5096c0 /rts/Sparks.c | |
parent | eea6454f0bcbec6c6612e963cd85702c475ef146 (diff) | |
download | haskell-313734473b419f55ee39d2df442f93a49b709aa4.tar.gz |
have each GC thread call GetRoots()
Diffstat (limited to 'rts/Sparks.c')
-rw-r--r-- | rts/Sparks.c | 89 |
1 files changed, 43 insertions, 46 deletions
diff --git a/rts/Sparks.c b/rts/Sparks.c index 0ff4ee4cce..2ebe5f66f1 100644 --- a/rts/Sparks.c +++ b/rts/Sparks.c @@ -108,68 +108,65 @@ findSpark (Capability *cap) * -------------------------------------------------------------------------- */ void -markSparkQueue (evac_fn evac) +markSparkQueue (evac_fn evac, Capability *cap) { StgClosure **sparkp, **to_sparkp; - nat i, n, pruned_sparks; // stats only + nat n, pruned_sparks; // stats only StgSparkPool *pool; - Capability *cap; PAR_TICKY_MARK_SPARK_QUEUE_START(); n = 0; pruned_sparks = 0; - for (i = 0; i < n_capabilities; i++) { - cap = &capabilities[i]; - pool = &(cap->r.rSparks); - - ASSERT_SPARK_POOL_INVARIANTS(pool); - + + pool = &(cap->r.rSparks); + + ASSERT_SPARK_POOL_INVARIANTS(pool); + #if defined(PARALLEL_HASKELL) - // stats only - n = 0; - pruned_sparks = 0; + // stats only + n = 0; + pruned_sparks = 0; #endif - sparkp = pool->hd; - to_sparkp = pool->hd; - while (sparkp != pool->tl) { - ASSERT(*sparkp!=NULL); - ASSERT(LOOKS_LIKE_CLOSURE_PTR(((StgClosure *)*sparkp))); - // ToDo?: statistics gathering here (also for GUM!) - if (closure_SHOULD_SPARK(*sparkp)) { - evac(sparkp); - *to_sparkp++ = *sparkp; - if (to_sparkp == pool->lim) { - to_sparkp = pool->base; - } - n++; - } else { - pruned_sparks++; - } - sparkp++; - if (sparkp == pool->lim) { - sparkp = pool->base; - } - } - pool->tl = to_sparkp; + sparkp = pool->hd; + to_sparkp = pool->hd; + while (sparkp != pool->tl) { + ASSERT(*sparkp!=NULL); + ASSERT(LOOKS_LIKE_CLOSURE_PTR(((StgClosure *)*sparkp))); + // ToDo?: statistics gathering here (also for GUM!) + if (closure_SHOULD_SPARK(*sparkp)) { + evac(sparkp); + *to_sparkp++ = *sparkp; + if (to_sparkp == pool->lim) { + to_sparkp = pool->base; + } + n++; + } else { + pruned_sparks++; + } + sparkp++; + if (sparkp == pool->lim) { + sparkp = pool->base; + } + } + pool->tl = to_sparkp; - PAR_TICKY_MARK_SPARK_QUEUE_END(n); + PAR_TICKY_MARK_SPARK_QUEUE_END(n); #if defined(PARALLEL_HASKELL) - debugTrace(DEBUG_sched, - "marked %d sparks and pruned %d sparks on [%x]", - n, pruned_sparks, mytid); + debugTrace(DEBUG_sched, + "marked %d sparks and pruned %d sparks on [%x]", + n, pruned_sparks, mytid); #else - debugTrace(DEBUG_sched, - "marked %d sparks and pruned %d sparks", - n, pruned_sparks); + debugTrace(DEBUG_sched, + "marked %d sparks and pruned %d sparks", + n, pruned_sparks); #endif - - debugTrace(DEBUG_sched, - "new spark queue len=%d; (hd=%p; tl=%p)\n", - sparkPoolSize(pool), pool->hd, pool->tl); - } + + debugTrace(DEBUG_sched, + "new spark queue len=%d; (hd=%p; tl=%p)\n", + sparkPoolSize(pool), pool->hd, pool->tl); } /* ----------------------------------------------------------------------------- |