diff options
| author | Michael D. Adams <t-madams@microsoft.com> | 2007-06-27 15:09:03 +0000 | 
|---|---|---|
| committer | Michael D. Adams <t-madams@microsoft.com> | 2007-06-27 15:09:03 +0000 | 
| commit | affbe8dae5d7eb350686b42ddbd4f3561b7bd0ec (patch) | |
| tree | 7558970725c9e17e0017d6c825949d8e178d3445 /compiler/codeGen/CgUtils.hs | |
| parent | 207802589da0d23c3f16195f453b24a1e46e322d (diff) | |
| download | haskell-affbe8dae5d7eb350686b42ddbd4f3561b7bd0ec.tar.gz | |
Added an SRT to each CmmCall and added the current SRT to the CgMonad
Diffstat (limited to 'compiler/codeGen/CgUtils.hs')
| -rw-r--r-- | compiler/codeGen/CgUtils.hs | 44 | 
1 files changed, 42 insertions, 2 deletions
| diff --git a/compiler/codeGen/CgUtils.hs b/compiler/codeGen/CgUtils.hs index a4d2338e52..26857d386c 100644 --- a/compiler/codeGen/CgUtils.hs +++ b/compiler/codeGen/CgUtils.hs @@ -29,7 +29,9 @@ module CgUtils (  	mkWordCLit,  	mkStringCLit, mkByteStringCLit,  	packHalfWordsCLit, -	blankWord +	blankWord, + +	getSRTInfo    ) where  #include "HsVersions.h" @@ -45,6 +47,8 @@ import CLabel  import CmmUtils  import MachOp  import ForeignCall +import ClosureInfo +import StgSyn (SRT(..))  import Literal  import Digraph  import ListSetOps @@ -284,8 +288,9 @@ emitRtsCall'     -> Maybe [GlobalReg]     -> Code  emitRtsCall' res fun args vols = do +    srt <- getSRTInfo      stmtsC caller_save -    stmtC (CmmCall target res args) +    stmtC (CmmCall target res args srt)      stmtsC caller_load    where      (caller_save, caller_load) = callerSaveVolatileRegs vols @@ -705,3 +710,38 @@ possiblySameLoc (CmmRegOff r1 start1) rep1 (CmmRegOff r2 start2) rep2  possiblySameLoc l1 rep1 (CmmLit _) rep2 = False  possiblySameLoc l1 rep1 l2	   rep2 = True	-- Conservative + +------------------------------------------------------------------------- +-- +--	Static Reference Tables +-- +------------------------------------------------------------------------- + +-- There is just one SRT for each top level binding; all the nested +-- bindings use sub-sections of this SRT.  The label is passed down to +-- the nested bindings via the monad. + +getSRTInfo :: FCode C_SRT +getSRTInfo = do +  srt_lbl <- getSRTLabel +  srt <- getSRT +  case srt of +    -- TODO: Should we panic in this case? +    -- Someone obviously thinks there should be an SRT +    NoSRT -> return NoC_SRT +    SRT off len bmp +      | len > hALF_WORD_SIZE_IN_BITS || bmp == [fromIntegral srt_escape] +      -> do id <- newUnique +            let srt_desc_lbl = mkLargeSRTLabel id +	    emitRODataLits srt_desc_lbl +             ( cmmLabelOffW srt_lbl off +	       : mkWordCLit (fromIntegral len) +	       : map mkWordCLit bmp) +	    return (C_SRT srt_desc_lbl 0 srt_escape) + +    SRT off len bmp +      | otherwise  +      -> return (C_SRT srt_lbl off (fromIntegral (head bmp))) +		-- The fromIntegral converts to StgHalfWord + +srt_escape = (-1) :: StgHalfWord | 
