[GHC] #13910: Inlining a definition causes GHC to panic (repSplitTyConApp_maybe)
GHC
ghc-devs at haskell.org
Thu Sep 14 22:30:41 UTC 2017
#13910: Inlining a definition causes GHC to panic (repSplitTyConApp_maybe)
-------------------------------------+-------------------------------------
Reporter: RyanGlScott | Owner: (none)
Type: bug | Status: new
Priority: normal | Milestone:
Component: Compiler (Type | Version: 8.2.1-rc2
checker) |
Resolution: | Keywords: TypeInType
Operating System: Unknown/Multiple | Architecture:
Type of failure: Compile-time | Unknown/Multiple
crash or panic | Test Case:
Blocked By: 14119 | Blocking:
Related Tickets: #13877, #14038, | Differential Rev(s):
#14175 |
Wiki Page: |
-------------------------------------+-------------------------------------
Comment (by simonpj):
I now think that the patch in comment:14 is bogus.
I tripped over this when debugging #13910, following
the patch in comment:7 of that ticket. We had
{{{
[W] alpha |> co ~ t
}}}
where `co :: <blah> ~ kappa`, `alpha` and `kappa` are unification
variables, `t :: tk` is a skolem.
We can't unify `alpha := t |> sym co` because the kinds don't match, so,
according to `Note [Equalities with incompatible kinds]` (introduced in
comment:14) we emit a derived equality
{{{
[D] kappa ~ tk
}}}
and park the original Wanted as an Irred.
ALAS! It turns out that `kappa` was ''already'' unified with `tk`, so the
new Derived is instantly solved, but since no unifications happen we don't
kick out the Wanted from the inert set, so it (utterly bogusly) stays
unsolved.
Possible solution: in the kind check in `canEqTyVar` use `zonk_eq_types`.
That would make this program work, I think, but a deeper bug is lurking.
The process described in `Note [Equalities with incompatible kinds]`
relies on the kind-equality being solved by unification. But what if we
have
{{{
[W] (alpha :: F Int) ~ (beta :: *)
}}}
Now we may indeed be able solve the kind equality `F Int ~ *`, if `F` is a
type function, with a suitable instance. But there is no unification
happening, and we really do need ultimately to unify `alpha` to `beta |>
co` where `co :: * ~ F Int`. I conclude that the patch in comment:14 is
utterly wrong.
Richard do you agree?
Given `[W] co :: (alpha :: k1) ~ (ty :: k2)`, kind-heterogeneous, I think
we probably ''do'' want to generate a wanted kind-equality
{{{
[W] co_k :: k1 ~ k2
}}}
Then rewrite the original equality to
{{{
[W] co' :: (alpha :: k1) ~ (ty :: k2) |> sym co_k
}}}
'''But we want to somehow refrain from actually carrying out the
unificationn unti we have discharged `co_k`.''' One way to do that might
be to park it in Irreds and kick it out when unifying `co_k`. But that
would fail if we end up iterating the entire implication in which this
constraint lives. Maybe we should refrain from unify `alpha := ty` if
there are any coercion holes in `ty`?
--
Ticket URL: <http://ghc.haskell.org/trac/ghc/ticket/13910#comment:9>
GHC <http://www.haskell.org/ghc/>
The Glasgow Haskell Compiler
More information about the ghc-tickets
mailing list