diff options
author | Teo Camarasu <teofilcamarasu@gmail.com> | 2022-07-15 09:47:15 +0100 |
---|---|---|
committer | Marge Bot <ben+marge-bot@smart-cactus.org> | 2022-07-18 16:38:44 -0400 |
commit | 6d8a715e20cf3583f99248383c1b2932d152bf52 (patch) | |
tree | 12b0696b69e76b5297055c3a21cbb0476e70ff24 /rts/sm | |
parent | d1c25a48154236861a413e058ea38d1b8320273f (diff) | |
download | haskell-6d8a715e20cf3583f99248383c1b2932d152bf52.tar.gz |
Allow running memInventory when the concurrent nonmoving gc is enabled
If the nonmoving gc is enabled and we are using a threaded RTS,
we now try to grab the collector mutex to avoid memInventory and
the collection racing.
Before memInventory was disabled.
Diffstat (limited to 'rts/sm')
-rw-r--r-- | rts/sm/NonMoving.h | 1 | ||||
-rw-r--r-- | rts/sm/Sanity.c | 18 |
2 files changed, 14 insertions, 5 deletions
diff --git a/rts/sm/NonMoving.h b/rts/sm/NonMoving.h index 6eabcb8493..17c0a3bec0 100644 --- a/rts/sm/NonMoving.h +++ b/rts/sm/NonMoving.h @@ -104,6 +104,7 @@ extern memcount nonmoving_live_words; #if defined(THREADED_RTS) extern bool concurrent_coll_running; +extern Mutex nonmoving_collection_mutex; #endif void nonmovingInit(void); diff --git a/rts/sm/Sanity.c b/rts/sm/Sanity.c index 9c2ccc2c41..ba381bfc2c 100644 --- a/rts/sm/Sanity.c +++ b/rts/sm/Sanity.c @@ -1190,11 +1190,12 @@ memInventory (bool show) bool leak; #if defined(THREADED_RTS) - // Can't easily do a memory inventory: We might race with the nonmoving - // collector. In principle we could try to take nonmoving_collection_mutex - // and do an inventory if we have it but we don't currently implement this. - if (RtsFlags.GcFlags.useNonmoving) - return; + // We need to be careful not to race with the nonmoving collector. + // If a nonmoving collection is on-going we simply abort the inventory. + if (RtsFlags.GcFlags.useNonmoving){ + if(TRY_ACQUIRE_LOCK(&nonmoving_collection_mutex)) + return; + } #endif // count the blocks we current have @@ -1298,6 +1299,13 @@ memInventory (bool show) } ASSERT(n_alloc_blocks == live_blocks); ASSERT(!leak); + +#if defined(THREADED_RTS) + if (RtsFlags.GcFlags.useNonmoving){ + RELEASE_LOCK(&nonmoving_collection_mutex); + } +#endif + } |