Coverage Report

Created: 2021-04-07 06:07

/src/botan/build/include/botan/internal/cast128.h
Line
Count
Source (jump to first uncovered line)
1
/*
2
* CAST-128
3
* (C) 1999-2007 Jack Lloyd
4
*
5
* Botan is released under the Simplified BSD License (see license.txt)
6
*/
7
8
#ifndef BOTAN_CAST128_H_
9
#define BOTAN_CAST128_H_
10
11
#include <botan/block_cipher.h>
12
13
namespace Botan {
14
15
/**
16
* CAST-128
17
*/
18
class CAST_128 final : public Block_Cipher_Fixed_Params<8, 11, 16>
19
   {
20
   public:
21
      void encrypt_n(const uint8_t in[], uint8_t out[], size_t blocks) const override;
22
      void decrypt_n(const uint8_t in[], uint8_t out[], size_t blocks) const override;
23
24
      void clear() override;
25
0
      std::string name() const override { return "CAST-128"; }
26
0
      std::unique_ptr<BlockCipher> new_object() const override { return std::make_unique<CAST_128>(); }
27
28
   private:
29
      void key_schedule(const uint8_t[], size_t) override;
30
31
      static void cast_ks(secure_vector<uint32_t>& ks,
32
                          secure_vector<uint32_t>& user_key);
33
34
      secure_vector<uint32_t> m_MK;
35
      secure_vector<uint8_t> m_RK;
36
   };
37
38
}
39
40
#endif