[Git][ghc/ghc][wip/mpickering-hannes] Force inner_bh outside of unsafeInterleaveIO
Matthew Pickering (@mpickering)
gitlab at gitlab.haskell.org
Sat Mar 23 15:58:44 UTC 2024
Matthew Pickering pushed to branch wip/mpickering-hannes at Glasgow Haskell Compiler / GHC
Commits:
bc2c4a52 by Matthew Pickering at 2024-03-23T15:58:14+00:00
Force inner_bh outside of unsafeInterleaveIO
This reduces the size of the FUN closure from 96 to 56 bytes.
- - - - -
1 changed file:
- compiler/GHC/Utils/Binary.hs
Changes:
=====================================
compiler/GHC/Utils/Binary.hs
=====================================
@@ -1144,15 +1144,17 @@ lazyGet' :: HasCallStack => Maybe (IORef BinHandle) -> (Bin () -> BinHandle -> I
lazyGet' mbh f bh = do
p <- get @(Bin ()) bh -- a BinPtr
p_a <- tellBin bh
+ -- Do this before to avoid retaining reference to old BH inside the unsafeInterleaveIO.
+ let !get_inner_bh = maybe (pure bh) readIORef mbh
a <- unsafeInterleaveIO $ do
-- NB: Use a fresh off_r variable in the child thread, for thread
-- safety.
- inner_bh <- maybe (pure bh) readIORef mbh
+ inner_bh <- get_inner_bh
off_r <- newFastMutInt 0
let bh' = inner_bh { _off_r = off_r }
- seekBin bh' p_a
+ seekBinNoExpand bh' p_a
f p bh'
- seekBin bh p -- skip over the object for now
+ seekBinNoExpand bh p -- skip over the object for now
return a
-- | Serialize the constructor strictly but lazily serialize a value inside a
@@ -1282,6 +1284,8 @@ getGenericSymbolTable :: forall a. (Bin () -> BinHandle -> IO a) -> IORef BinHan
getGenericSymbolTable deserialiser bhRef bh = do
sz <- forwardGet bh (get bh) :: IO Int
mut_arr <- newArray_ (0, sz-1) :: IO (IOArray Int a)
+ -- Using lazyPut/lazyGet is quite space inefficient as each usage will allocate a large closure
+ -- (6 arguments-ish).
forM_ [0..(sz-1)] $ \i -> do
f <- lazyGet' (Just bhRef) deserialiser bh
writeArray mut_arr i f
View it on GitLab: https://gitlab.haskell.org/ghc/ghc/-/commit/bc2c4a5231550fed6f14fb3075a50b20a61366a5
--
View it on GitLab: https://gitlab.haskell.org/ghc/ghc/-/commit/bc2c4a5231550fed6f14fb3075a50b20a61366a5
You're receiving this email because of your account on gitlab.haskell.org.
-------------- next part --------------
An HTML attachment was scrubbed...
URL: <http://mail.haskell.org/pipermail/ghc-commits/attachments/20240323/c0c6a5f6/attachment-0001.html>
More information about the ghc-commits
mailing list