|
Crypto++
5.6.4
Free C++ class library of cryptographic schemes
|
Inheritance diagram for Whirlpool:Public Member Functions | |
| void | TruncatedFinal (byte *hash, size_t size) |
| Computes the hash of the current message. More... | |
Public Member Functions inherited from IteratedHashWithStaticTransform< word64, BigEndian, 64, 64, Whirlpool > | |
| unsigned int | DigestSize () const |
| Provides the digest size of the hash. More... | |
Public Member Functions inherited from ClonableImpl< Whirlpool, AlgorithmImpl< IteratedHash< word64, BigEndian, T_BlockSize >, Whirlpool > > | |
| Clonable * | Clone () const |
Public Member Functions inherited from AlgorithmImpl< IteratedHash< word64, BigEndian, T_BlockSize >, Whirlpool > | |
| std::string | AlgorithmName () const |
Public Member Functions inherited from IteratedHash< word64, BigEndian, T_BlockSize > | |
| unsigned int | BlockSize () const |
| ByteOrder | GetByteOrder () const |
Public Member Functions inherited from IteratedHashBase< word64, HashTransformation > | |
| unsigned int | OptimalBlockSize () const |
| unsigned int | OptimalDataAlignment () const |
| void | Update (const byte *input, size_t length) |
| byte * | CreateUpdateSpace (size_t &size) |
| void | Restart () |
| void | TruncatedFinal (byte *digest, size_t size) |
Public Member Functions inherited from HashTransformation | |
| HashTransformation & | Ref () |
| Provides a reference to this object. 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 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... | |
Public Member Functions inherited from Algorithm | |
| Algorithm (bool checkSelfTestStatus=true) | |
| Interface for all crypto algorithms. More... | |
Static Public Member Functions | |
| static void | InitState (HashWordType *state) |
| The Whirlpool hashing function. More... | |
| static void | Transform (word64 *digest, const word64 *data) |
| static const char * | StaticAlgorithmName () |
Static Public Member Functions inherited from AlgorithmImpl< IteratedHash< word64, BigEndian, T_BlockSize >, Whirlpool > | |
| static std::string | StaticAlgorithmName () |
Static Public Member Functions inherited from IteratedHash< word64, BigEndian, T_BlockSize > | |
| static void | CorrectEndianess (HashWordType *out, const HashWordType *in, size_t byteCount) |
Additional Inherited Members | |
Public Types inherited from IteratedHash< word64, BigEndian, T_BlockSize > | |
| typedef BigEndian | ByteOrderClass |
| typedef word64 | HashWordType |
Public Types inherited from IteratedHashBase< word64, HashTransformation > | |
| typedef word64 | HashWordType |
Static Public Attributes inherited from IteratedHashWithStaticTransform< word64, BigEndian, 64, 64, Whirlpool > | |
| static const int | DIGESTSIZE |
Static Public Attributes inherited from IteratedHash< word64, BigEndian, T_BlockSize > | |
| static const int | BLOCKSIZE |
Definition at line 10 of file whrlpool.h.
|
static |
The Whirlpool hashing function.
References
The Whirlpool algorithm was developed by Paulo S. L. M. Barreto and Vincent Rijmen.
See P.S.L.M. Barreto, V. Rijmen, ``The Whirlpool hashing function,'' NESSIE submission, 2000 (tweaked version, 2001), https://www.cosic.esat.kuleuven.ac.be/nessie/workshop/submissions/whirlpool.zip
=============================================================================
Differences from version 2.1:
=============================================================================
Differences from version 2.0:
Differences from version 1.0:
=============================================================================
THIS SOFTWARE IS PROVIDED BY THE AUTHORS ''AS IS'' AND ANY EXPRESS OR IMPLIED WARRANTIES, INCLUDING, BUT NOT LIMITED TO, THE IMPLIED WARRANTIES OF MERCHANTABILITY AND FITNESS FOR A PARTICULAR PURPOSE ARE DISCLAIMED. IN NO EVENT SHALL THE AUTHORS OR CONTRIBUTORS BE LIABLE FOR ANY DIRECT, INDIRECT, INCIDENTAL, SPECIAL, EXEMPLARY, OR CONSEQUENTIAL DAMAGES (INCLUDING, BUT NOT LIMITED TO, PROCUREMENT OF SUBSTITUTE GOODS OR SERVICES; LOSS OF USE, DATA, OR PROFITS; OR BUSINESS INTERRUPTION) HOWEVER CAUSED AND ON ANY THEORY OF LIABILITY, WHETHER IN CONTRACT, STRICT LIABILITY, OR TORT (INCLUDING NEGLIGENCE OR OTHERWISE) ARISING IN ANY WAY OUT OF THE USE OF THIS SOFTWARE, EVEN IF ADVISED OF THE POSSIBILITY OF SUCH DAMAGE.
Definition at line 95 of file whrlpool.cpp.
|
virtual |
Computes the hash of the current message.
| digest | a pointer to the buffer to receive the hash |
| digestSize | the size of the truncated digest, in bytes |
TruncatedFinal() call Final() and then copies digestSize bytes to digest
TruncatedFinal() restarts the hash for the next message.
COUNTOF(digest) == DigestSize() or COUNTOF(digest) == HASH::DIGESTSIZE ensures the output byte buffer is large enough for the digest. Implements HashTransformation.
Definition at line 100 of file whrlpool.cpp.
1.8.13