Coverage Report

Created: 2021-04-07 06:07

/src/botan/build/include/botan/internal/sm3.h
Line
Count
Source (jump to first uncovered line)
1
/*
2
* SM3
3
* (C) 2017 Ribose Inc.
4
*
5
* Botan is released under the Simplified BSD License (see license.txt)
6
*/
7
8
#ifndef BOTAN_SM3_H_
9
#define BOTAN_SM3_H_
10
11
#include <botan/internal/mdx_hash.h>
12
13
namespace Botan {
14
15
enum {
16
  SM3_BLOCK_BYTES = 64,
17
  SM3_DIGEST_BYTES = 32
18
};
19
20
/**
21
* SM3
22
*/
23
class SM3 final : public MDx_HashFunction
24
   {
25
   public:
26
0
      std::string name() const override { return "SM3"; }
27
0
      size_t output_length() const override { return SM3_DIGEST_BYTES; }
28
0
      std::unique_ptr<HashFunction> new_object() const override { return std::make_unique<SM3>(); }
29
      std::unique_ptr<HashFunction> copy_state() const override;
30
31
      void clear() override;
32
33
      SM3() : MDx_HashFunction(SM3_BLOCK_BYTES, true, true), m_digest(SM3_DIGEST_BYTES)
34
0
         { clear(); }
35
   private:
36
      void compress_n(const uint8_t[], size_t blocks) override;
37
      void copy_out(uint8_t[]) override;
38
39
      /**
40
      * The digest value
41
      */
42
      secure_vector<uint32_t> m_digest;
43
   };
44
45
}
46
47
#endif