X-Git-Url: http://git.megacz.com/?a=blobdiff_plain;f=ghc%2Frts%2FGCCompact.h;h=4de4bf32934ec9ecb9d88826a4aa44dd09864921;hb=5ac854ef908d3f93164bad991b18944fc3a9db35;hp=8244e87c4544bd66f4ae6ac6d8c9acc74a9d3b35;hpb=dfd7d6d02a597949b08161ae3d49dc6dfc9e812d;p=ghc-hetmet.git diff --git a/ghc/rts/GCCompact.h b/ghc/rts/GCCompact.h index 8244e87..4de4bf3 100644 --- a/ghc/rts/GCCompact.h +++ b/ghc/rts/GCCompact.h @@ -1,5 +1,5 @@ /* ----------------------------------------------------------------------------- - * $Id: GCCompact.h,v 1.1 2001/07/23 17:23:19 simonmar Exp $ + * $Id: GCCompact.h,v 1.2 2001/07/30 13:06:18 simonmar Exp $ * * (c) The GHC Team 1998-1999 * @@ -17,6 +17,16 @@ mark(StgPtr p, bdescr *bd) *bitmap_word |= bit_mask; } +static inline void +unmark(StgPtr p, bdescr *bd) +{ + nat offset_within_block = p - bd->start; // in words + StgPtr bitmap_word = (StgPtr)bd->u.bitmap + + (offset_within_block / (sizeof(W_)*BITS_PER_BYTE)); + nat bit_mask = 1 << (offset_within_block & (sizeof(W_)*BITS_PER_BYTE - 1)); + *bitmap_word &= ~bit_mask; +} + static inline int is_marked(StgPtr p, bdescr *bd) {