| Safe Haskell | Safe-Inferred | 
|---|---|
| Language | Haskell2010 | 
GHC.StgToCmm.ExtCode
Description
Our extended FCode monad.
Synopsis
- data CmmParse a
- unEC :: CmmParse a -> String -> Env -> Decls -> FCode (Decls, a)
- data Named
- type Env = UniqFM FastString Named
- loopDecls :: CmmParse a -> CmmParse a
- getEnv :: CmmParse Env
- withName :: String -> CmmParse a -> CmmParse a
- getName :: CmmParse String
- newLocal :: CmmType -> FastString -> CmmParse LocalReg
- newLabel :: FastString -> CmmParse BlockId
- newBlockId :: MonadUnique m => m BlockId
- newFunctionName :: FastString -> UnitId -> ExtCode
- newImport :: (FastString, CLabel) -> CmmParse ()
- lookupLabel :: FastString -> CmmParse BlockId
- lookupName :: FastString -> CmmParse CmmExpr
- code :: FCode a -> CmmParse a
- emit :: CmmAGraph -> CmmParse ()
- emitLabel :: BlockId -> CmmParse ()
- emitAssign :: CmmReg -> CmmExpr -> CmmParse ()
- emitStore :: CmmExpr -> CmmExpr -> CmmParse ()
- getCode :: CmmParse a -> CmmParse CmmAGraph
- getCodeR :: CmmParse a -> CmmParse (a, CmmAGraph)
- getCodeScoped :: CmmParse a -> CmmParse (a, CmmAGraphScoped)
- emitOutOfLine :: BlockId -> CmmAGraphScoped -> CmmParse ()
- withUpdFrameOff :: UpdFrameOffset -> CmmParse () -> CmmParse ()
- getUpdFrameOff :: CmmParse UpdFrameOffset
- getProfile :: CmmParse Profile
- getPlatform :: CmmParse Platform
- getPtrOpts :: CmmParse PtrOpts
Documentation
Does a computation in the FCode monad, with a current environment and a list of local declarations. Returns the resulting list of declarations.
Instances
| Applicative CmmParse # | |
| Defined in GHC.StgToCmm.ExtCode | |
| Functor CmmParse # | |
| Monad CmmParse # | |
| HasDynFlags CmmParse # | |
| Defined in GHC.StgToCmm.ExtCode Methods | |
| MonadUnique CmmParse # | |
| Defined in GHC.StgToCmm.ExtCode Methods getUniqueSupplyM :: CmmParse UniqSupply # getUniqueM :: CmmParse Unique # getUniquesM :: CmmParse [Unique] # | |
The environment contains variable definitions or blockids.
type Env = UniqFM FastString Named #
An environment of named things.
loopDecls :: CmmParse a -> CmmParse a #
Takes the variable declarations and imports from the monad and makes an environment, which is looped back into the computation. In this way, we can have embedded declarations that scope over the whole procedure, and imports that scope over the entire module. Discards the local declaration contained within decl'
Arguments
| :: CmmType | data type | 
| -> FastString | name of variable | 
| -> CmmParse LocalReg | register holding the value | 
Create a fresh local variable of a given type.
newLabel :: FastString -> CmmParse BlockId #
Allocate a fresh label.
newBlockId :: MonadUnique m => m BlockId #
Arguments
| :: FastString | name of the function | 
| -> UnitId | package of the current module | 
| -> ExtCode | 
Add a local function to the environment.
newImport :: (FastString, CLabel) -> CmmParse () #
Add an imported foreign label to the list of local declarations. If this is done at the start of the module the declaration will scope over the whole module.
lookupLabel :: FastString -> CmmParse BlockId #
Lookup the BlockId bound to the label with this name. If one hasn't been bound yet, create a fresh one based on the Unique of the name.
lookupName :: FastString -> CmmParse CmmExpr #
Lookup the location of a named variable. Unknown names are treated as if they had been 'import'ed from the runtime system. This saves us a lot of bother in the RTS sources, at the expense of deferring some errors to link time.
emitAssign :: CmmReg -> CmmExpr -> CmmParse () #
getCodeScoped :: CmmParse a -> CmmParse (a, CmmAGraphScoped) #
emitOutOfLine :: BlockId -> CmmAGraphScoped -> CmmParse () #
withUpdFrameOff :: UpdFrameOffset -> CmmParse () -> CmmParse () #