summaryrefslogtreecommitdiff
path: root/rts/PrimOps.cmm
diff options
context:
space:
mode:
authorDaniel Gröber <dxld@darkboxed.org>2020-04-12 19:26:12 +0200
committerMarge Bot <ben+marge-bot@smart-cactus.org>2020-04-14 23:31:38 -0400
commit1dd3d18c2afd9e6009cd53295d26f8b31ca58fec (patch)
tree7408777f513e29bbad01d39d51bdf4dd2ce78eaf /rts/PrimOps.cmm
parente149dea9bb89b77d34f50075946d6b4751a974f0 (diff)
downloadhaskell-1dd3d18c2afd9e6009cd53295d26f8b31ca58fec.tar.gz
Remove call to LDV_RECORD_CREATE for array resizing
Diffstat (limited to 'rts/PrimOps.cmm')
-rw-r--r--rts/PrimOps.cmm25
1 files changed, 10 insertions, 15 deletions
diff --git a/rts/PrimOps.cmm b/rts/PrimOps.cmm
index a692517d4e..88354c4ebd 100644
--- a/rts/PrimOps.cmm
+++ b/rts/PrimOps.cmm
@@ -158,17 +158,15 @@ stg_isMutableByteArrayPinnedzh ( gcptr mba )
jump stg_isByteArrayPinnedzh(mba);
}
-/* Note [LDV profiling when resizing arrays]
- * ~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~
+/* Note [LDV profiling and resizing arrays]
+ * ~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~
*
- * When we resize an array, as far as the LDV profiler is concerned, it dies and
- * then is created anew.
+ * As far as the LDV profiler is concerned arrays are "inherently used" which
+ * means we don't track their time of use and eventual destruction. We just
+ * assume they get used.
*
- * The OVERWRITING_CLOSURE_OFS macro handles calling LDV_recordDead() to mark it
- * as dead but in the primops below we still have to call LDV_RECORD_CREATE to
- * inform the profiler of the new array.
- *
- * See also overwritingClosureOfs()
+ * Thus it is not necessary to call LDV_RECORD_CREATE when resizing them as we
+ * used to as the LDV profiler will essentially ignore arrays anyways.
*/
// shrink size of MutableByteArray in-place
@@ -180,8 +178,7 @@ stg_shrinkMutableByteArrayzh ( gcptr mba, W_ new_size )
OVERWRITING_CLOSURE_OFS(mba, (BYTES_TO_WDS(SIZEOF_StgArrBytes) +
ROUNDUP_BYTES_TO_WDS(new_size)));
StgArrBytes_bytes(mba) = new_size;
- // See Note [LDV Profiling when Shrinking Arrays]
- LDV_RECORD_CREATE(mba);
+ // No need to call LDV_RECORD_CREATE. See Note [LDV profiling and resizing arrays]
return ();
}
@@ -205,8 +202,7 @@ stg_resizzeMutableByteArrayzh ( gcptr mba, W_ new_size )
OVERWRITING_CLOSURE_OFS(mba, (BYTES_TO_WDS(SIZEOF_StgArrBytes) +
new_size_wds));
StgArrBytes_bytes(mba) = new_size;
- // See Note [LDV profiling when resizing arrays]
- LDV_RECORD_CREATE(mba);
+ // No need to call LDV_RECORD_CREATE. See Note [LDV profiling and resizing arrays]
return (mba);
} else {
@@ -235,8 +231,7 @@ stg_shrinkSmallMutableArrayzh ( gcptr mba, W_ new_size )
OVERWRITING_CLOSURE_OFS(mba, (BYTES_TO_WDS(SIZEOF_StgSmallMutArrPtrs) +
new_size));
StgSmallMutArrPtrs_ptrs(mba) = new_size;
- // See Note [LDV profiling when resizing arrays]
- LDV_RECORD_CREATE(mba);
+ // No need to call LDV_RECORD_CREATE. See Note [LDV profiling and resizing arrays]
return ();
}