summaryrefslogtreecommitdiff
path: root/compiler
diff options
context:
space:
mode:
authorSebastian Graf <sebastian.graf@kit.edu>2022-04-08 09:50:17 +0200
committerSebastian Graf <sebastian.graf@kit.edu>2022-04-12 17:54:58 +0200
commitb06f4f470b6bbe296cc828f8698e9d55cca39d73 (patch)
treec0c9a9d203bcb1e23e9808054e6b8c863bae8871 /compiler
parent4d2ee313f23a4454d12c9f94ff132f078dd64d31 (diff)
downloadhaskell-b06f4f470b6bbe296cc828f8698e9d55cca39d73.tar.gz
Specialise: Check `typeDeterminesValue` before specialising on an interesting dictionarywip/T19644
I extracted the checks from `Note [Type determines value]` into its own function, so that we share the logic properly. Then I made sure that we actually call `typeDeterminesValue` everywhere we check for `interestingDict`.
Diffstat (limited to 'compiler')
-rw-r--r--compiler/GHC/Core/Opt/Specialise.hs14
1 files changed, 10 insertions, 4 deletions
diff --git a/compiler/GHC/Core/Opt/Specialise.hs b/compiler/GHC/Core/Opt/Specialise.hs
index 6801e3e0a8..36ee54b7c0 100644
--- a/compiler/GHC/Core/Opt/Specialise.hs
+++ b/compiler/GHC/Core/Opt/Specialise.hs
@@ -2811,7 +2811,7 @@ mkCallUDs' env f args
-- we decide on a case by case basis if we want to specialise
-- on this argument; if so, SpecDict, if not UnspecArg
mk_spec_arg arg (Anon InvisArg pred)
- | not (isIPLikePred (scaledThing pred))
+ | typeDeterminesValue (scaledThing pred)
-- See Note [Type determines value]
, interestingDict env arg
-- See Note [Interesting dictionary arguments]
@@ -2881,8 +2881,13 @@ whole it's only a small win: 2.2% improvement in allocation for ansi,
1.2% for bspt, but mostly 0.0! Average 0.1% increase in binary size.
-}
+typeDeterminesValue :: Type -> Bool
+-- See Note [Type determines value]
+typeDeterminesValue ty = isDictTy ty && not (isIPLikePred ty)
+
interestingDict :: SpecEnv -> CoreExpr -> Bool
--- A dictionary argument is interesting if it has *some* structure
+-- A dictionary argument is interesting if it has *some* structure,
+-- see Note [Interesting dictionary arguments]
-- NB: "dictionary" arguments include constraints of all sorts,
-- including equality constraints; hence the Coercion case
interestingDict env (Var v) = hasSomeUnfolding (idUnfolding v)
@@ -3164,7 +3169,8 @@ cloneBindSM :: SpecEnv -> CoreBind -> SpecM (SpecEnv, SpecEnv, CoreBind)
cloneBindSM env@(SE { se_subst = subst, se_interesting = interesting }) (NonRec bndr rhs)
= do { us <- getUniqueSupplyM
; let (subst', bndr') = Core.cloneIdBndr subst us bndr
- interesting' | interestingDict env rhs
+ interesting' | typeDeterminesValue (idType bndr)
+ , interestingDict env rhs
= interesting `extendVarSet` bndr'
| otherwise = interesting
; return (env, env { se_subst = subst', se_interesting = interesting' }
@@ -3175,7 +3181,7 @@ cloneBindSM env@(SE { se_subst = subst, se_interesting = interesting }) (Rec pai
; let (subst', bndrs') = Core.cloneRecIdBndrs subst us (map fst pairs)
env' = env { se_subst = subst'
, se_interesting = interesting `extendVarSetList`
- [ v | (v,r) <- pairs, interestingDict env r ] }
+ [ v | (v,r) <- pairs, typeDeterminesValue (idType v), interestingDict env r ] }
; return (env', env', Rec (bndrs' `zip` map snd pairs)) }
newDictBndr :: SpecEnv -> CoreBndr -> SpecM CoreBndr