summaryrefslogtreecommitdiff
diff options
context:
space:
mode:
authorAndreas Klebinger <klebinger.andreas@gmx.at>2022-08-12 17:44:22 +0200
committerAndreas Klebinger <klebinger.andreas@gmx.at>2022-09-15 10:12:42 +0200
commit7cce70073f5017cf5514f92a900c76e47a4292a5 (patch)
treefbf7e6eaf352e8db88d16aaa5c613ab0017e68e2
parentd6ea8356b721ea4c3b871a796c1b2b13f94fd471 (diff)
downloadhaskell-7cce70073f5017cf5514f92a900c76e47a4292a5.tar.gz
Stg.InferTags.Rewrite - Avoid some thunks.wip/andreask/infer_exprs
-rw-r--r--compiler/GHC/Stg/InferTags/Rewrite.hs18
1 files changed, 9 insertions, 9 deletions
diff --git a/compiler/GHC/Stg/InferTags/Rewrite.hs b/compiler/GHC/Stg/InferTags/Rewrite.hs
index 253763cc5b..d2d0bbeb2f 100644
--- a/compiler/GHC/Stg/InferTags/Rewrite.hs
+++ b/compiler/GHC/Stg/InferTags/Rewrite.hs
@@ -128,7 +128,7 @@ getMap :: RM (UniqFM Id TagSig)
getMap = RM $ ((\(fst,_,_,_) -> fst) <$> get)
setMap :: (UniqFM Id TagSig) -> RM ()
-setMap m = RM $ do
+setMap !m = RM $ do
(_,us,mod,lcls) <- get
put (m, us,mod,lcls)
@@ -139,7 +139,7 @@ getFVs :: RM IdSet
getFVs = RM $ ((\(_,_,_,lcls) -> lcls) <$> get)
setFVs :: IdSet -> RM ()
-setFVs fvs = RM $ do
+setFVs !fvs = RM $ do
(tag_map,us,mod,_lcls) <- get
put (tag_map, us,mod,fvs)
@@ -195,9 +195,9 @@ withBinders NotTopLevel sigs cont = do
withClosureLcls :: DIdSet -> RM a -> RM a
withClosureLcls fvs act = do
old_fvs <- getFVs
- let fvs' = nonDetStrictFoldDVarSet (flip extendVarSet) old_fvs fvs
+ let !fvs' = nonDetStrictFoldDVarSet (flip extendVarSet) old_fvs fvs
setFVs fvs'
- r <- act
+ !r <- act
setFVs old_fvs
return r
@@ -206,9 +206,9 @@ withClosureLcls fvs act = do
withLcl :: Id -> RM a -> RM a
withLcl fv act = do
old_fvs <- getFVs
- let fvs' = extendVarSet old_fvs fv
+ let !fvs' = extendVarSet old_fvs fv
setFVs fvs'
- r <- act
+ !r <- act
setFVs old_fvs
return r
@@ -222,7 +222,7 @@ isTagged v = do
| otherwise -> do -- Local binding
!s <- getMap
let !sig = lookupWithDefaultUFM s (pprPanic "unknown Id:" (ppr v)) v
- return $ case sig of
+ return $! case sig of
TagSig info ->
case info of
TagDunno -> False
@@ -234,7 +234,7 @@ isTagged v = do
, isNullaryRepDataCon con
-> return True
| Just lf_info <- idLFInfo_maybe v
- -> return $
+ -> return $!
-- Can we treat the thing as tagged based on it's LFInfo?
case lf_info of
-- Function, applied not entered.
@@ -353,7 +353,7 @@ rewriteArg (lit@StgLitArg{}) = return lit
rewriteId :: Id -> RM Id
rewriteId v = do
- is_tagged <- isTagged v
+ !is_tagged <- isTagged v
if is_tagged then return $! setIdTagSig v (TagSig TagProper)
else return v