diff options
Diffstat (limited to 'compiler/cmm/CmmInfo.hs')
| -rw-r--r-- | compiler/cmm/CmmInfo.hs | 56 | 
1 files changed, 28 insertions, 28 deletions
| diff --git a/compiler/cmm/CmmInfo.hs b/compiler/cmm/CmmInfo.hs index 29affaef0b..0735937754 100644 --- a/compiler/cmm/CmmInfo.hs +++ b/compiler/cmm/CmmInfo.hs @@ -24,7 +24,6 @@ import qualified Stream  import Hoopl  import Maybes -import Constants  import DynFlags  import Panic  import UniqSupply @@ -114,8 +113,8 @@ mkInfoTable dflags proc@(CmmProc infos entry_lbl blocks)                -- Use a zero place-holder in place of the                -- entry-label in the info table                return (top_decls ++ -                      [mkRODataLits info_lbl (zeroCLit : rel_std_info ++ -                                                         rel_extra_bits)]) +                      [mkRODataLits info_lbl (zeroCLit dflags : rel_std_info ++ +                                                                rel_extra_bits)])            _nonempty ->               -- Separately emit info table (with the function entry               -- point as first entry) and the entry code @@ -172,9 +171,9 @@ mkInfoTableContents dflags      -- (which in turn came from a handwritten .cmm file)    | StackRep frame <- smrep -  = do { (prof_lits, prof_data) <- mkProfLits prof -       ; let (srt_label, srt_bitmap) = mkSRTLit srt -       ; (liveness_lit, liveness_data) <- mkLivenessBits frame +  = do { (prof_lits, prof_data) <- mkProfLits dflags prof +       ; let (srt_label, srt_bitmap) = mkSRTLit dflags srt +       ; (liveness_lit, liveness_data) <- mkLivenessBits dflags frame         ; let               std_info = mkStdInfoTable dflags prof_lits rts_tag srt_bitmap liveness_lit               rts_tag | Just tag <- mb_rts_tag = tag @@ -184,9 +183,9 @@ mkInfoTableContents dflags         ; return (prof_data ++ liveness_data, (std_info, srt_label)) }    | HeapRep _ ptrs nonptrs closure_type <- smrep -  = do { let layout  = packHalfWordsCLit ptrs nonptrs -       ; (prof_lits, prof_data) <- mkProfLits prof -       ; let (srt_label, srt_bitmap) = mkSRTLit srt +  = do { let layout  = packHalfWordsCLit dflags ptrs nonptrs +       ; (prof_lits, prof_data) <- mkProfLits dflags prof +       ; let (srt_label, srt_bitmap) = mkSRTLit dflags srt         ; (mb_srt_field, mb_layout, extra_bits, ct_data)                                  <- mk_pieces closure_type srt_label         ; let std_info = mkStdInfoTable dflags prof_lits @@ -208,24 +207,24 @@ mkInfoTableContents dflags        = return (Nothing, Nothing, srt_label, [])      mk_pieces (ThunkSelector offset) _no_srt -      = return (Just 0, Just (mkWordCLit offset), [], []) +      = return (Just 0, Just (mkWordCLit dflags offset), [], [])           -- Layout known (one free var); we use the layout field for offset      mk_pieces (Fun arity (ArgSpec fun_type)) srt_label  -      = do { let extra_bits = packHalfWordsCLit fun_type arity : srt_label +      = do { let extra_bits = packHalfWordsCLit dflags fun_type arity : srt_label             ; return (Nothing, Nothing,  extra_bits, []) }      mk_pieces (Fun arity (ArgGen arg_bits)) srt_label -      = do { (liveness_lit, liveness_data) <- mkLivenessBits arg_bits +      = do { (liveness_lit, liveness_data) <- mkLivenessBits dflags arg_bits             ; let fun_type | null liveness_data = aRG_GEN                            | otherwise          = aRG_GEN_BIG -                 extra_bits = [ packHalfWordsCLit fun_type arity +                 extra_bits = [ packHalfWordsCLit dflags fun_type arity                                , srt_lit, liveness_lit, slow_entry ]             ; return (Nothing, Nothing, extra_bits, liveness_data) }        where          slow_entry = CmmLabel (toSlowEntryLbl info_lbl)          srt_lit = case srt_label of -                    []          -> mkIntCLit 0 +                    []          -> mkIntCLit dflags 0                      (lit:_rest) -> ASSERT( null _rest ) lit      mk_pieces BlackHole _ = panic "mk_pieces: BlackHole" @@ -233,11 +232,12 @@ mkInfoTableContents dflags  mkInfoTableContents _ _ _ = panic "mkInfoTableContents"   -- NonInfoTable dealt with earlier -mkSRTLit :: C_SRT +mkSRTLit :: DynFlags +         -> C_SRT           -> ([CmmLit],    -- srt_label, if any               StgHalfWord) -- srt_bitmap -mkSRTLit NoC_SRT                = ([], 0) -mkSRTLit (C_SRT lbl off bitmap) = ([cmmLabelOffW lbl off], bitmap) +mkSRTLit _      NoC_SRT                = ([], 0) +mkSRTLit dflags (C_SRT lbl off bitmap) = ([cmmLabelOffW dflags lbl off], bitmap)  ------------------------------------------------------------------------- @@ -297,34 +297,34 @@ makeRelativeRefTo _ _ lit = lit  -- The head of the stack layout is the top of the stack and  -- the least-significant bit. -mkLivenessBits :: Liveness -> UniqSM (CmmLit, [RawCmmDecl]) +mkLivenessBits :: DynFlags -> Liveness -> UniqSM (CmmLit, [RawCmmDecl])                -- ^ Returns:                --   1. The bitmap (literal value or label)                --   2. Large bitmap CmmData if needed -mkLivenessBits liveness -  | n_bits > mAX_SMALL_BITMAP_SIZE    -- does not fit in one word +mkLivenessBits dflags liveness +  | n_bits > mAX_SMALL_BITMAP_SIZE dflags -- does not fit in one word    = do { uniq <- getUniqueUs         ; let bitmap_lbl = mkBitmapLabel uniq         ; return (CmmLabel bitmap_lbl,                    [mkRODataLits bitmap_lbl lits]) }    | otherwise -- Fits in one word -  = return (mkWordCLit bitmap_word, []) +  = return (mkWordCLit dflags bitmap_word, [])    where      n_bits = length liveness      bitmap :: Bitmap -    bitmap = mkBitmap liveness +    bitmap = mkBitmap dflags liveness      small_bitmap = case bitmap of   		     []  -> 0                       [b] -> b  		     _   -> panic "mkLiveness"      bitmap_word = fromIntegral n_bits -              .|. (small_bitmap `shiftL` bITMAP_BITS_SHIFT) +              .|. (small_bitmap `shiftL` bITMAP_BITS_SHIFT dflags) -    lits = mkWordCLit (fromIntegral n_bits) : map mkWordCLit bitmap +    lits = mkWordCLit dflags (fromIntegral n_bits) : map (mkWordCLit dflags) bitmap        -- The first word is the size.  The structure must match        -- StgLargeBitmap in includes/rts/storage/InfoTable.h @@ -361,7 +361,7 @@ mkStdInfoTable dflags (type_descr, closure_descr) cl_type srt_len layout_lit  	| dopt Opt_SccProfilingOn dflags = [type_descr, closure_descr]  	| otherwise = [] -    type_lit = packHalfWordsCLit cl_type srt_len +    type_lit = packHalfWordsCLit dflags cl_type srt_len  -------------------------------------------------------------------------  -- @@ -369,9 +369,9 @@ mkStdInfoTable dflags (type_descr, closure_descr) cl_type srt_len layout_lit  --  ------------------------------------------------------------------------- -mkProfLits :: ProfilingInfo -> UniqSM ((CmmLit,CmmLit), [RawCmmDecl]) -mkProfLits NoProfilingInfo       = return ((zeroCLit, zeroCLit), []) -mkProfLits (ProfilingInfo td cd) +mkProfLits :: DynFlags -> ProfilingInfo -> UniqSM ((CmmLit,CmmLit), [RawCmmDecl]) +mkProfLits dflags NoProfilingInfo       = return ((zeroCLit dflags, zeroCLit dflags), []) +mkProfLits _ (ProfilingInfo td cd)    = do { (td_lit, td_decl) <- newStringLit td         ; (cd_lit, cd_decl) <- newStringLit cd         ; return ((td_lit,cd_lit), [td_decl,cd_decl]) } | 
