summaryrefslogtreecommitdiff
path: root/rts
diff options
context:
space:
mode:
authorSimon Marlow <simonmar@microsoft.com>2006-06-29 12:05:26 +0000
committerSimon Marlow <simonmar@microsoft.com>2006-06-29 12:05:26 +0000
commitb19bcfd953fdb10059753c1270ac1e4631da0f53 (patch)
tree94b058e349cbb770b64a59314cdf0d69252b11e6 /rts
parent47f809644d5ccba8be7a27a9d8ebbb818cac33ef (diff)
downloadhaskell-b19bcfd953fdb10059753c1270ac1e4631da0f53.tar.gz
use the new "prim %write_barrier()" in .cmm instead of calls to wb()
Diffstat (limited to 'rts')
-rw-r--r--rts/RaiseAsync.c4
-rw-r--r--rts/Updates.h46
2 files changed, 25 insertions, 25 deletions
diff --git a/rts/RaiseAsync.c b/rts/RaiseAsync.c
index b0c7064540..f9ec31884c 100644
--- a/rts/RaiseAsync.c
+++ b/rts/RaiseAsync.c
@@ -240,7 +240,7 @@ check_target:
{
Capability *target_cap;
- wb();
+ write_barrier();
target_cap = target->cap;
if (target_cap == cap && (target->flags & TSO_BLOCKEX) == 0) {
// It's on our run queue and not blocking exceptions
@@ -464,7 +464,7 @@ blockedThrowTo (StgTSO *source, StgTSO *target)
dirtyTSO(target); // we modified the blocked_exceptions queue
source->block_info.tso = target;
- wb(); // throwTo_exception *must* be visible if BlockedOnException is.
+ write_barrier(); // throwTo_exception *must* be visible if BlockedOnException is.
source->why_blocked = BlockedOnException;
}
diff --git a/rts/Updates.h b/rts/Updates.h
index f20b088432..c8c75b130e 100644
--- a/rts/Updates.h
+++ b/rts/Updates.h
@@ -277,7 +277,7 @@ FILL_SLOP(StgClosure *p)
DEBUG_FILL_SLOP(p1); \
LDV_RECORD_DEAD_FILL_SLOP_DYNAMIC(p1); \
StgInd_indirectee(p1) = p2; \
- foreign "C" wb() []; \
+ prim %write_barrier() []; \
bd = Bdescr(p1); \
if (bdescr_gen_no(bd) != 0 :: CInt) { \
foreign "C" recordMutableCap(p1 "ptr", \
@@ -294,28 +294,28 @@ FILL_SLOP(StgClosure *p)
and_then; \
}
#else
-#define updateWithIndirection(ind_info, p1, p2, and_then) \
- { \
- bdescr *bd; \
- \
- /* cas(p1, 0, &stg_WHITEHOLE_info); */ \
- ASSERT( (P_)p1 != (P_)p2 && !closure_IND(p1) ); \
- DEBUG_FILL_SLOP(p1); \
- LDV_RECORD_DEAD_FILL_SLOP_DYNAMIC(p1); \
- ((StgInd *)p1)->indirectee = p2; \
- wb(); \
- bd = Bdescr((P_)p1); \
- if (bd->gen_no != 0) { \
- recordMutableGenLock(p1, &generations[bd->gen_no]); \
- SET_INFO(p1, &stg_IND_OLDGEN_info); \
- TICK_UPD_OLD_IND(); \
- and_then; \
- } else { \
- SET_INFO(p1, ind_info); \
- LDV_RECORD_CREATE(p1); \
- TICK_UPD_NEW_IND(); \
- and_then; \
- } \
+#define updateWithIndirection(ind_info, p1, p2, and_then) \
+ { \
+ bdescr *bd; \
+ \
+ /* cas(p1, 0, &stg_WHITEHOLE_info); */ \
+ ASSERT( (P_)p1 != (P_)p2 && !closure_IND(p1) ); \
+ DEBUG_FILL_SLOP(p1); \
+ LDV_RECORD_DEAD_FILL_SLOP_DYNAMIC(p1); \
+ ((StgInd *)p1)->indirectee = p2; \
+ write_barrier(); \
+ bd = Bdescr((P_)p1); \
+ if (bd->gen_no != 0) { \
+ recordMutableGenLock(p1, &generations[bd->gen_no]); \
+ SET_INFO(p1, &stg_IND_OLDGEN_info); \
+ TICK_UPD_OLD_IND(); \
+ and_then; \
+ } else { \
+ SET_INFO(p1, ind_info); \
+ LDV_RECORD_CREATE(p1); \
+ TICK_UPD_NEW_IND(); \
+ and_then; \
+ } \
}
#endif