You can not select more than 25 topics
Topics must start with a letter or number, can include dashes ('-') and can be up to 35 characters long.
61 lines
2.7 KiB
61 lines
2.7 KiB
// sm3.h - written and placed in the public domain by Jeffrey Walton and Han Lulu |
|
// Based on the specification provided by Sean Shen and Xiaodong Lee. |
|
// Based on code by Krzysztof Kwiatkowski and Jack Lloyd. |
|
// Also see https://tools.ietf.org/html/draft-shen-sm3-hash. |
|
|
|
/// \file sm3.h |
|
/// \brief Classes for the SM3 hash function |
|
/// \details SM3 is a hash function designed by Xiaoyun Wang, et al. The hash is part of the |
|
/// Chinese State Cryptography Administration portfolio. |
|
/// \sa <A HREF="https://tools.ietf.org/html/draft-shen-sm3-hash">SM3 Hash Function</A> and |
|
/// <A HREF="http://github.com/guanzhi/GmSSL">Reference implementation using OpenSSL</A>. |
|
/// \since Crypto++ 6.0 |
|
|
|
#ifndef CRYPTOPP_SM3_H |
|
#define CRYPTOPP_SM3_H |
|
|
|
#include "config.h" |
|
#include "iterhash.h" |
|
|
|
NAMESPACE_BEGIN(CryptoPP) |
|
|
|
/// \brief SM3 hash function |
|
/// \details SM3 is a hash function designed by Xiaoyun Wang, et al. The hash is part of the |
|
/// Chinese State Cryptography Administration portfolio. |
|
/// \sa <A HREF="https://tools.ietf.org/html/draft-shen-sm3-hash">SM3 Hash Function</A> |
|
/// \since Crypto++ 6.0 |
|
class SM3 : public IteratedHashWithStaticTransform<word32, BigEndian, 64, 32, SM3, 32, true> |
|
{ |
|
public: |
|
/// \brief Initialize state array |
|
/// \param state the state of the hash |
|
/// \details InitState sets a state array to SHA256 initial values |
|
/// \details Hashes which derive from IteratedHashWithStaticTransform provide static |
|
/// member functions InitState() and Transform(). External classes, like SEAL and MDC, |
|
/// can initialize state with a user provided key and operate the hash on the data |
|
/// with the user supplied state. |
|
static void InitState(HashWordType *state); |
|
|
|
/// \brief Operate the hash |
|
/// \param digest the state of the hash |
|
/// \param data the data to be digested |
|
/// \details Transform() operates the hash on <tt>data</tt>. When the call is invoked |
|
/// <tt>digest</tt> holds initial or current state. Upon return <tt>digest</tt> holds |
|
/// the hash or updated state. |
|
/// \details Hashes which derive from IteratedHashWithStaticTransform provide static |
|
/// member functions InitState() and Transform(). External classes, like SEAL and MDC, |
|
/// can initialize state with a user provided key and operate the hash on the data |
|
/// with the user supplied state. |
|
static void Transform(HashWordType *digest, const HashWordType *data); |
|
|
|
/// \brief The algorithm name |
|
/// \returns C-style string "SM3" |
|
CRYPTOPP_STATIC_CONSTEXPR const char* StaticAlgorithmName() { return "SM3"; } |
|
|
|
protected: |
|
size_t HashMultipleBlocks(const HashWordType *input, size_t length); |
|
}; |
|
|
|
NAMESPACE_END |
|
|
|
#endif // CRYPTOPP_SM3_H
|
|
|