{-# OPTIONS_HADDOCK prune #-}
{-# LANGUAGE BangPatterns #-}
{-# LANGUAGE MagicHash #-}
{-# LANGUAGE PatternSynonyms #-}
{-# LANGUAGE UnboxedTuples #-}
module Crypto.DRBG.HMAC.SHA512 (
DRBG
, Error(..)
, new
, gen
, reseed
, wipe
, _read_v
, _read_k
) where
import Crypto.DRBG.HMAC.Internal (Error(..), _RESEED_COUNTER, _MAX_BYTES)
import qualified Crypto.Hash.SHA512 as SHA512
import Crypto.Hash.SHA512.Internal (Registers(..))
import qualified Crypto.Hash.SHA512.Internal as SHA512 (cat)
import Control.Monad.Primitive (PrimMonad, PrimState)
import Control.Monad.ST (ST)
import GHC.Exts (RealWorld)
import qualified Control.Monad.Primitive as Prim (unsafeIOToPrim)
import qualified Data.ByteString as BS
import qualified Data.ByteString.Builder as BSB
import qualified Data.ByteString.Internal as BI
import qualified Data.Primitive.PrimArray as PA
import Data.Word (Word64)
import qualified GHC.Word
import qualified Foreign.Ptr as FP
newtype DRBG s = DRBG (PA.MutablePrimArray s Word64)
instance Show (DRBG s) where
show :: DRBG s -> String
show DRBG s
_ = String
"<drbg>"
new
:: PrimMonad m
=> BS.ByteString
-> BS.ByteString
-> BS.ByteString
-> m (DRBG (PrimState m))
new :: forall (m :: * -> *).
PrimMonad m =>
ByteString -> ByteString -> ByteString -> m (DRBG (PrimState m))
new ByteString
entropy ByteString
nonce ByteString
ps = do
drbg <- Int -> m (MutablePrimArray (PrimState m) Word64)
forall (m :: * -> *) a.
(PrimMonad m, Prim a) =>
Int -> m (MutablePrimArray (PrimState m) a)
PA.newPinnedPrimArray Int
33
init_counter drbg
PA.setPrimArray drbg 01 08 (0x0000000000000000 :: Word64)
PA.setPrimArray drbg 09 08 (0x0101010101010101 :: Word64)
PA.setPrimArray drbg 17 16 (0x0000000000000000 :: Word64)
update drbg (entropy <> nonce <> ps)
pure $! DRBG drbg
{-# INLINABLE new #-}
{-# SPECIALIZE new
:: BS.ByteString -> BS.ByteString -> BS.ByteString -> IO (DRBG RealWorld) #-}
{-# SPECIALIZE new
:: BS.ByteString -> BS.ByteString -> BS.ByteString -> ST s (DRBG s) #-}
reseed
:: PrimMonad m
=> DRBG (PrimState m)
-> BS.ByteString
-> BS.ByteString
-> m ()
reseed :: forall (m :: * -> *).
PrimMonad m =>
DRBG (PrimState m) -> ByteString -> ByteString -> m ()
reseed (DRBG MutablePrimArray (PrimState m) Word64
drbg) ByteString
entr ByteString
addl = do
MutablePrimArray (PrimState m) Word64 -> ByteString -> m ()
forall (m :: * -> *).
PrimMonad m =>
MutablePrimArray (PrimState m) Word64 -> ByteString -> m ()
update MutablePrimArray (PrimState m) Word64
drbg (ByteString
entr ByteString -> ByteString -> ByteString
forall a. Semigroup a => a -> a -> a
<> ByteString
addl)
MutablePrimArray (PrimState m) Word64 -> m ()
forall (m :: * -> *).
PrimMonad m =>
MutablePrimArray (PrimState m) Word64 -> m ()
init_counter MutablePrimArray (PrimState m) Word64
drbg
{-# INLINE reseed #-}
gen
:: PrimMonad m
=> DRBG (PrimState m)
-> BS.ByteString
-> Word64
-> m (Either Error BS.ByteString)
gen :: forall (m :: * -> *).
PrimMonad m =>
DRBG (PrimState m)
-> ByteString -> Word64 -> m (Either Error ByteString)
gen (DRBG MutablePrimArray (PrimState m) Word64
drbg) addl :: ByteString
addl@(BI.PS ForeignPtr Word8
_ Int
_ Int
l) Word64
bytes
| Word64
bytes Word64 -> Word64 -> Bool
forall a. Ord a => a -> a -> Bool
> Word64
_MAX_BYTES = Either Error ByteString -> m (Either Error ByteString)
forall a. a -> m a
forall (f :: * -> *) a. Applicative f => a -> f a
pure (Either Error ByteString -> m (Either Error ByteString))
-> Either Error ByteString -> m (Either Error ByteString)
forall a b. (a -> b) -> a -> b
$! Error -> Either Error ByteString
forall a b. a -> Either a b
Left Error
MaxBytesExceeded
| Bool
otherwise = do
ctr <- MutablePrimArray (PrimState m) Word64 -> m Word64
forall (m :: * -> *).
PrimMonad m =>
MutablePrimArray (PrimState m) Word64 -> m Word64
read_counter MutablePrimArray (PrimState m) Word64
drbg
if ctr > _RESEED_COUNTER
then pure $! Left ReseedRequired
else do
if l == 0 then pure () else update drbg addl
!(GHC.Word.W64# k00) <- PA.readPrimArray drbg 01
!(GHC.Word.W64# k01) <- PA.readPrimArray drbg 02
!(GHC.Word.W64# k02) <- PA.readPrimArray drbg 03
!(GHC.Word.W64# k03) <- PA.readPrimArray drbg 04
!(GHC.Word.W64# k04) <- PA.readPrimArray drbg 05
!(GHC.Word.W64# k05) <- PA.readPrimArray drbg 06
!(GHC.Word.W64# k06) <- PA.readPrimArray drbg 07
!(GHC.Word.W64# k07) <- PA.readPrimArray drbg 08
!(GHC.Word.W64# v00) <- PA.readPrimArray drbg 09
!(GHC.Word.W64# v01) <- PA.readPrimArray drbg 10
!(GHC.Word.W64# v02) <- PA.readPrimArray drbg 11
!(GHC.Word.W64# v03) <- PA.readPrimArray drbg 12
!(GHC.Word.W64# v04) <- PA.readPrimArray drbg 13
!(GHC.Word.W64# v05) <- PA.readPrimArray drbg 14
!(GHC.Word.W64# v06) <- PA.readPrimArray drbg 15
!(GHC.Word.W64# v07) <- PA.readPrimArray drbg 16
let !k0 = (# Word64#, Word64#, Word64#, Word64#, Word64#, Word64#, Word64#,
Word64# #)
-> Registers
Registers (# Word64#
k00, Word64#
k01, Word64#
k02, Word64#
k03, Word64#
k04, Word64#
k05, Word64#
k06, Word64#
k07 #)
!v0 = (# Word64#, Word64#, Word64#, Word64#, Word64#, Word64#, Word64#,
Word64# #)
-> Registers
Registers (# Word64#
v00, Word64#
v01, Word64#
v02, Word64#
v03, Word64#
v04, Word64#
v05, Word64#
v06, Word64#
v07 #)
!res <- gen_loop drbg k0 v0 bytes
update drbg addl
write_counter drbg (ctr + 1)
pure $! Right res
{-# INLINABLE gen #-}
{-# SPECIALIZE gen
:: DRBG RealWorld -> BS.ByteString -> Word64
-> IO (Either Error BS.ByteString) #-}
{-# SPECIALIZE gen
:: DRBG s -> BS.ByteString -> Word64
-> ST s (Either Error BS.ByteString) #-}
wipe
:: PrimMonad m
=> DRBG (PrimState m)
-> m ()
wipe :: forall (m :: * -> *). PrimMonad m => DRBG (PrimState m) -> m ()
wipe (DRBG MutablePrimArray (PrimState m) Word64
drbg) = do
MutablePrimArray (PrimState m) Word64 -> m ()
forall (m :: * -> *).
PrimMonad m =>
MutablePrimArray (PrimState m) Word64 -> m ()
init_counter MutablePrimArray (PrimState m) Word64
drbg
MutablePrimArray (PrimState m) Word64
-> Int -> Int -> Word64 -> m ()
forall a (m :: * -> *).
(Prim a, PrimMonad m) =>
MutablePrimArray (PrimState m) a -> Int -> Int -> a -> m ()
PA.setPrimArray MutablePrimArray (PrimState m) Word64
drbg Int
01 Int
08 (Word64
0x0000000000000000 :: Word64)
MutablePrimArray (PrimState m) Word64
-> Int -> Int -> Word64 -> m ()
forall a (m :: * -> *).
(Prim a, PrimMonad m) =>
MutablePrimArray (PrimState m) a -> Int -> Int -> a -> m ()
PA.setPrimArray MutablePrimArray (PrimState m) Word64
drbg Int
09 Int
08 (Word64
0x0101010101010101 :: Word64)
MutablePrimArray (PrimState m) Word64
-> Int -> Int -> Word64 -> m ()
forall a (m :: * -> *).
(Prim a, PrimMonad m) =>
MutablePrimArray (PrimState m) a -> Int -> Int -> a -> m ()
PA.setPrimArray MutablePrimArray (PrimState m) Word64
drbg Int
17 Int
16 (Word64
0x0000000000000000 :: Word64)
{-# INLINE wipe #-}
gen_loop
:: PrimMonad m
=> PA.MutablePrimArray (PrimState m) Word64
-> Registers
-> Registers
-> Word64
-> m BS.ByteString
gen_loop :: forall (m :: * -> *).
PrimMonad m =>
MutablePrimArray (PrimState m) Word64
-> Registers -> Registers -> Word64 -> m ByteString
gen_loop MutablePrimArray (PrimState m) Word64
drbg Registers
k0 Registers
v0 Word64
bytes = ByteString -> Registers -> Word64 -> m ByteString
forall {m :: * -> *}.
(PrimState m ~ PrimState m, PrimMonad m) =>
ByteString -> Registers -> Word64 -> m ByteString
loop ByteString
forall a. Monoid a => a
mempty Registers
v0 Word64
0 where
!vp :: Ptr b
vp = MutablePrimArray (PrimState m) Word64 -> Ptr Word64
forall s a. MutablePrimArray s a -> Ptr a
PA.mutablePrimArrayContents MutablePrimArray (PrimState m) Word64
drbg Ptr Word64 -> Int -> Ptr b
forall a b. Ptr a -> Int -> Ptr b
`FP.plusPtr` Int
72
!sp :: Ptr b
sp = MutablePrimArray (PrimState m) Word64 -> Ptr Word64
forall s a. MutablePrimArray s a -> Ptr a
PA.mutablePrimArrayContents MutablePrimArray (PrimState m) Word64
drbg Ptr Word64 -> Int -> Ptr b
forall a b. Ptr a -> Int -> Ptr b
`FP.plusPtr` Int
136
loop :: ByteString -> Registers -> Word64 -> m ByteString
loop !ByteString
acc Registers
v Word64
l
| Word64
l Word64 -> Word64 -> Bool
forall a. Ord a => a -> a -> Bool
>= Word64
bytes = do
MutablePrimArray (PrimState m) Word64 -> Registers -> m ()
forall (m :: * -> *).
PrimMonad m =>
MutablePrimArray (PrimState m) Word64 -> Registers -> m ()
write_v MutablePrimArray (PrimState m) Word64
MutablePrimArray (PrimState m) Word64
drbg Registers
v
ByteString -> m ByteString
forall a. a -> m a
forall (f :: * -> *) a. Applicative f => a -> f a
pure ByteString
acc
| Bool
otherwise = do
IO () -> m ()
forall (m :: * -> *) a. PrimMonad m => IO a -> m a
Prim.unsafeIOToPrim (IO () -> m ()) -> IO () -> m ()
forall a b. (a -> b) -> a -> b
$ Ptr Word64 -> Ptr Word64 -> Registers -> Registers -> IO ()
SHA512._hmac_rr Ptr Word64
forall {b}. Ptr b
vp Ptr Word64
forall {b}. Ptr b
sp Registers
k0 Registers
v
!(GHC.Word.W64# nv0) <- MutablePrimArray (PrimState m) Word64 -> Int -> m Word64
forall a (m :: * -> *).
(Prim a, PrimMonad m) =>
MutablePrimArray (PrimState m) a -> Int -> m a
PA.readPrimArray MutablePrimArray (PrimState m) Word64
MutablePrimArray (PrimState m) Word64
drbg Int
09
!(GHC.Word.W64# nv1) <- PA.readPrimArray drbg 10
!(GHC.Word.W64# nv2) <- PA.readPrimArray drbg 11
!(GHC.Word.W64# nv3) <- PA.readPrimArray drbg 12
!(GHC.Word.W64# nv4) <- PA.readPrimArray drbg 13
!(GHC.Word.W64# nv5) <- PA.readPrimArray drbg 14
!(GHC.Word.W64# nv6) <- PA.readPrimArray drbg 15
!(GHC.Word.W64# nv7) <- PA.readPrimArray drbg 16
let !nv = (# Word64#, Word64#, Word64#, Word64#, Word64#, Word64#, Word64#,
Word64# #)
-> Registers
Registers (# Word64#
nv0, Word64#
nv1, Word64#
nv2, Word64#
nv3, Word64#
nv4, Word64#
nv5, Word64#
nv6, Word64#
nv7 #)
!na = ByteString
acc ByteString -> ByteString -> ByteString
forall a. Semigroup a => a -> a -> a
<> Registers -> ByteString
SHA512.cat Registers
nv
!nl = Word64
l Word64 -> Word64 -> Word64
forall a. Num a => a -> a -> a
+ Word64
64
loop na nv nl
{-# INLINE gen_loop #-}
update
:: PrimMonad m
=> PA.MutablePrimArray (PrimState m) Word64
-> BS.ByteString
-> m ()
update :: forall (m :: * -> *).
PrimMonad m =>
MutablePrimArray (PrimState m) Word64 -> ByteString -> m ()
update MutablePrimArray (PrimState m) Word64
drbg provided_data :: ByteString
provided_data@(BI.PS ForeignPtr Word8
_ Int
_ Int
l) = do
!(GHC.Word.W64# k00) <- MutablePrimArray (PrimState m) Word64 -> Int -> m Word64
forall a (m :: * -> *).
(Prim a, PrimMonad m) =>
MutablePrimArray (PrimState m) a -> Int -> m a
PA.readPrimArray MutablePrimArray (PrimState m) Word64
drbg Int
01
!(GHC.Word.W64# k01) <- PA.readPrimArray drbg 02
!(GHC.Word.W64# k02) <- PA.readPrimArray drbg 03
!(GHC.Word.W64# k03) <- PA.readPrimArray drbg 04
!(GHC.Word.W64# k04) <- PA.readPrimArray drbg 05
!(GHC.Word.W64# k05) <- PA.readPrimArray drbg 06
!(GHC.Word.W64# k06) <- PA.readPrimArray drbg 07
!(GHC.Word.W64# k07) <- PA.readPrimArray drbg 08
!(GHC.Word.W64# v00) <- PA.readPrimArray drbg 09
!(GHC.Word.W64# v01) <- PA.readPrimArray drbg 10
!(GHC.Word.W64# v02) <- PA.readPrimArray drbg 11
!(GHC.Word.W64# v03) <- PA.readPrimArray drbg 12
!(GHC.Word.W64# v04) <- PA.readPrimArray drbg 13
!(GHC.Word.W64# v05) <- PA.readPrimArray drbg 14
!(GHC.Word.W64# v06) <- PA.readPrimArray drbg 15
!(GHC.Word.W64# v07) <- PA.readPrimArray drbg 16
let !k0 = (# Word64#, Word64#, Word64#, Word64#, Word64#, Word64#, Word64#,
Word64# #)
-> Registers
Registers (# Word64#
k00, Word64#
k01, Word64#
k02, Word64#
k03, Word64#
k04, Word64#
k05, Word64#
k06, Word64#
k07 #)
!v0 = (# Word64#, Word64#, Word64#, Word64#, Word64#, Word64#, Word64#,
Word64# #)
-> Registers
Registers (# Word64#
v00, Word64#
v01, Word64#
v02, Word64#
v03, Word64#
v04, Word64#
v05, Word64#
v06, Word64#
v07 #)
!kp = MutablePrimArray (PrimState m) Word64 -> Ptr Word64
forall s a. MutablePrimArray s a -> Ptr a
PA.mutablePrimArrayContents MutablePrimArray (PrimState m) Word64
drbg Ptr Word64 -> Int -> Ptr b
forall a b. Ptr a -> Int -> Ptr b
`FP.plusPtr` Int
08
!vp = MutablePrimArray (PrimState m) Word64 -> Ptr Word64
forall s a. MutablePrimArray s a -> Ptr a
PA.mutablePrimArrayContents MutablePrimArray (PrimState m) Word64
drbg Ptr Word64 -> Int -> Ptr b
forall a b. Ptr a -> Int -> Ptr b
`FP.plusPtr` Int
72
!sp = MutablePrimArray (PrimState m) Word64 -> Ptr Word64
forall s a. MutablePrimArray s a -> Ptr a
PA.mutablePrimArrayContents MutablePrimArray (PrimState m) Word64
drbg Ptr Word64 -> Int -> Ptr b
forall a b. Ptr a -> Int -> Ptr b
`FP.plusPtr` Int
136
Prim.unsafeIOToPrim $ SHA512._hmac_rsb kp sp k0 v0 0x00 provided_data
!(GHC.Word.W64# k10) <- PA.readPrimArray drbg 01
!(GHC.Word.W64# k11) <- PA.readPrimArray drbg 02
!(GHC.Word.W64# k12) <- PA.readPrimArray drbg 03
!(GHC.Word.W64# k13) <- PA.readPrimArray drbg 04
!(GHC.Word.W64# k14) <- PA.readPrimArray drbg 05
!(GHC.Word.W64# k15) <- PA.readPrimArray drbg 06
!(GHC.Word.W64# k16) <- PA.readPrimArray drbg 07
!(GHC.Word.W64# k17) <- PA.readPrimArray drbg 08
let !k1 = (# Word64#, Word64#, Word64#, Word64#, Word64#, Word64#, Word64#,
Word64# #)
-> Registers
Registers (# Word64#
k10, Word64#
k11, Word64#
k12, Word64#
k13, Word64#
k14, Word64#
k15, Word64#
k16, Word64#
k17 #)
Prim.unsafeIOToPrim $ SHA512._hmac_rr vp sp k1 v0
if l == 0
then pure ()
else do
!(GHC.Word.W64# v10) <- PA.readPrimArray drbg 09
!(GHC.Word.W64# v11) <- PA.readPrimArray drbg 10
!(GHC.Word.W64# v12) <- PA.readPrimArray drbg 11
!(GHC.Word.W64# v13) <- PA.readPrimArray drbg 12
!(GHC.Word.W64# v14) <- PA.readPrimArray drbg 13
!(GHC.Word.W64# v15) <- PA.readPrimArray drbg 14
!(GHC.Word.W64# v16) <- PA.readPrimArray drbg 15
!(GHC.Word.W64# v17) <- PA.readPrimArray drbg 16
let !v1 = (# Word64#, Word64#, Word64#, Word64#, Word64#, Word64#, Word64#,
Word64# #)
-> Registers
Registers (# Word64#
v10, Word64#
v11, Word64#
v12, Word64#
v13, Word64#
v14, Word64#
v15, Word64#
v16, Word64#
v17 #)
Prim.unsafeIOToPrim $ SHA512._hmac_rsb kp sp k1 v1 0x01 provided_data
!(GHC.Word.W64# k20) <- PA.readPrimArray drbg 01
!(GHC.Word.W64# k21) <- PA.readPrimArray drbg 02
!(GHC.Word.W64# k22) <- PA.readPrimArray drbg 03
!(GHC.Word.W64# k23) <- PA.readPrimArray drbg 04
!(GHC.Word.W64# k24) <- PA.readPrimArray drbg 05
!(GHC.Word.W64# k25) <- PA.readPrimArray drbg 06
!(GHC.Word.W64# k26) <- PA.readPrimArray drbg 07
!(GHC.Word.W64# k27) <- PA.readPrimArray drbg 08
let !k2 = (# Word64#, Word64#, Word64#, Word64#, Word64#, Word64#, Word64#,
Word64# #)
-> Registers
Registers (# Word64#
k20, Word64#
k21, Word64#
k22, Word64#
k23, Word64#
k24, Word64#
k25, Word64#
k26, Word64#
k27 #)
Prim.unsafeIOToPrim $ SHA512._hmac_rr vp sp k2 v1
{-# INLINABLE update #-}
{-# SPECIALIZE update
:: PA.MutablePrimArray RealWorld Word64 -> BS.ByteString -> IO () #-}
{-# SPECIALIZE update
:: PA.MutablePrimArray s Word64 -> BS.ByteString -> ST s () #-}
init_counter
:: PrimMonad m
=> PA.MutablePrimArray (PrimState m) Word64
-> m ()
init_counter :: forall (m :: * -> *).
PrimMonad m =>
MutablePrimArray (PrimState m) Word64 -> m ()
init_counter MutablePrimArray (PrimState m) Word64
drbg =
MutablePrimArray (PrimState m) Word64 -> Int -> Word64 -> m ()
forall a (m :: * -> *).
(Prim a, PrimMonad m) =>
MutablePrimArray (PrimState m) a -> Int -> a -> m ()
PA.writePrimArray MutablePrimArray (PrimState m) Word64
drbg Int
0 (Word64
0x01 :: Word64)
{-# INLINE init_counter #-}
read_counter
:: PrimMonad m
=> PA.MutablePrimArray (PrimState m) Word64
-> m Word64
read_counter :: forall (m :: * -> *).
PrimMonad m =>
MutablePrimArray (PrimState m) Word64 -> m Word64
read_counter MutablePrimArray (PrimState m) Word64
drbg = MutablePrimArray (PrimState m) Word64 -> Int -> m Word64
forall a (m :: * -> *).
(Prim a, PrimMonad m) =>
MutablePrimArray (PrimState m) a -> Int -> m a
PA.readPrimArray MutablePrimArray (PrimState m) Word64
drbg Int
0
{-# INLINE read_counter #-}
write_counter
:: PrimMonad m
=> PA.MutablePrimArray (PrimState m) Word64
-> Word64
-> m ()
write_counter :: forall (m :: * -> *).
PrimMonad m =>
MutablePrimArray (PrimState m) Word64 -> Word64 -> m ()
write_counter MutablePrimArray (PrimState m) Word64
drbg = MutablePrimArray (PrimState m) Word64 -> Int -> Word64 -> m ()
forall a (m :: * -> *).
(Prim a, PrimMonad m) =>
MutablePrimArray (PrimState m) a -> Int -> a -> m ()
PA.writePrimArray MutablePrimArray (PrimState m) Word64
drbg Int
0
{-# INLINE write_counter #-}
write_v
:: PrimMonad m
=> PA.MutablePrimArray (PrimState m) Word64
-> Registers
-> m ()
write_v :: forall (m :: * -> *).
PrimMonad m =>
MutablePrimArray (PrimState m) Word64 -> Registers -> m ()
write_v MutablePrimArray (PrimState m) Word64
drbg (R Word64#
v0 Word64#
v1 Word64#
v2 Word64#
v3 Word64#
v4 Word64#
v5 Word64#
v6 Word64#
v7) = do
MutablePrimArray (PrimState m) Word64 -> Int -> Word64 -> m ()
forall a (m :: * -> *).
(Prim a, PrimMonad m) =>
MutablePrimArray (PrimState m) a -> Int -> a -> m ()
PA.writePrimArray MutablePrimArray (PrimState m) Word64
drbg Int
09 (Word64# -> Word64
GHC.Word.W64# Word64#
v0)
MutablePrimArray (PrimState m) Word64 -> Int -> Word64 -> m ()
forall a (m :: * -> *).
(Prim a, PrimMonad m) =>
MutablePrimArray (PrimState m) a -> Int -> a -> m ()
PA.writePrimArray MutablePrimArray (PrimState m) Word64
drbg Int
10 (Word64# -> Word64
GHC.Word.W64# Word64#
v1)
MutablePrimArray (PrimState m) Word64 -> Int -> Word64 -> m ()
forall a (m :: * -> *).
(Prim a, PrimMonad m) =>
MutablePrimArray (PrimState m) a -> Int -> a -> m ()
PA.writePrimArray MutablePrimArray (PrimState m) Word64
drbg Int
11 (Word64# -> Word64
GHC.Word.W64# Word64#
v2)
MutablePrimArray (PrimState m) Word64 -> Int -> Word64 -> m ()
forall a (m :: * -> *).
(Prim a, PrimMonad m) =>
MutablePrimArray (PrimState m) a -> Int -> a -> m ()
PA.writePrimArray MutablePrimArray (PrimState m) Word64
drbg Int
12 (Word64# -> Word64
GHC.Word.W64# Word64#
v3)
MutablePrimArray (PrimState m) Word64 -> Int -> Word64 -> m ()
forall a (m :: * -> *).
(Prim a, PrimMonad m) =>
MutablePrimArray (PrimState m) a -> Int -> a -> m ()
PA.writePrimArray MutablePrimArray (PrimState m) Word64
drbg Int
13 (Word64# -> Word64
GHC.Word.W64# Word64#
v4)
MutablePrimArray (PrimState m) Word64 -> Int -> Word64 -> m ()
forall a (m :: * -> *).
(Prim a, PrimMonad m) =>
MutablePrimArray (PrimState m) a -> Int -> a -> m ()
PA.writePrimArray MutablePrimArray (PrimState m) Word64
drbg Int
14 (Word64# -> Word64
GHC.Word.W64# Word64#
v5)
MutablePrimArray (PrimState m) Word64 -> Int -> Word64 -> m ()
forall a (m :: * -> *).
(Prim a, PrimMonad m) =>
MutablePrimArray (PrimState m) a -> Int -> a -> m ()
PA.writePrimArray MutablePrimArray (PrimState m) Word64
drbg Int
15 (Word64# -> Word64
GHC.Word.W64# Word64#
v6)
MutablePrimArray (PrimState m) Word64 -> Int -> Word64 -> m ()
forall a (m :: * -> *).
(Prim a, PrimMonad m) =>
MutablePrimArray (PrimState m) a -> Int -> a -> m ()
PA.writePrimArray MutablePrimArray (PrimState m) Word64
drbg Int
16 (Word64# -> Word64
GHC.Word.W64# Word64#
v7)
{-# INLINE write_v #-}
_read_v
:: PrimMonad m
=> DRBG (PrimState m)
-> m BS.ByteString
_read_v :: forall (m :: * -> *).
PrimMonad m =>
DRBG (PrimState m) -> m ByteString
_read_v (DRBG MutablePrimArray (PrimState m) Word64
drbg) = do
!v00 <- MutablePrimArray (PrimState m) Word64 -> Int -> m Word64
forall a (m :: * -> *).
(Prim a, PrimMonad m) =>
MutablePrimArray (PrimState m) a -> Int -> m a
PA.readPrimArray MutablePrimArray (PrimState m) Word64
drbg Int
09
!v01 <- PA.readPrimArray drbg 10
!v02 <- PA.readPrimArray drbg 11
!v03 <- PA.readPrimArray drbg 12
!v04 <- PA.readPrimArray drbg 13
!v05 <- PA.readPrimArray drbg 14
!v06 <- PA.readPrimArray drbg 15
!v07 <- PA.readPrimArray drbg 16
pure . BS.toStrict . BSB.toLazyByteString $ mconcat [
BSB.word64BE v00
, BSB.word64BE v01
, BSB.word64BE v02
, BSB.word64BE v03
, BSB.word64BE v04
, BSB.word64BE v05
, BSB.word64BE v06
, BSB.word64BE v07
]
_read_k
:: PrimMonad m
=> DRBG (PrimState m)
-> m BS.ByteString
_read_k :: forall (m :: * -> *).
PrimMonad m =>
DRBG (PrimState m) -> m ByteString
_read_k (DRBG MutablePrimArray (PrimState m) Word64
drbg) = do
!k00 <- MutablePrimArray (PrimState m) Word64 -> Int -> m Word64
forall a (m :: * -> *).
(Prim a, PrimMonad m) =>
MutablePrimArray (PrimState m) a -> Int -> m a
PA.readPrimArray MutablePrimArray (PrimState m) Word64
drbg Int
01
!k01 <- PA.readPrimArray drbg 02
!k02 <- PA.readPrimArray drbg 03
!k03 <- PA.readPrimArray drbg 04
!k04 <- PA.readPrimArray drbg 05
!k05 <- PA.readPrimArray drbg 06
!k06 <- PA.readPrimArray drbg 07
!k07 <- PA.readPrimArray drbg 08
pure . BS.toStrict . BSB.toLazyByteString $ mconcat [
BSB.word64BE k00
, BSB.word64BE k01
, BSB.word64BE k02
, BSB.word64BE k03
, BSB.word64BE k04
, BSB.word64BE k05
, BSB.word64BE k06
, BSB.word64BE k07
]