[GHC] #14373: Introduce PTR-tagging for big constructor families
GHC
ghc-devs at haskell.org
Thu Oct 19 16:54:21 UTC 2017
#14373: Introduce PTR-tagging for big constructor families
-------------------------------------+-------------------------------------
Reporter: heisenbug | Owner: (none)
Type: bug | Status: new
Priority: normal | Milestone:
Component: Compiler | Version: 8.2.1
Keywords: | Operating System: Unknown/Multiple
Architecture: | Type of failure: None/Unknown
Unknown/Multiple |
Test Case: | Blocked By:
Blocking: | Related Tickets:
Differential Rev(s): | Wiki Page:
-------------------------------------+-------------------------------------
Currently only ''small'' constructor families come into the benefit of
pointer tagging.
In big fams, 1 is the tag that says "I am evaluated". I suggest to do
best-effort pointer tagging on big families too by this scheme:
Ptr-tag 1..6 for the first 6 constructors, 7 would signify "look into the
info table and branch on that tag". In the info table the tags will then
be 6..(familySize - 1).
I have an implementation which I'll submit to fabricator soon.
TODOs: update wiki pages.
--
Ticket URL: <http://ghc.haskell.org/trac/ghc/ticket/14373>
GHC <http://www.haskell.org/ghc/>
The Glasgow Haskell Compiler
More information about the ghc-tickets
mailing list