|
| | BLAKE2b (bool treeMode=false, unsigned int digestSize=DIGESTSIZE) |
| | Construct a BLAKE2b hash. More...
|
| |
| | BLAKE2b (unsigned int digestSize) |
| | Construct a BLAKE2s hash. More...
|
| |
| | BLAKE2b (const byte *key, size_t keyLength, const byte *salt=NULL, size_t saltLength=0, const byte *personalization=NULL, size_t personalizationLength=0, bool treeMode=false, unsigned int digestSize=DIGESTSIZE) |
| | Construct a BLAKE2b hash. More...
|
| |
| std::string | AlgorithmName () const |
| | Retrieve the object's name. More...
|
| |
| unsigned int | BlockSize () const |
| | Provides the block size of the compression function. More...
|
| |
| unsigned int | DigestSize () const |
| | Provides the digest size of the hash. More...
|
| |
| unsigned int | OptimalDataAlignment () const |
| | Provides input and output data alignment for optimal performance. More...
|
| |
| void | Update (const byte *input, size_t length) |
| | Updates a hash with additional input. More...
|
| |
| void | Restart () |
| | Restart the hash. More...
|
| |
| void | Restart (const BLAKE2b_ParameterBlock &block, const word64 counter[2]) |
| | Restart a hash with parameter block and counter. More...
|
| |
| void | SetTreeMode (bool mode) |
| | Set tree mode. More...
|
| |
| bool | GetTreeMode () const |
| | Get tree mode. More...
|
| |
| void | TruncatedFinal (byte *hash, size_t size) |
| | Computes the hash of the current message. More...
|
| |
| std::string | AlgorithmProvider () const |
| | Retrieve the provider of this algorithm. More...
|
| |
| size_t | MinKeyLength () const |
| | The minimum key length used by the algorithm. More...
|
| |
| size_t | MaxKeyLength () const |
| | The maximum key length used by the algorithm. More...
|
| |
| size_t | DefaultKeyLength () const |
| | The default key length used by the algorithm. More...
|
| |
| size_t | GetValidKeyLength (size_t keylength) const |
| | Provides a valid key length for the algorithm. More...
|
| |
| SimpleKeyingInterface::IV_Requirement | IVRequirement () const |
| | The default IV requirements for the algorithm. More...
|
| |
| unsigned int | IVSize () const |
| | The initialization vector length for the algorithm. More...
|
| |
| virtual bool | IsValidKeyLength (size_t keylength) const |
| | Returns whether keylength is a valid key length. More...
|
| |
| virtual void | SetKey (const byte *key, size_t length, const NameValuePairs ¶ms=g_nullNameValuePairs) |
| | Sets or reset the key of this object. More...
|
| |
| void | SetKeyWithRounds (const byte *key, size_t length, int rounds) |
| | Sets or reset the key of this object. More...
|
| |
| void | SetKeyWithIV (const byte *key, size_t length, const byte *iv, size_t ivLength) |
| | Sets or reset the key of this object. More...
|
| |
| void | SetKeyWithIV (const byte *key, size_t length, const byte *iv) |
| | Sets or reset the key of this object. More...
|
| |
| bool | IsResynchronizable () const |
| | Determines if the object can be resynchronized. More...
|
| |
| bool | CanUseRandomIVs () const |
| | Determines if the object can use random IVs. More...
|
| |
| bool | CanUsePredictableIVs () const |
| | Determines if the object can use random but possibly predictable IVs. More...
|
| |
| bool | CanUseStructuredIVs () const |
| | Determines if the object can use structured IVs. More...
|
| |
| unsigned int | DefaultIVLength () const |
| | Provides the default size of an IV. More...
|
| |
| virtual unsigned int | MinIVLength () const |
| | Provides the minimum size of an IV. More...
|
| |
| virtual unsigned int | MaxIVLength () const |
| | Provides the maximum size of an IV. More...
|
| |
| virtual void | Resynchronize (const byte *iv, int ivLength=-1) |
| | Resynchronize with an IV. More...
|
| |
| virtual void | GetNextIV (RandomNumberGenerator &rng, byte *iv) |
| | Retrieves a secure IV for the next message. More...
|
| |
| HashTransformation & | Ref () |
| | Provides a reference to this object. More...
|
| |
| virtual byte * | CreateUpdateSpace (size_t &size) |
| | Request space which can be written into by the caller. More...
|
| |
| virtual void | Final (byte *digest) |
| | Computes the hash of the current message. More...
|
| |
| unsigned int | TagSize () const |
| | Provides the tag size of the hash. More...
|
| |
| virtual unsigned int | OptimalBlockSize () const |
| | Provides the input block size most efficient for this hash. More...
|
| |
| virtual void | CalculateDigest (byte *digest, const byte *input, size_t length) |
| | Updates the hash with additional input and computes the hash of the current message. More...
|
| |
| virtual bool | Verify (const byte *digest) |
| | Verifies the hash of the current message. More...
|
| |
| virtual bool | VerifyDigest (const byte *digest, const byte *input, size_t length) |
| | Updates the hash with additional input and verifies the hash of the current message. More...
|
| |
| virtual void | CalculateTruncatedDigest (byte *digest, size_t digestSize, const byte *input, size_t length) |
| | Updates the hash with additional input and computes the hash of the current message. More...
|
| |
| virtual bool | TruncatedVerify (const byte *digest, size_t digestLength) |
| | Verifies the hash of the current message. More...
|
| |
| virtual bool | VerifyTruncatedDigest (const byte *digest, size_t digestLength, const byte *input, size_t length) |
| | Updates the hash with additional input and verifies the hash of the current message. More...
|
| |
| | Algorithm (bool checkSelfTestStatus=true) |
| | Interface for all crypto algorithms. More...
|
| |
| virtual Clonable * | Clone () const |
| | Copies this object. More...
|
| |
The BLAKE2b cryptographic hash function.
BLAKE2b can function as both a hash and keyed hash. If you want only the hash, then use the BLAKE2b constructor that accepts no parameters or digest size. If you want a keyed hash, then use the constructor that accpts the key as a parameter. Once a key and digest size are selected, its effectively immutable. The Restart() method that accepts a ParameterBlock does not allow you to change it.
- See also
- Aumasson, Neves, Wilcox-O'Hearn and Winnerlein's BLAKE2: simpler, smaller, fast as MD5 (2013.01.29).
- Since
- C++ since Crypto++ 5.6.4, SSE since Crypto++ 5.6.4, NEON since Crypto++ 6.0, Power8 since Crypto++ 8.0
Definition at line 344 of file blake2.h.
| std::string BLAKE2b::AlgorithmProvider |
( |
| ) |
const |
|
virtual |
Retrieve the provider of this algorithm.
- Returns
- the algorithm provider
The algorithm provider can be a name like "C++", "SSE", "NEON", "AESNI", "ARMv8" and "Power8". C++ is standard C++ code. Other labels, like SSE, usually indicate a specialized implementation using instructions from a higher instruction set architecture (ISA). Future labels may include external hardware like a hardware security module (HSM).
Generally speaking Wei Dai's original IA-32 ASM code falls under "SSE2". Labels like "SSSE3" and "SSE4.1" follow after Wei's code and use intrinsics instead of ASM.
Algorithms which combine different instructions or ISAs provide the dominant one. For example on x86 AES/GCM returns "AESNI" rather than "CLMUL" or "AES+SSE4.1" or "AES+CLMUL" or "AES+SSE4.1+CLMUL".
- Note
- Provider is not universally implemented yet.
- Since
- Crypto++ 8.0
Reimplemented from Algorithm.
Definition at line 212 of file blake2.cpp.