{-# LANGUAGE TypeFamilies #-}
{-# LANGUAGE GADTs #-}
{-# LANGUAGE RankNTypes #-}
{-# LANGUAGE MultiParamTypeClasses #-}
{-# LANGUAGE FlexibleInstances #-}
{-# LANGUAGE DataKinds #-}
module Raaz.Core.Memory
(
Memory(..)
, VoidMemory, withMemoryPtr
, withMemory, withSecureMemory
, Alloc
, pointerAlloc
, Initialisable(..), Extractable(..), modifyMem
, Access(..)
, ReadAccessible(..), WriteAccessible(..), memTransfer
, MemoryCell, copyCell, withCellPointer, unsafeGetCellPointer
) where
import Foreign.Ptr ( castPtr )
import Foreign.Storable ( Storable )
import Raaz.Core.Prelude
import Raaz.Core.MonoidalAction
import Raaz.Core.Types hiding ( zipWith )
import Raaz.Core.Types.Internal
type AllocField = Field (Ptr Word8)
type Alloc mem = TwistRF AllocField (BYTES Int) mem
makeAlloc :: LengthUnit l => l -> (Ptr Word8 -> mem) -> Alloc mem
makeAlloc :: l -> (Ptr Word8 -> mem) -> Alloc mem
makeAlloc l
l Ptr Word8 -> mem
memCreate = WrappedArrow (->) (Ptr Word8) mem -> BYTES Int -> Alloc mem
forall (f :: * -> *) m a. f a -> m -> TwistRF f m a
TwistRF ((Ptr Word8 -> mem) -> WrappedArrow (->) (Ptr Word8) mem
forall (a :: * -> * -> *) b c. a b c -> WrappedArrow a b c
WrapArrow Ptr Word8 -> mem
memCreate) (BYTES Int -> Alloc mem) -> BYTES Int -> Alloc mem
forall a b. (a -> b) -> a -> b
$ l -> BYTES Int
forall src dest. (LengthUnit src, LengthUnit dest) => src -> dest
atLeast l
l
pointerAlloc :: LengthUnit l => l -> Alloc (Ptr Word8)
pointerAlloc :: l -> Alloc (Ptr Word8)
pointerAlloc l
l = l -> (Ptr Word8 -> Ptr Word8) -> Alloc (Ptr Word8)
forall l mem. LengthUnit l => l -> (Ptr Word8 -> mem) -> Alloc mem
makeAlloc l
l Ptr Word8 -> Ptr Word8
forall a. a -> a
id
class Memory m where
memoryAlloc :: Alloc m
unsafeToPointer :: m -> Ptr Word8
newtype VoidMemory = VoidMemory { VoidMemory -> Ptr Word8
unVoidMemory :: Ptr Word8 }
instance Memory VoidMemory where
memoryAlloc :: Alloc VoidMemory
memoryAlloc = BYTES Int -> (Ptr Word8 -> VoidMemory) -> Alloc VoidMemory
forall l mem. LengthUnit l => l -> (Ptr Word8 -> mem) -> Alloc mem
makeAlloc (BYTES Int
0 :: BYTES Int) Ptr Word8 -> VoidMemory
VoidMemory
unsafeToPointer :: VoidMemory -> Ptr Word8
unsafeToPointer = VoidMemory -> Ptr Word8
unVoidMemory
instance ( Memory ma, Memory mb ) => Memory (ma, mb) where
memoryAlloc :: Alloc (ma, mb)
memoryAlloc = (,) (ma -> mb -> (ma, mb))
-> TwistRF AllocField (BYTES Int) ma
-> TwistRF AllocField (BYTES Int) (mb -> (ma, mb))
forall (f :: * -> *) a b. Functor f => (a -> b) -> f a -> f b
<$> TwistRF AllocField (BYTES Int) ma
forall m. Memory m => Alloc m
memoryAlloc TwistRF AllocField (BYTES Int) (mb -> (ma, mb))
-> TwistRF AllocField (BYTES Int) mb -> Alloc (ma, mb)
forall (f :: * -> *) a b. Applicative f => f (a -> b) -> f a -> f b
<*> TwistRF AllocField (BYTES Int) mb
forall m. Memory m => Alloc m
memoryAlloc
unsafeToPointer :: (ma, mb) -> Ptr Word8
unsafeToPointer (ma
ma, mb
_) = ma -> Ptr Word8
forall m. Memory m => m -> Ptr Word8
unsafeToPointer ma
ma
instance ( Memory ma
, Memory mb
, Memory mc
)
=> Memory (ma, mb, mc) where
memoryAlloc :: Alloc (ma, mb, mc)
memoryAlloc = (,,)
(ma -> mb -> mc -> (ma, mb, mc))
-> TwistRF AllocField (BYTES Int) ma
-> TwistRF AllocField (BYTES Int) (mb -> mc -> (ma, mb, mc))
forall (f :: * -> *) a b. Functor f => (a -> b) -> f a -> f b
<$> TwistRF AllocField (BYTES Int) ma
forall m. Memory m => Alloc m
memoryAlloc
TwistRF AllocField (BYTES Int) (mb -> mc -> (ma, mb, mc))
-> TwistRF AllocField (BYTES Int) mb
-> TwistRF AllocField (BYTES Int) (mc -> (ma, mb, mc))
forall (f :: * -> *) a b. Applicative f => f (a -> b) -> f a -> f b
<*> TwistRF AllocField (BYTES Int) mb
forall m. Memory m => Alloc m
memoryAlloc
TwistRF AllocField (BYTES Int) (mc -> (ma, mb, mc))
-> TwistRF AllocField (BYTES Int) mc -> Alloc (ma, mb, mc)
forall (f :: * -> *) a b. Applicative f => f (a -> b) -> f a -> f b
<*> TwistRF AllocField (BYTES Int) mc
forall m. Memory m => Alloc m
memoryAlloc
unsafeToPointer :: (ma, mb, mc) -> Ptr Word8
unsafeToPointer (ma
ma,mb
_,mc
_) = ma -> Ptr Word8
forall m. Memory m => m -> Ptr Word8
unsafeToPointer ma
ma
instance ( Memory ma
, Memory mb
, Memory mc
, Memory md
)
=> Memory (ma, mb, mc, md) where
memoryAlloc :: Alloc (ma, mb, mc, md)
memoryAlloc = (,,,)
(ma -> mb -> mc -> md -> (ma, mb, mc, md))
-> TwistRF AllocField (BYTES Int) ma
-> TwistRF
AllocField (BYTES Int) (mb -> mc -> md -> (ma, mb, mc, md))
forall (f :: * -> *) a b. Functor f => (a -> b) -> f a -> f b
<$> TwistRF AllocField (BYTES Int) ma
forall m. Memory m => Alloc m
memoryAlloc
TwistRF AllocField (BYTES Int) (mb -> mc -> md -> (ma, mb, mc, md))
-> TwistRF AllocField (BYTES Int) mb
-> TwistRF AllocField (BYTES Int) (mc -> md -> (ma, mb, mc, md))
forall (f :: * -> *) a b. Applicative f => f (a -> b) -> f a -> f b
<*> TwistRF AllocField (BYTES Int) mb
forall m. Memory m => Alloc m
memoryAlloc
TwistRF AllocField (BYTES Int) (mc -> md -> (ma, mb, mc, md))
-> TwistRF AllocField (BYTES Int) mc
-> TwistRF AllocField (BYTES Int) (md -> (ma, mb, mc, md))
forall (f :: * -> *) a b. Applicative f => f (a -> b) -> f a -> f b
<*> TwistRF AllocField (BYTES Int) mc
forall m. Memory m => Alloc m
memoryAlloc
TwistRF AllocField (BYTES Int) (md -> (ma, mb, mc, md))
-> TwistRF AllocField (BYTES Int) md -> Alloc (ma, mb, mc, md)
forall (f :: * -> *) a b. Applicative f => f (a -> b) -> f a -> f b
<*> TwistRF AllocField (BYTES Int) md
forall m. Memory m => Alloc m
memoryAlloc
unsafeToPointer :: (ma, mb, mc, md) -> Ptr Word8
unsafeToPointer (ma
ma,mb
_,mc
_,md
_) = ma -> Ptr Word8
forall m. Memory m => m -> Ptr Word8
unsafeToPointer ma
ma
withMemoryPtr :: Memory m
=> (BYTES Int -> Ptr Word8 -> IO a)
-> m -> IO a
withMemoryPtr :: (BYTES Int -> Ptr Word8 -> IO a) -> m -> IO a
withMemoryPtr BYTES Int -> Ptr Word8 -> IO a
action m
mem = BYTES Int -> Ptr Word8 -> IO a
action BYTES Int
sz (Ptr Word8 -> IO a) -> Ptr Word8 -> IO a
forall a b. (a -> b) -> a -> b
$ m -> Ptr Word8
forall m. Memory m => m -> Ptr Word8
unsafeToPointer m
mem
where sz :: BYTES Int
sz = TwistRF AllocField (BYTES Int) m -> BYTES Int
forall (f :: * -> *) m a. TwistRF f m a -> m
twistMonoidValue (TwistRF AllocField (BYTES Int) m -> BYTES Int)
-> TwistRF AllocField (BYTES Int) m -> BYTES Int
forall a b. (a -> b) -> a -> b
$ m -> TwistRF AllocField (BYTES Int) m
forall m. Memory m => m -> Alloc m
getAlloc m
mem
getAlloc :: Memory m => m -> Alloc m
getAlloc :: m -> Alloc m
getAlloc m
_ = Alloc m
forall m. Memory m => Alloc m
memoryAlloc
withMemory :: Memory mem => (mem -> IO a) -> IO a
withMemory :: (mem -> IO a) -> IO a
withMemory = Alloc mem -> (mem -> IO a) -> IO a
forall mem a. Alloc mem -> (mem -> IO a) -> IO a
withM Alloc mem
forall m. Memory m => Alloc m
memoryAlloc
where withM :: Alloc mem -> (mem -> IO a) -> IO a
withM :: Alloc mem -> (mem -> IO a) -> IO a
withM Alloc mem
alctr mem -> IO a
action = BYTES Int -> (Ptr Word8 -> IO a) -> IO a
forall l (ptr :: * -> *) something b.
(LengthUnit l, Pointer ptr) =>
l -> (ptr something -> IO b) -> IO b
allocaBuffer BYTES Int
sz Ptr Word8 -> IO a
actualAction
where sz :: BYTES Int
sz = Alloc mem -> BYTES Int
forall (f :: * -> *) m a. TwistRF f m a -> m
twistMonoidValue Alloc mem
alctr
getM :: Ptr Word8 -> mem
getM = Field (Ptr Word8) mem -> Ptr Word8 -> mem
forall space b. Field space b -> space -> b
computeField (Field (Ptr Word8) mem -> Ptr Word8 -> mem)
-> Field (Ptr Word8) mem -> Ptr Word8 -> mem
forall a b. (a -> b) -> a -> b
$ Alloc mem -> Field (Ptr Word8) mem
forall (f :: * -> *) m a. TwistRF f m a -> f a
twistFunctorValue Alloc mem
alctr
wipeIt :: Ptr Word8 -> IO ()
wipeIt Ptr Word8
cptr = Ptr Word8 -> BYTES Int -> IO ()
forall l (ptr :: * -> *) a.
(LengthUnit l, Pointer ptr) =>
ptr a -> l -> IO ()
wipeMemory Ptr Word8
cptr BYTES Int
sz
actualAction :: Ptr Word8 -> IO a
actualAction Ptr Word8
cptr = mem -> IO a
action (Ptr Word8 -> mem
getM Ptr Word8
cptr) IO a -> IO () -> IO a
forall (f :: * -> *) a b. Applicative f => f a -> f b -> f a
<* Ptr Word8 -> IO ()
wipeIt Ptr Word8
cptr
withSecureMemory :: Memory mem => (mem -> IO a) -> IO a
withSecureMemory :: (mem -> IO a) -> IO a
withSecureMemory = TwistRF AllocField (BYTES Int) mem -> (mem -> IO a) -> IO a
forall l (ptr :: * -> *) a b b.
(LengthUnit l, Pointer ptr) =>
TwistRF (WrappedArrow (->) (ptr a)) l b -> (b -> IO b) -> IO b
withSM TwistRF AllocField (BYTES Int) mem
forall m. Memory m => Alloc m
memoryAlloc
where
withSM :: TwistRF (WrappedArrow (->) (ptr a)) l b -> (b -> IO b) -> IO b
withSM TwistRF (WrappedArrow (->) (ptr a)) l b
alctr b -> IO b
action = l -> (ptr a -> IO b) -> IO b
forall l (ptr :: * -> *) something b.
(LengthUnit l, Pointer ptr) =>
l -> (ptr something -> IO b) -> IO b
allocaSecure l
sz ((ptr a -> IO b) -> IO b) -> (ptr a -> IO b) -> IO b
forall a b. (a -> b) -> a -> b
$ b -> IO b
action (b -> IO b) -> (ptr a -> b) -> ptr a -> IO b
forall b c a. (b -> c) -> (a -> b) -> a -> c
. ptr a -> b
getM
where sz :: l
sz = TwistRF (WrappedArrow (->) (ptr a)) l b -> l
forall (f :: * -> *) m a. TwistRF f m a -> m
twistMonoidValue TwistRF (WrappedArrow (->) (ptr a)) l b
alctr
getM :: ptr a -> b
getM = Field (ptr a) b -> ptr a -> b
forall space b. Field space b -> space -> b
computeField (Field (ptr a) b -> ptr a -> b) -> Field (ptr a) b -> ptr a -> b
forall a b. (a -> b) -> a -> b
$ TwistRF (WrappedArrow (->) (ptr a)) l b -> Field (ptr a) b
forall (f :: * -> *) m a. TwistRF f m a -> f a
twistFunctorValue TwistRF (WrappedArrow (->) (ptr a)) l b
alctr
class Memory m => Initialisable m v where
initialise :: v -> m -> IO ()
class Memory m => m v where
:: m -> IO v
modifyMem :: (Initialisable mem a, Extractable mem b) => (b -> a) -> mem -> IO ()
modifyMem :: (b -> a) -> mem -> IO ()
modifyMem b -> a
f mem
mem = mem -> IO b
forall m v. Extractable m v => m -> IO v
extract mem
mem IO b -> (b -> IO ()) -> IO ()
forall (m :: * -> *) a b. Monad m => m a -> (a -> m b) -> m b
>>= (a -> mem -> IO ()) -> mem -> a -> IO ()
forall a b c. (a -> b -> c) -> b -> a -> c
flip a -> mem -> IO ()
forall m v. Initialisable m v => v -> m -> IO ()
initialise mem
mem (a -> IO ()) -> (b -> a) -> b -> IO ()
forall b c a. (b -> c) -> (a -> b) -> a -> c
. b -> a
f
data Access = Access
{ Access -> Ptr Word8
accessPtr :: Ptr Word8
, Access -> BYTES Int
accessSize :: BYTES Int
}
memTransfer :: (ReadAccessible src, WriteAccessible dest)
=> Dest dest
-> Src src
-> IO ()
memTransfer :: Dest dest -> Src src -> IO ()
memTransfer Dest dest
dest Src src
src = do
let dmem :: dest
dmem = Dest dest -> dest
forall a. Dest a -> a
unDest Dest dest
dest
smem :: src
smem = Src src -> src
forall a. Src a -> a
unSrc Src src
src
in do src -> IO ()
forall mem. ReadAccessible mem => mem -> IO ()
beforeReadAdjustment src
smem
[Access] -> [Access] -> IO ()
copyAccessList (dest -> [Access]
forall mem. WriteAccessible mem => mem -> [Access]
writeAccess dest
dmem) (src -> [Access]
forall mem. ReadAccessible mem => mem -> [Access]
readAccess src
smem)
dest -> IO ()
forall mem. WriteAccessible mem => mem -> IO ()
afterWriteAdjustment dest
dmem
copyAccessList :: [Access] -> [Access] -> IO ()
copyAccessList :: [Access] -> [Access] -> IO ()
copyAccessList (Access
da:[Access]
ds) (Access
sa:[Access]
ss)
| BYTES Int
dsize BYTES Int -> BYTES Int -> Bool
forall a. Ord a => a -> a -> Bool
> BYTES Int
ssize = IO ()
tAct IO () -> IO () -> IO ()
forall (m :: * -> *) a b. Monad m => m a -> m b -> m b
>> [Access] -> [Access] -> IO ()
copyAccessList (Access
da' Access -> [Access] -> [Access]
forall a. a -> [a] -> [a]
: [Access]
ds) [Access]
ss
| BYTES Int
ssize BYTES Int -> BYTES Int -> Bool
forall a. Ord a => a -> a -> Bool
> BYTES Int
dsize = IO ()
tAct IO () -> IO () -> IO ()
forall (m :: * -> *) a b. Monad m => m a -> m b -> m b
>> [Access] -> [Access] -> IO ()
copyAccessList [Access]
ds (Access
sa' Access -> [Access] -> [Access]
forall a. a -> [a] -> [a]
: [Access]
ss)
| Bool
otherwise = IO ()
tAct IO () -> IO () -> IO ()
forall (m :: * -> *) a b. Monad m => m a -> m b -> m b
>> [Access] -> [Access] -> IO ()
copyAccessList [Access]
ds [Access]
ss
where dsize :: BYTES Int
dsize = Access -> BYTES Int
accessSize Access
da
ssize :: BYTES Int
ssize = Access -> BYTES Int
accessSize Access
sa
trans :: BYTES Int
trans = BYTES Int -> BYTES Int -> BYTES Int
forall a. Ord a => a -> a -> a
min BYTES Int
dsize BYTES Int
ssize
dptr :: Ptr Word8
dptr = Access -> Ptr Word8
accessPtr Access
da
sptr :: Ptr Word8
sptr = Access -> Ptr Word8
accessPtr Access
sa
da' :: Access
da' = Ptr Word8 -> BYTES Int -> Access
Access (Access -> Ptr Word8
accessPtr Access
da Ptr Word8 -> BYTES Int -> Ptr Word8
forall l a. LengthUnit l => Ptr a -> l -> Ptr a
`movePtr` BYTES Int
trans) (BYTES Int
dsize BYTES Int -> BYTES Int -> BYTES Int
forall a. Num a => a -> a -> a
- BYTES Int
trans)
sa' :: Access
sa' = Ptr Word8 -> BYTES Int -> Access
Access (Access -> Ptr Word8
accessPtr Access
sa Ptr Word8 -> BYTES Int -> Ptr Word8
forall l a. LengthUnit l => Ptr a -> l -> Ptr a
`movePtr` BYTES Int
trans) (BYTES Int
ssize BYTES Int -> BYTES Int -> BYTES Int
forall a. Num a => a -> a -> a
- BYTES Int
trans)
tAct :: IO ()
tAct = Dest (Ptr Word8) -> Src (Ptr Word8) -> BYTES Int -> IO ()
forall l (ptrS :: * -> *) (ptrD :: * -> *) dest src.
(LengthUnit l, Pointer ptrS, Pointer ptrD) =>
Dest (ptrD dest) -> Src (ptrS src) -> l -> IO ()
memcpy (Ptr Word8 -> Dest (Ptr Word8)
forall a. a -> Dest a
destination Ptr Word8
dptr) (Ptr Word8 -> Src (Ptr Word8)
forall a. a -> Src a
source Ptr Word8
sptr) BYTES Int
trans
copyAccessList [Access]
_ [Access]
_ = () -> IO ()
forall (m :: * -> *) a. Monad m => a -> m a
return ()
class Memory mem => ReadAccessible mem where
beforeReadAdjustment :: mem -> IO ()
readAccess :: mem -> [Access]
class Memory mem => WriteAccessible mem where
writeAccess :: mem -> [Access]
afterWriteAdjustment :: mem -> IO ()
newtype MemoryCell a = MemoryCell { MemoryCell a -> Ptr a
unMemoryCell :: Ptr a }
instance Storable a => Memory (MemoryCell a) where
memoryAlloc :: Alloc (MemoryCell a)
memoryAlloc = a -> Alloc (MemoryCell a)
forall b. Storable b => b -> Alloc (MemoryCell b)
allocator a
forall a. HasCallStack => a
undefined
where allocator :: Storable b => b -> Alloc (MemoryCell b)
allocator :: b -> Alloc (MemoryCell b)
allocator b
b = BYTES Int -> (Ptr Word8 -> MemoryCell b) -> Alloc (MemoryCell b)
forall l mem. LengthUnit l => l -> (Ptr Word8 -> mem) -> Alloc mem
makeAlloc (Proxy b -> BYTES Int
forall a. Storable a => Proxy a -> BYTES Int
alignedSizeOf (Proxy b -> BYTES Int) -> Proxy b -> BYTES Int
forall a b. (a -> b) -> a -> b
$ b -> Proxy b
forall (f :: * -> *) a. Applicative f => a -> f a
pure b
b) ((Ptr Word8 -> MemoryCell b) -> Alloc (MemoryCell b))
-> (Ptr Word8 -> MemoryCell b) -> Alloc (MemoryCell b)
forall a b. (a -> b) -> a -> b
$ Ptr b -> MemoryCell b
forall a. Ptr a -> MemoryCell a
MemoryCell (Ptr b -> MemoryCell b)
-> (Ptr Word8 -> Ptr b) -> Ptr Word8 -> MemoryCell b
forall b c a. (b -> c) -> (a -> b) -> a -> c
. Ptr Word8 -> Ptr b
forall a b. Ptr a -> Ptr b
castPtr
unsafeToPointer :: MemoryCell a -> Ptr Word8
unsafeToPointer = Ptr a -> Ptr Word8
forall a b. Ptr a -> Ptr b
castPtr (Ptr a -> Ptr Word8)
-> (MemoryCell a -> Ptr a) -> MemoryCell a -> Ptr Word8
forall b c a. (b -> c) -> (a -> b) -> a -> c
. MemoryCell a -> Ptr a
forall a. MemoryCell a -> Ptr a
unMemoryCell
unsafeGetCellPointer :: Storable a => MemoryCell a -> Ptr a
unsafeGetCellPointer :: MemoryCell a -> Ptr a
unsafeGetCellPointer = Ptr a -> Ptr a
forall a. Storable a => Ptr a -> Ptr a
nextLocation (Ptr a -> Ptr a)
-> (MemoryCell a -> Ptr a) -> MemoryCell a -> Ptr a
forall b c a. (b -> c) -> (a -> b) -> a -> c
. MemoryCell a -> Ptr a
forall a. MemoryCell a -> Ptr a
unMemoryCell
withCellPointer :: Storable a => (Ptr a -> IO b) -> MemoryCell a -> IO b
{-# INLINE withCellPointer #-}
withCellPointer :: (Ptr a -> IO b) -> MemoryCell a -> IO b
withCellPointer Ptr a -> IO b
action = Ptr a -> IO b
action (Ptr a -> IO b) -> (MemoryCell a -> Ptr a) -> MemoryCell a -> IO b
forall b c a. (b -> c) -> (a -> b) -> a -> c
. MemoryCell a -> Ptr a
forall a. Storable a => MemoryCell a -> Ptr a
unsafeGetCellPointer
copyCell :: Storable a => Dest (MemoryCell a) -> Src (MemoryCell a) -> IO ()
copyCell :: Dest (MemoryCell a) -> Src (MemoryCell a) -> IO ()
copyCell Dest (MemoryCell a)
dest Src (MemoryCell a)
src = Dest (Ptr a) -> Src (Ptr a) -> BYTES Int -> IO ()
forall l (ptrS :: * -> *) (ptrD :: * -> *) dest src.
(LengthUnit l, Pointer ptrS, Pointer ptrD) =>
Dest (ptrD dest) -> Src (ptrS src) -> l -> IO ()
memcpy (MemoryCell a -> Ptr a
forall a. Storable a => MemoryCell a -> Ptr a
unsafeGetCellPointer (MemoryCell a -> Ptr a) -> Dest (MemoryCell a) -> Dest (Ptr a)
forall (f :: * -> *) a b. Functor f => (a -> b) -> f a -> f b
<$> Dest (MemoryCell a)
dest) (MemoryCell a -> Ptr a
forall a. Storable a => MemoryCell a -> Ptr a
unsafeGetCellPointer (MemoryCell a -> Ptr a) -> Src (MemoryCell a) -> Src (Ptr a)
forall (f :: * -> *) a b. Functor f => (a -> b) -> f a -> f b
<$> Src (MemoryCell a)
src) BYTES Int
sz
where getProxy :: Dest (MemoryCell a) -> Proxy a
getProxy :: Dest (MemoryCell a) -> Proxy a
getProxy Dest (MemoryCell a)
_ = Proxy a
forall k (t :: k). Proxy t
Proxy
sz :: BYTES Int
sz = Proxy a -> BYTES Int
forall a. Storable a => Proxy a -> BYTES Int
sizeOf (Dest (MemoryCell a) -> Proxy a
forall a. Dest (MemoryCell a) -> Proxy a
getProxy Dest (MemoryCell a)
dest)
instance Storable a => Initialisable (MemoryCell a) a where
initialise :: a -> MemoryCell a -> IO ()
initialise a
a = (Ptr a -> a -> IO ()) -> a -> Ptr a -> IO ()
forall a b c. (a -> b -> c) -> b -> a -> c
flip Ptr a -> a -> IO ()
forall a. Storable a => Ptr a -> a -> IO ()
pokeAligned a
a (Ptr a -> IO ())
-> (MemoryCell a -> Ptr a) -> MemoryCell a -> IO ()
forall b c a. (b -> c) -> (a -> b) -> a -> c
. MemoryCell a -> Ptr a
forall a. MemoryCell a -> Ptr a
unMemoryCell
{-# INLINE initialise #-}
instance Storable a => Extractable (MemoryCell a) a where
extract :: MemoryCell a -> IO a
extract = Ptr a -> IO a
forall a. Storable a => Ptr a -> IO a
peekAligned (Ptr a -> IO a) -> (MemoryCell a -> Ptr a) -> MemoryCell a -> IO a
forall b c a. (b -> c) -> (a -> b) -> a -> c
. MemoryCell a -> Ptr a
forall a. MemoryCell a -> Ptr a
unMemoryCell
{-# INLINE extract #-}
memCellToAccess :: EndianStore a => MemoryCell a -> [Access]
memCellToAccess :: MemoryCell a -> [Access]
memCellToAccess MemoryCell a
mem = [ Access :: Ptr Word8 -> BYTES Int -> Access
Access { accessPtr :: Ptr Word8
accessPtr = Ptr a -> Ptr Word8
forall a b. Ptr a -> Ptr b
castPtr (Ptr a -> Ptr Word8) -> Ptr a -> Ptr Word8
forall a b. (a -> b) -> a -> b
$ MemoryCell a -> Ptr a
forall a. Storable a => MemoryCell a -> Ptr a
unsafeGetCellPointer MemoryCell a
mem
, accessSize :: BYTES Int
accessSize = Proxy a -> BYTES Int
forall a. Storable a => Proxy a -> BYTES Int
sizeOf (Proxy a -> BYTES Int) -> Proxy a -> BYTES Int
forall a b. (a -> b) -> a -> b
$ MemoryCell a -> Proxy a
forall a. MemoryCell a -> Proxy a
getProxy MemoryCell a
mem
}
]
where getProxy :: MemoryCell a -> Proxy a
getProxy :: MemoryCell a -> Proxy a
getProxy MemoryCell a
_ = Proxy a
forall k (t :: k). Proxy t
Proxy
instance EndianStore a => ReadAccessible (MemoryCell a) where
beforeReadAdjustment :: MemoryCell a -> IO ()
beforeReadAdjustment MemoryCell a
mem = Ptr a -> Int -> IO ()
forall w. EndianStore w => Ptr w -> Int -> IO ()
adjustEndian (MemoryCell a -> Ptr a
forall a. Storable a => MemoryCell a -> Ptr a
unsafeGetCellPointer MemoryCell a
mem) Int
1
readAccess :: MemoryCell a -> [Access]
readAccess = MemoryCell a -> [Access]
forall a. EndianStore a => MemoryCell a -> [Access]
memCellToAccess
instance EndianStore a => WriteAccessible (MemoryCell a) where
writeAccess :: MemoryCell a -> [Access]
writeAccess = MemoryCell a -> [Access]
forall a. EndianStore a => MemoryCell a -> [Access]
memCellToAccess
afterWriteAdjustment :: MemoryCell a -> IO ()
afterWriteAdjustment MemoryCell a
mem = Ptr a -> Int -> IO ()
forall w. EndianStore w => Ptr w -> Int -> IO ()
adjustEndian (MemoryCell a -> Ptr a
forall a. Storable a => MemoryCell a -> Ptr a
unsafeGetCellPointer MemoryCell a
mem) Int
1