-- | -- Module : Crypto.Hash.BLAKE2bp -- License : BSD-style -- Maintainer : Vincent Hanquez -- Stability : experimental -- Portability : unknown -- -- module containing the binding functions to work with the -- BLAKE2bp cryptographic hash. -- {-# LANGUAGE ForeignFunctionInterface #-} module Crypto.Hash.BLAKE2bp ( BLAKE2bp (..) ) where import Crypto.Hash.Types import Foreign.Ptr (Ptr) import Data.Word (Word8, Word32) -- | BLAKE2bp cryptographic hash algorithm data BLAKE2bp = BLAKE2bp deriving (Show) instance HashAlgorithm BLAKE2bp where hashBlockSize _ = 128 hashDigestSize _ = 64 hashInternalContextSize _ = 2325 hashInternalInit = c_blake2sp_init hashInternalUpdate = c_blake2sp_update hashInternalFinalize = c_blake2sp_finalize foreign import ccall unsafe "cryptonite_blake2sp_init" c_blake2sp_init :: Ptr (Context a)-> IO () foreign import ccall "cryptonite_blake2sp_update" c_blake2sp_update :: Ptr (Context a) -> Ptr Word8 -> Word32 -> IO () foreign import ccall unsafe "cryptonite_blake2sp_finalize" c_blake2sp_finalize :: Ptr (Context a) -> Ptr (Digest a) -> IO ()