X-Git-Url: http://git.megacz.com/?p=ghc-hetmet.git;a=blobdiff_plain;f=rts%2Fsm%2FStorage.h;h=30bdf54a1d9cc21edf7d63ca5b00d16b904aaa74;hp=5ddcbdcdc2c78d45d3993945cdbbb6dd4c244874;hb=5270423a6afe69f1dc57e5e5a474812182718d40;hpb=063b822bb68f84dd9729327bb1765637c25aceb4 diff --git a/rts/sm/Storage.h b/rts/sm/Storage.h index 5ddcbdc..30bdf54 100644 --- a/rts/sm/Storage.h +++ b/rts/sm/Storage.h @@ -9,6 +9,8 @@ #ifndef SM_STORAGE_H #define SM_STORAGE_H +#include "Capability.h" + BEGIN_RTS_PRIVATE /* ----------------------------------------------------------------------------- @@ -23,12 +25,11 @@ void freeStorage(void); Storage manager state -------------------------------------------------------------------------- */ -extern bdescr * pinned_object_block; - INLINE_HEADER rtsBool -doYouWantToGC( void ) +doYouWantToGC( Capability *cap ) { - return (alloc_blocks >= alloc_blocks_lim); + return (cap->r.rCurrentNursery->link == NULL || + cap->r.rNursery->n_large_blocks >= alloc_blocks_lim); } /* for splitting blocks groups in two */ @@ -120,6 +121,8 @@ void dirty_MVAR(StgRegTable *reg, StgClosure *p); Nursery manipulation -------------------------------------------------------------------------- */ +extern step *nurseries; + void resetNurseries ( void ); void resizeNurseries ( nat blocks ); void resizeNurseriesFixed ( nat blocks );