summaryrefslogtreecommitdiff
path: root/rts
diff options
context:
space:
mode:
authorSimon Marlow <marlowsd@gmail.com>2012-11-05 16:06:24 +0000
committerSimon Marlow <marlowsd@gmail.com>2012-11-12 15:49:43 +0000
commit1c160e588706f4ff6b4e391602e38f0a2044ec13 (patch)
tree992ad0f7ba25f2d3fe8ca3b88699b4139872ed14 /rts
parent2ef95e8fe0df15eb182a480b2d221a827f36ee96 (diff)
downloadhaskell-1c160e588706f4ff6b4e391602e38f0a2044ec13.tar.gz
ASSERT(HpAlloc==0) in the update code, to catch HpAlloc bugs
Diffstat (limited to 'rts')
-rw-r--r--rts/Updates.cmm16
1 files changed, 15 insertions, 1 deletions
diff --git a/rts/Updates.cmm b/rts/Updates.cmm
index 53b2cbaa61..b3b6b20ef3 100644
--- a/rts/Updates.cmm
+++ b/rts/Updates.cmm
@@ -29,6 +29,8 @@ INFO_TABLE_RET ( stg_upd_frame, UPDATE_FRAME,
UPDATE_FRAME_FIELDS(W_,P_,info_ptr,_ccs,_unused,updatee) )
return (P_ ret) /* the closure being returned */
{
+ ASSERT(HpAlloc == 0); // Note [HpAlloc]
+
/* ToDo: it might be a PAP, so we should check... */
TICK_UPD_CON_IN_NEW(sizeW_fromITBL(%GET_STD_INFO(updatee)));
@@ -47,7 +49,7 @@ INFO_TABLE_RET ( stg_marked_upd_frame, UPDATE_FRAME,
{
W_ v;
- if (HpAlloc != 0) { ccall barf("HpAlloc"); }
+ ASSERT(HpAlloc == 0); // Note [HpAlloc]
// we know the closure is a BLACKHOLE
v = StgInd_indirectee(updatee);
@@ -87,3 +89,15 @@ INFO_TABLE_RET ( stg_bh_upd_frame, UPDATE_FRAME,
( UPDATE_FRAME_FIELDS(,,info_ptr,ccs,_unused,updatee) )
(ret);
}
+
+/* Note [HpAlloc]
+ *
+ * HpAlloc is required to be zero unless we just bumped Hp and failed
+ * the heap check: see HeapStackCheck.cmm. Failures that result from
+ * HpAlloc being non-zero are very hard to track down, because they
+ * manifest as spurious heap corruption that happens only with +RTS
+ * -N2 or greater (because then we have a lot more
+ * interruptCapability() calls happening). Hence, we assert
+ * HpAlloc==0 as often as possible, and in the update code is a good
+ * place to do that.
+ */