[GHC] #11143: Feature request: Add index/read/write primops with byte offset for ByteArray#
GHC
ghc-devs at haskell.org
Wed Feb 21 20:34:24 UTC 2018
#11143: Feature request: Add index/read/write primops with byte offset for
ByteArray#
-------------------------------------+-------------------------------------
Reporter: vagarenko | Owner: sjakobi
Type: feature request | Status: new
Priority: normal | Milestone:
Component: Compiler | Version: 7.10.2
Resolution: | Keywords: newcomers
Operating System: Unknown/Multiple | Architecture:
Type of failure: Runtime | Unknown/Multiple
performance bug | Test Case:
Blocked By: | Blocking:
Related Tickets: | Differential Rev(s): Phab:D4433
Wiki Page: |
-------------------------------------+-------------------------------------
Comment (by vagarenko):
> Can we instead have primops which take both an offset measured in bytes
and an offset measured in terms of the type?
> {{{#!hs
> indexTYPEArray# :: ByteArray# -> Int# {-byte offset-} -> Int#
{-type offset-} -> TYPE#
> readTYPEArray# :: MutableByteArray# s -> Int# {-byte offset-} -> Int#
{-type offset-} -> State# s -> (#State# s, TYPE##)
> writeTYPEArray# :: MutableByteArray# s -> Int# {-byte offset-} -> Int#
{-type offset-} -> TYPE# -> State# s -> State# s
>
> indexTYPEOffAddr# :: Addr# -> Int# {-byte offset-} -> Int# {-type
offset-} -> TYPE
> readTYPEOffAddr# :: Addr# -> Int# {-byte offset-} -> Int# {-type
offset-} -> State# s -> (#State# s, TYPE ##)
> writeTYPEOffAddr# :: Addr# -> Int# {-byte offset-} -> Int# {-type
offset-} -> TYPE -> State# s -> State# s
> }}}
>
> All of these go through the `mkBasicIndexed{Read,Write}` functions,
which take both a byte offset and a type offset, so it seems reasonable to
expose that.
I'm confused. Why do you want this? Isn't `byte offset` here is just `type
offset * sizeof type`?
--
Ticket URL: <http://ghc.haskell.org/trac/ghc/ticket/11143#comment:7>
GHC <http://www.haskell.org/ghc/>
The Glasgow Haskell Compiler
More information about the ghc-tickets
mailing list