diff options
author | Ben Gamari <ben@smart-cactus.org> | 2020-03-05 18:42:28 -0500 |
---|---|---|
committer | Ben Gamari <ben@smart-cactus.org> | 2020-04-25 18:48:11 -0400 |
commit | 44f91ef2ccbaf62acd869406cb5e9a26494b3bed (patch) | |
tree | f06032fedaec6ec3a4c34cf520d4398fb808d993 | |
parent | 6d7c1339824c76e79505d6c6f83d439f26a9dee8 (diff) | |
download | haskell-wip/gc/fix-bitmap-clear.tar.gz |
nonmoving: Eagerly flush all capabilities' update remembered setswip/gc/fix-bitmap-clear
(cherry picked from commit 2fa79119570b358a4db61446396889b8260d7957)
-rw-r--r-- | rts/sm/GC.c | 6 |
1 files changed, 4 insertions, 2 deletions
diff --git a/rts/sm/GC.c b/rts/sm/GC.c index 9cf9774687..0fa927f2ad 100644 --- a/rts/sm/GC.c +++ b/rts/sm/GC.c @@ -738,11 +738,13 @@ GarbageCollect (uint32_t collect_gen, } } // for all generations - // Flush the update remembered set. See Note [Eager update remembered set + // Flush the update remembered sets. See Note [Eager update remembered set // flushing] in NonMovingMark.c if (RtsFlags.GcFlags.useNonmoving) { RELEASE_SM_LOCK; - nonmovingAddUpdRemSetBlocks(&gct->cap->upd_rem_set.queue); + for (n = 0; n < n_capabilities; n++) { + nonmovingAddUpdRemSetBlocks(&capabilities[n]->upd_rem_set.queue); + } ACQUIRE_SM_LOCK; } |