diff options
Diffstat (limited to 'ghc/rts/RetainerSet.h')
| -rw-r--r-- | ghc/rts/RetainerSet.h | 67 | 
1 files changed, 64 insertions, 3 deletions
| diff --git a/ghc/rts/RetainerSet.h b/ghc/rts/RetainerSet.h index feed43e74a..5b6a5b2269 100644 --- a/ghc/rts/RetainerSet.h +++ b/ghc/rts/RetainerSet.h @@ -1,5 +1,5 @@  /* ----------------------------------------------------------------------------- - * $Id: RetainerSet.h,v 1.1 2001/11/22 14:25:12 simonmar Exp $ + * $Id: RetainerSet.h,v 1.2 2001/11/26 16:54:21 simonmar Exp $   *   * (c) The GHC Team, 2001   * Author: Sungwoo Park @@ -8,9 +8,70 @@   *   * ---------------------------------------------------------------------------*/ +#ifndef RETAINERSET_H +#define RETAINERSET_H +  #ifdef PROFILING  /* +  Type 'retainer' defines the retainer identity. + +  Invariant: +    1. The retainer identity of a given retainer cannot change during  +    program execution, no matter where it is actually stored. +    For instance, the memory address of a retainer cannot be used as +    its retainer identity because its location may change during garbage +    collections. +    2. Type 'retainer' must come with comparison operations as well as +    an equality operation. That it, <, >, and == must be supported - +    this is necessary to store retainers in a sorted order in retainer sets. +    Therefore, you cannot use a huge structure type as 'retainer', for instance. + +  We illustrate three possibilities of defining 'retainer identity'. +  Choose one of the following three compiler directives: + +   Retainer scheme 1 (RETAINER_SCHEME_INFO) : retainer = info table +   Retainer scheme 2 (RETAINER_SCHEME_CCS)  : retainer = cost centre stack +   Retainer scheme 3 (RETAINER_SCHEME_CC)   : retainer = cost centre +*/ + +// #define RETAINER_SCHEME_INFO +#define RETAINER_SCHEME_CCS +// #define RETAINER_SCHEME_CC + +#ifdef RETAINER_SCHEME_INFO +struct _StgInfoTable; +typedef struct _StgInfoTable *retainer; +#endif + +#ifdef RETAINER_SCHEME_CCS +typedef CostCentreStack *retainer; +#endif + +#ifdef RETAINER_SCHEME_CC +typedef CostCentre *retainer; +#endif + +/* +  Type 'retainerSet' defines an abstract datatype for sets of retainers.   + +  Invariants: +    A retainer set stores its elements in increasing order (in element[] array). + */ + +typedef struct _RetainerSet { +  nat num;                      // number of elements +  StgWord hashKey;              // hash key for this retainer set +  struct _RetainerSet *link;    // link to the next retainer set in the bucket +  int id;   // unique id of this retainer set (used when printing) +            // Its absolute value is interpreted as its true id; if id is +            // negative, it indicates that this retainer set has had a postive +            // cost after some retainer profiling. +  retainer element[0];          // elements of this retainer set +  // do not put anything below here! +} RetainerSet; + +/*    Note:       There are two ways of maintaining all retainer sets. The first is simply by      freeing all the retainer sets and re-initialize the hash table at each @@ -135,5 +196,5 @@ void outputAllRetainerSet(FILE *);  //       the best place to define it.  void printRetainer(FILE *, retainer); -#endif /* PROFILING */ - +#endif // PROFILING +#endif // RETAINERSET_H | 
