ghc-heap-8.10.7: Functions for walking GHC's heap
Copyright (c) 2012 Joachim Breitner
License BSD3
Maintainer Joachim Breitner <mail@joachim-breitner.de>
Safe Haskell None
Language Haskell2010

GHC.Exts.Heap

Description

With this module, you can investigate the heap representation of Haskell values, i.e. to investigate sharing and lazy evaluation.

Synopsis

Closure types

data GenClosure b Source #

This is the representation of a Haskell value on the heap. It reflects https://gitlab.haskell.org/ghc/ghc/blob/master/includes/rts/storage/Closures.h

The data type is parametrized by the type to store references in. Usually this is a Box with the type synonym Closure .

All Heap objects have the same basic layout. A header containing a pointer to the info table and a payload with various fields. The info field below always refers to the info table pointed to by the header. The remaining fields are the payload.

See https://gitlab.haskell.org/ghc/ghc/wikis/commentary/rts/storage/heap-objects for more information.

Constructors

ConstrClosure

A data constructor

Fields

FunClosure

A function

Fields

ThunkClosure

A thunk, an expression not obviously in head normal form

Fields

SelectorClosure

A thunk which performs a simple selection operation

Fields

PAPClosure

An unsaturated function application

Fields

APClosure

A function application

Fields

APStackClosure

A suspended thunk evaluation

Fields

IndClosure

A pointer to another closure, introduced when a thunk is updated to point at its value

Fields

BCOClosure

A byte-code object (BCO) which can be interpreted by GHC's byte-code interpreter (e.g. as used by GHCi)

Fields

BlackholeClosure

A thunk under evaluation by another thread

Fields

ArrWordsClosure

A ByteArray#

Fields

MutArrClosure

A MutableByteArray#

Fields

SmallMutArrClosure

A SmallMutableArray#

Since: 8.10.1

Fields

MVarClosure

An MVar# , with a queue of thread state objects blocking on them

Fields

MutVarClosure

A MutVar#

Fields

BlockingQueueClosure

An STM blocking queue.

Fields

WeakClosure

Fields

IntClosure

Primitive Int

WordClosure

Primitive Word

Int64Closure

Primitive Int64

Word64Closure

Primitive Word64

AddrClosure

Primitive Addr

FloatClosure

Primitive Float

DoubleClosure

Primitive Double

OtherClosure

Another kind of closure

UnsupportedClosure

Instances

Instances details
Functor GenClosure Source #
Instance details

Defined in GHC.Exts.Heap.Closures

Foldable GenClosure Source #
Instance details

Defined in GHC.Exts.Heap.Closures

Traversable GenClosure Source #
Instance details

Defined in GHC.Exts.Heap.Closures

Show b => Show ( GenClosure b) Source #
Instance details

Defined in GHC.Exts.Heap.Closures

Generic ( GenClosure b) Source #
Instance details

Defined in GHC.Exts.Heap.Closures

Associated Types

type Rep ( GenClosure b) :: Type -> Type Source #

type Rep ( GenClosure b) Source #
Instance details

Defined in GHC.Exts.Heap.Closures

type Rep ( GenClosure b) = D1 (' MetaData "GenClosure" "GHC.Exts.Heap.Closures" "ghc-heap-8.10.7-IUP7BK823zx9GcxXynNXv1" ' False ) (((( C1 (' MetaCons "ConstrClosure" ' PrefixI ' True ) (( S1 (' MetaSel (' Just "info") ' NoSourceUnpackedness ' SourceStrict ' DecidedStrict ) ( Rec0 StgInfoTable ) :*: ( S1 (' MetaSel (' Just "ptrArgs") ' NoSourceUnpackedness ' SourceStrict ' DecidedStrict ) ( Rec0 [b]) :*: S1 (' MetaSel (' Just "dataArgs") ' NoSourceUnpackedness ' SourceStrict ' DecidedStrict ) ( Rec0 [ Word ]))) :*: ( S1 (' MetaSel (' Just "pkg") ' NoSourceUnpackedness ' SourceStrict ' DecidedStrict ) ( Rec0 String ) :*: ( S1 (' MetaSel (' Just "modl") ' NoSourceUnpackedness ' SourceStrict ' DecidedStrict ) ( Rec0 String ) :*: S1 (' MetaSel (' Just "name") ' NoSourceUnpackedness ' SourceStrict ' DecidedStrict ) ( Rec0 String )))) :+: ( C1 (' MetaCons "FunClosure" ' PrefixI ' True ) ( S1 (' MetaSel (' Just "info") ' NoSourceUnpackedness ' SourceStrict ' DecidedStrict ) ( Rec0 StgInfoTable ) :*: ( S1 (' MetaSel (' Just "ptrArgs") ' NoSourceUnpackedness ' SourceStrict ' DecidedStrict ) ( Rec0 [b]) :*: S1 (' MetaSel (' Just "dataArgs") ' NoSourceUnpackedness ' SourceStrict ' DecidedStrict ) ( Rec0 [ Word ]))) :+: C1 (' MetaCons "ThunkClosure" ' PrefixI ' True ) ( S1 (' MetaSel (' Just "info") ' NoSourceUnpackedness ' SourceStrict ' DecidedStrict ) ( Rec0 StgInfoTable ) :*: ( S1 (' MetaSel (' Just "ptrArgs") ' NoSourceUnpackedness ' SourceStrict ' DecidedStrict ) ( Rec0 [b]) :*: S1 (' MetaSel (' Just "dataArgs") ' NoSourceUnpackedness ' SourceStrict ' DecidedStrict ) ( Rec0 [ Word ]))))) :+: ( C1 (' MetaCons "SelectorClosure" ' PrefixI ' True ) ( S1 (' MetaSel (' Just "info") ' NoSourceUnpackedness ' SourceStrict ' DecidedStrict ) ( Rec0 StgInfoTable ) :*: S1 (' MetaSel (' Just "selectee") ' NoSourceUnpackedness ' SourceStrict ' DecidedStrict ) ( Rec0 b)) :+: ( C1 (' MetaCons "PAPClosure" ' PrefixI ' True ) (( S1 (' MetaSel (' Just "info") ' NoSourceUnpackedness ' SourceStrict ' DecidedStrict ) ( Rec0 StgInfoTable ) :*: S1 (' MetaSel (' Just "arity") ' NoSourceUnpackedness ' SourceStrict ' DecidedStrict ) ( Rec0 HalfWord )) :*: ( S1 (' MetaSel (' Just "n_args") ' NoSourceUnpackedness ' SourceStrict ' DecidedStrict ) ( Rec0 HalfWord ) :*: ( S1 (' MetaSel (' Just "fun") ' NoSourceUnpackedness ' SourceStrict ' DecidedStrict ) ( Rec0 b) :*: S1 (' MetaSel (' Just "payload") ' NoSourceUnpackedness ' SourceStrict ' DecidedStrict ) ( Rec0 [b])))) :+: C1 (' MetaCons "APClosure" ' PrefixI ' True ) (( S1 (' MetaSel (' Just "info") ' NoSourceUnpackedness ' SourceStrict ' DecidedStrict ) ( Rec0 StgInfoTable ) :*: S1 (' MetaSel (' Just "arity") ' NoSourceUnpackedness ' SourceStrict ' DecidedStrict ) ( Rec0 HalfWord )) :*: ( S1 (' MetaSel (' Just "n_args") ' NoSourceUnpackedness ' SourceStrict ' DecidedStrict ) ( Rec0 HalfWord ) :*: ( S1 (' MetaSel (' Just "fun") ' NoSourceUnpackedness ' SourceStrict ' DecidedStrict ) ( Rec0 b) :*: S1 (' MetaSel (' Just "payload") ' NoSourceUnpackedness ' SourceStrict ' DecidedStrict ) ( Rec0 [b]))))))) :+: (( C1 (' MetaCons "APStackClosure" ' PrefixI ' True ) ( S1 (' MetaSel (' Just "info") ' NoSourceUnpackedness ' SourceStrict ' DecidedStrict ) ( Rec0 StgInfoTable ) :*: ( S1 (' MetaSel (' Just "fun") ' NoSourceUnpackedness ' SourceStrict ' DecidedStrict ) ( Rec0 b) :*: S1 (' MetaSel (' Just "payload") ' NoSourceUnpackedness ' SourceStrict ' DecidedStrict ) ( Rec0 [b]))) :+: ( C1 (' MetaCons "IndClosure" ' PrefixI ' True ) ( S1 (' MetaSel (' Just "info") ' NoSourceUnpackedness ' SourceStrict ' DecidedStrict ) ( Rec0 StgInfoTable ) :*: S1 (' MetaSel (' Just "indirectee") ' NoSourceUnpackedness ' SourceStrict ' DecidedStrict ) ( Rec0 b)) :+: C1 (' MetaCons "BCOClosure" ' PrefixI ' True ) (( S1 (' MetaSel (' Just "info") ' NoSourceUnpackedness ' SourceStrict ' DecidedStrict ) ( Rec0 StgInfoTable ) :*: ( S1 (' MetaSel (' Just "instrs") ' NoSourceUnpackedness ' SourceStrict ' DecidedStrict ) ( Rec0 b) :*: S1 (' MetaSel (' Just "literals") ' NoSourceUnpackedness ' SourceStrict ' DecidedStrict ) ( Rec0 b))) :*: (( S1 (' MetaSel (' Just "bcoptrs") ' NoSourceUnpackedness ' SourceStrict ' DecidedStrict ) ( Rec0 b) :*: S1 (' MetaSel (' Just "arity") ' NoSourceUnpackedness ' SourceStrict ' DecidedStrict ) ( Rec0 HalfWord )) :*: ( S1 (' MetaSel (' Just "size") ' NoSourceUnpackedness ' SourceStrict ' DecidedStrict ) ( Rec0 HalfWord ) :*: S1 (' MetaSel (' Just "bitmap") ' NoSourceUnpackedness ' SourceStrict ' DecidedStrict ) ( Rec0 [ Word ])))))) :+: (( C1 (' MetaCons "BlackholeClosure" ' PrefixI ' True ) ( S1 (' MetaSel (' Just "info") ' NoSourceUnpackedness ' SourceStrict ' DecidedStrict ) ( Rec0 StgInfoTable ) :*: S1 (' MetaSel (' Just "indirectee") ' NoSourceUnpackedness ' SourceStrict ' DecidedStrict ) ( Rec0 b)) :+: C1 (' MetaCons "ArrWordsClosure" ' PrefixI ' True ) ( S1 (' MetaSel (' Just "info") ' NoSourceUnpackedness ' SourceStrict ' DecidedStrict ) ( Rec0 StgInfoTable ) :*: ( S1 (' MetaSel (' Just "bytes") ' NoSourceUnpackedness ' SourceStrict ' DecidedStrict ) ( Rec0 Word ) :*: S1 (' MetaSel (' Just "arrWords") ' NoSourceUnpackedness ' SourceStrict ' DecidedStrict ) ( Rec0 [ Word ])))) :+: ( C1 (' MetaCons "MutArrClosure" ' PrefixI ' True ) (( S1 (' MetaSel (' Just "info") ' NoSourceUnpackedness ' SourceStrict ' DecidedStrict ) ( Rec0 StgInfoTable ) :*: S1 (' MetaSel (' Just "mccPtrs") ' NoSourceUnpackedness ' SourceStrict ' DecidedStrict ) ( Rec0 Word )) :*: ( S1 (' MetaSel (' Just "mccSize") ' NoSourceUnpackedness ' SourceStrict ' DecidedStrict ) ( Rec0 Word ) :*: S1 (' MetaSel (' Just "mccPayload") ' NoSourceUnpackedness ' SourceStrict ' DecidedStrict ) ( Rec0 [b]))) :+: C1 (' MetaCons "SmallMutArrClosure" ' PrefixI ' True ) ( S1 (' MetaSel (' Just "info") ' NoSourceUnpackedness ' SourceStrict ' DecidedStrict ) ( Rec0 StgInfoTable ) :*: ( S1 (' MetaSel (' Just "mccPtrs") ' NoSourceUnpackedness ' SourceStrict ' DecidedStrict ) ( Rec0 Word ) :*: S1 (' MetaSel (' Just "mccPayload") ' NoSourceUnpackedness ' SourceStrict ' DecidedStrict ) ( Rec0 [b]))))))) :+: ((( C1 (' MetaCons "MVarClosure" ' PrefixI ' True ) (( S1 (' MetaSel (' Just "info") ' NoSourceUnpackedness ' SourceStrict ' DecidedStrict ) ( Rec0 StgInfoTable ) :*: S1 (' MetaSel (' Just "queueHead") ' NoSourceUnpackedness ' SourceStrict ' DecidedStrict ) ( Rec0 b)) :*: ( S1 (' MetaSel (' Just "queueTail") ' NoSourceUnpackedness ' SourceStrict ' DecidedStrict ) ( Rec0 b) :*: S1 (' MetaSel (' Just "value") ' NoSourceUnpackedness ' SourceStrict ' DecidedStrict ) ( Rec0 b))) :+: ( C1 (' MetaCons "MutVarClosure" ' PrefixI ' True ) ( S1 (' MetaSel (' Just "info") ' NoSourceUnpackedness ' SourceStrict ' DecidedStrict ) ( Rec0 StgInfoTable ) :*: S1 (' MetaSel (' Just "var") ' NoSourceUnpackedness ' SourceStrict ' DecidedStrict ) ( Rec0 b)) :+: C1 (' MetaCons "BlockingQueueClosure" ' PrefixI ' True ) (( S1 (' MetaSel (' Just "info") ' NoSourceUnpackedness ' SourceStrict ' DecidedStrict ) ( Rec0 StgInfoTable ) :*: S1 (' MetaSel (' Just "link") ' NoSourceUnpackedness ' SourceStrict ' DecidedStrict ) ( Rec0 b)) :*: ( S1 (' MetaSel (' Just "blackHole") ' NoSourceUnpackedness ' SourceStrict ' DecidedStrict ) ( Rec0 b) :*: ( S1 (' MetaSel (' Just "owner") ' NoSourceUnpackedness ' SourceStrict ' DecidedStrict ) ( Rec0 b) :*: S1 (' MetaSel (' Just "queue") ' NoSourceUnpackedness ' SourceStrict ' DecidedStrict ) ( Rec0 b)))))) :+: ( C1 (' MetaCons "WeakClosure" ' PrefixI ' True ) (( S1 (' MetaSel (' Just "info") ' NoSourceUnpackedness ' SourceStrict ' DecidedStrict ) ( Rec0 StgInfoTable ) :*: ( S1 (' MetaSel (' Just "cfinalizers") ' NoSourceUnpackedness ' SourceStrict ' DecidedStrict ) ( Rec0 b) :*: S1 (' MetaSel (' Just "key") ' NoSourceUnpackedness ' SourceStrict ' DecidedStrict ) ( Rec0 b))) :*: ( S1 (' MetaSel (' Just "value") ' NoSourceUnpackedness ' SourceStrict ' DecidedStrict ) ( Rec0 b) :*: ( S1 (' MetaSel (' Just "finalizer") ' NoSourceUnpackedness ' SourceStrict ' DecidedStrict ) ( Rec0 b) :*: S1 (' MetaSel (' Just "link") ' NoSourceUnpackedness ' SourceStrict ' DecidedStrict ) ( Rec0 b)))) :+: ( C1 (' MetaCons "IntClosure" ' PrefixI ' True ) ( S1 (' MetaSel (' Just "ptipe") ' NoSourceUnpackedness ' NoSourceStrictness ' DecidedLazy ) ( Rec0 PrimType ) :*: S1 (' MetaSel (' Just "intVal") ' NoSourceUnpackedness ' SourceStrict ' DecidedStrict ) ( Rec0 Int )) :+: C1 (' MetaCons "WordClosure" ' PrefixI ' True ) ( S1 (' MetaSel (' Just "ptipe") ' NoSourceUnpackedness ' NoSourceStrictness ' DecidedLazy ) ( Rec0 PrimType ) :*: S1 (' MetaSel (' Just "wordVal") ' NoSourceUnpackedness ' SourceStrict ' DecidedStrict ) ( Rec0 Word ))))) :+: (( C1 (' MetaCons "Int64Closure" ' PrefixI ' True ) ( S1 (' MetaSel (' Just "ptipe") ' NoSourceUnpackedness ' NoSourceStrictness ' DecidedLazy ) ( Rec0 PrimType ) :*: S1 (' MetaSel (' Just "int64Val") ' NoSourceUnpackedness ' SourceStrict ' DecidedStrict ) ( Rec0 Int64 )) :+: ( C1 (' MetaCons "Word64Closure" ' PrefixI ' True ) ( S1 (' MetaSel (' Just "ptipe") ' NoSourceUnpackedness ' NoSourceStrictness ' DecidedLazy ) ( Rec0 PrimType ) :*: S1 (' MetaSel (' Just "word64Val") ' NoSourceUnpackedness ' SourceStrict ' DecidedStrict ) ( Rec0 Word64 )) :+: C1 (' MetaCons "AddrClosure" ' PrefixI ' True ) ( S1 (' MetaSel (' Just "ptipe") ' NoSourceUnpackedness ' NoSourceStrictness ' DecidedLazy ) ( Rec0 PrimType ) :*: S1 (' MetaSel (' Just "addrVal") ' NoSourceUnpackedness ' SourceStrict ' DecidedStrict ) ( Rec0 Int )))) :+: (( C1 (' MetaCons "FloatClosure" ' PrefixI ' True ) ( S1 (' MetaSel (' Just "ptipe") ' NoSourceUnpackedness ' NoSourceStrictness ' DecidedLazy ) ( Rec0 PrimType ) :*: S1 (' MetaSel (' Just "floatVal") ' NoSourceUnpackedness ' SourceStrict ' DecidedStrict ) ( Rec0 Float )) :+: C1 (' MetaCons "DoubleClosure" ' PrefixI ' True ) ( S1 (' MetaSel (' Just "ptipe") ' NoSourceUnpackedness ' NoSourceStrictness ' DecidedLazy ) ( Rec0 PrimType ) :*: S1 (' MetaSel (' Just "doubleVal") ' NoSourceUnpackedness ' SourceStrict ' DecidedStrict ) ( Rec0 Double ))) :+: ( C1 (' MetaCons "OtherClosure" ' PrefixI ' True ) ( S1 (' MetaSel (' Just "info") ' NoSourceUnpackedness ' SourceStrict ' DecidedStrict ) ( Rec0 StgInfoTable ) :*: ( S1 (' MetaSel (' Just "hvalues") ' NoSourceUnpackedness ' SourceStrict ' DecidedStrict ) ( Rec0 [b]) :*: S1 (' MetaSel (' Just "rawWords") ' NoSourceUnpackedness ' SourceStrict ' DecidedStrict ) ( Rec0 [ Word ]))) :+: C1 (' MetaCons "UnsupportedClosure" ' PrefixI ' True ) ( S1 (' MetaSel (' Just "info") ' NoSourceUnpackedness ' SourceStrict ' DecidedStrict ) ( Rec0 StgInfoTable )))))))

data ClosureType Source #

Instances

Instances details
Enum ClosureType Source #
Instance details

Defined in GHC.Exts.Heap.ClosureTypes

Eq ClosureType Source #
Instance details

Defined in GHC.Exts.Heap.ClosureTypes

Ord ClosureType Source #
Instance details

Defined in GHC.Exts.Heap.ClosureTypes

Show ClosureType Source #
Instance details

Defined in GHC.Exts.Heap.ClosureTypes

Generic ClosureType Source #
Instance details

Defined in GHC.Exts.Heap.ClosureTypes

type Rep ClosureType Source #
Instance details

Defined in GHC.Exts.Heap.ClosureTypes

type Rep ClosureType = D1 (' MetaData "ClosureType" "GHC.Exts.Heap.ClosureTypes" "ghc-heap-8.10.7-IUP7BK823zx9GcxXynNXv1" ' False ) (((((( C1 (' MetaCons "INVALID_OBJECT" ' PrefixI ' False ) ( U1 :: Type -> Type ) :+: C1 (' MetaCons "CONSTR" ' PrefixI ' False ) ( U1 :: Type -> Type )) :+: ( C1 (' MetaCons "CONSTR_1_0" ' PrefixI ' False ) ( U1 :: Type -> Type ) :+: C1 (' MetaCons "CONSTR_0_1" ' PrefixI ' False ) ( U1 :: Type -> Type ))) :+: (( C1 (' MetaCons "CONSTR_2_0" ' PrefixI ' False ) ( U1 :: Type -> Type ) :+: C1 (' MetaCons "CONSTR_1_1" ' PrefixI ' False ) ( U1 :: Type -> Type )) :+: ( C1 (' MetaCons "CONSTR_0_2" ' PrefixI ' False ) ( U1 :: Type -> Type ) :+: C1 (' MetaCons "CONSTR_NOCAF" ' PrefixI ' False ) ( U1 :: Type -> Type )))) :+: ((( C1 (' MetaCons "FUN" ' PrefixI ' False ) ( U1 :: Type -> Type ) :+: C1 (' MetaCons "FUN_1_0" ' PrefixI ' False ) ( U1 :: Type -> Type )) :+: ( C1 (' MetaCons "FUN_0_1" ' PrefixI ' False ) ( U1 :: Type -> Type ) :+: C1 (' MetaCons "FUN_2_0" ' PrefixI ' False ) ( U1 :: Type -> Type ))) :+: (( C1 (' MetaCons "FUN_1_1" ' PrefixI ' False ) ( U1 :: Type -> Type ) :+: C1 (' MetaCons "FUN_0_2" ' PrefixI ' False ) ( U1 :: Type -> Type )) :+: ( C1 (' MetaCons "FUN_STATIC" ' PrefixI ' False ) ( U1 :: Type -> Type ) :+: C1 (' MetaCons "THUNK" ' PrefixI ' False ) ( U1 :: Type -> Type ))))) :+: (((( C1 (' MetaCons "THUNK_1_0" ' PrefixI ' False ) ( U1 :: Type -> Type ) :+: C1 (' MetaCons "THUNK_0_1" ' PrefixI ' False ) ( U1 :: Type -> Type )) :+: ( C1 (' MetaCons "THUNK_2_0" ' PrefixI ' False ) ( U1 :: Type -> Type ) :+: C1 (' MetaCons "THUNK_1_1" ' PrefixI ' False ) ( U1 :: Type -> Type ))) :+: (( C1 (' MetaCons "THUNK_0_2" ' PrefixI ' False ) ( U1 :: Type -> Type ) :+: C1 (' MetaCons "THUNK_STATIC" ' PrefixI ' False ) ( U1 :: Type -> Type )) :+: ( C1 (' MetaCons "THUNK_SELECTOR" ' PrefixI ' False ) ( U1 :: Type -> Type ) :+: C1 (' MetaCons "BCO" ' PrefixI ' False ) ( U1 :: Type -> Type )))) :+: ((( C1 (' MetaCons "AP" ' PrefixI ' False ) ( U1 :: Type -> Type ) :+: C1 (' MetaCons "PAP" ' PrefixI ' False ) ( U1 :: Type -> Type )) :+: ( C1 (' MetaCons "AP_STACK" ' PrefixI ' False ) ( U1 :: Type -> Type ) :+: C1 (' MetaCons "IND" ' PrefixI ' False ) ( U1 :: Type -> Type ))) :+: (( C1 (' MetaCons "IND_STATIC" ' PrefixI ' False ) ( U1 :: Type -> Type ) :+: C1 (' MetaCons "RET_BCO" ' PrefixI ' False ) ( U1 :: Type -> Type )) :+: ( C1 (' MetaCons "RET_SMALL" ' PrefixI ' False ) ( U1 :: Type -> Type ) :+: C1 (' MetaCons "RET_BIG" ' PrefixI ' False ) ( U1 :: Type -> Type )))))) :+: ((((( C1 (' MetaCons "RET_FUN" ' PrefixI ' False ) ( U1 :: Type -> Type ) :+: C1 (' MetaCons "UPDATE_FRAME" ' PrefixI ' False ) ( U1 :: Type -> Type )) :+: ( C1 (' MetaCons "CATCH_FRAME" ' PrefixI ' False ) ( U1 :: Type -> Type ) :+: C1 (' MetaCons "UNDERFLOW_FRAME" ' PrefixI ' False ) ( U1 :: Type -> Type ))) :+: (( C1 (' MetaCons "STOP_FRAME" ' PrefixI ' False ) ( U1 :: Type -> Type ) :+: C1 (' MetaCons "BLOCKING_QUEUE" ' PrefixI ' False ) ( U1 :: Type -> Type )) :+: ( C1 (' MetaCons "BLACKHOLE" ' PrefixI ' False ) ( U1 :: Type -> Type ) :+: C1 (' MetaCons "MVAR_CLEAN" ' PrefixI ' False ) ( U1 :: Type -> Type )))) :+: ((( C1 (' MetaCons "MVAR_DIRTY" ' PrefixI ' False ) ( U1 :: Type -> Type ) :+: C1 (' MetaCons "TVAR" ' PrefixI ' False ) ( U1 :: Type -> Type )) :+: ( C1 (' MetaCons "ARR_WORDS" ' PrefixI ' False ) ( U1 :: Type -> Type ) :+: C1 (' MetaCons "MUT_ARR_PTRS_CLEAN" ' PrefixI ' False ) ( U1 :: Type -> Type ))) :+: (( C1 (' MetaCons "MUT_ARR_PTRS_DIRTY" ' PrefixI ' False ) ( U1 :: Type -> Type ) :+: C1 (' MetaCons "MUT_ARR_PTRS_FROZEN_DIRTY" ' PrefixI ' False ) ( U1 :: Type -> Type )) :+: ( C1 (' MetaCons "MUT_ARR_PTRS_FROZEN_CLEAN" ' PrefixI ' False ) ( U1 :: Type -> Type ) :+: C1 (' MetaCons "MUT_VAR_CLEAN" ' PrefixI ' False ) ( U1 :: Type -> Type ))))) :+: (((( C1 (' MetaCons "MUT_VAR_DIRTY" ' PrefixI ' False ) ( U1 :: Type -> Type ) :+: C1 (' MetaCons "WEAK" ' PrefixI ' False ) ( U1 :: Type -> Type )) :+: ( C1 (' MetaCons "PRIM" ' PrefixI ' False ) ( U1 :: Type -> Type ) :+: C1 (' MetaCons "MUT_PRIM" ' PrefixI ' False ) ( U1 :: Type -> Type ))) :+: (( C1 (' MetaCons "TSO" ' PrefixI ' False ) ( U1 :: Type -> Type ) :+: C1 (' MetaCons "STACK" ' PrefixI ' False ) ( U1 :: Type -> Type )) :+: ( C1 (' MetaCons "TREC_CHUNK" ' PrefixI ' False ) ( U1 :: Type -> Type ) :+: C1 (' MetaCons "ATOMICALLY_FRAME" ' PrefixI ' False ) ( U1 :: Type -> Type )))) :+: ((( C1 (' MetaCons "CATCH_RETRY_FRAME" ' PrefixI ' False ) ( U1 :: Type -> Type ) :+: C1 (' MetaCons "CATCH_STM_FRAME" ' PrefixI ' False ) ( U1 :: Type -> Type )) :+: ( C1 (' MetaCons "WHITEHOLE" ' PrefixI ' False ) ( U1 :: Type -> Type ) :+: C1 (' MetaCons "SMALL_MUT_ARR_PTRS_CLEAN" ' PrefixI ' False ) ( U1 :: Type -> Type ))) :+: (( C1 (' MetaCons "SMALL_MUT_ARR_PTRS_DIRTY" ' PrefixI ' False ) ( U1 :: Type -> Type ) :+: C1 (' MetaCons "SMALL_MUT_ARR_PTRS_FROZEN_DIRTY" ' PrefixI ' False ) ( U1 :: Type -> Type )) :+: ( C1 (' MetaCons "SMALL_MUT_ARR_PTRS_FROZEN_CLEAN" ' PrefixI ' False ) ( U1 :: Type -> Type ) :+: ( C1 (' MetaCons "COMPACT_NFDATA" ' PrefixI ' False ) ( U1 :: Type -> Type ) :+: C1 (' MetaCons "N_CLOSURE_TYPES" ' PrefixI ' False ) ( U1 :: Type -> Type ))))))))

Info Table types

data StgInfoTable Source #

This is a somewhat faithful representation of an info table. See https://gitlab.haskell.org/ghc/ghc/blob/master/includes/rts/storage/InfoTables.h for more details on this data structure.

Instances

Instances details
Show StgInfoTable Source #
Instance details

Defined in GHC.Exts.Heap.InfoTable.Types

Generic StgInfoTable Source #
Instance details

Defined in GHC.Exts.Heap.InfoTable.Types

type Rep StgInfoTable Source #
Instance details

Defined in GHC.Exts.Heap.InfoTable.Types

itblSize :: Int Source #

Size in bytes of a standard InfoTable

peekItbl :: Ptr StgInfoTable -> IO StgInfoTable Source #

Read an InfoTable from the heap into a haskell type. WARNING: This code assumes it is passed a pointer to a "standard" info table. If tables_next_to_code is enabled, it will look 1 byte before the start for the entry field.

Closure inspection

getBoxedClosureData :: Box -> IO Closure Source #

Like getClosureData , but taking a Box , so it is easier to work with.

allClosures :: GenClosure b -> [b] Source #

For generic code, this function returns all referenced closures.

Boxes

data Box Source #

An arbitrary Haskell value in a safe Box. The point is that even unevaluated thunks can safely be moved around inside the Box, and when required, e.g. in getBoxedClosureData , the function knows how far it has to evaluate the argument.

Constructors

Box Any

asBox :: a -> Box Source #

This takes an arbitrary value and puts it into a box. Note that calls like

asBox (head list)

will put the thunk "head list" into the box, not the element at the head of the list. For that, use careful case expressions:

case list of x:_ -> asBox x

areBoxesEqual :: Box -> Box -> IO Bool Source #

Boxes can be compared, but this is not pure, as different heap objects can, after garbage collection, become the same object.