Crypto++ 8.7
Free C++ class library of cryptographic schemes
rijndael.h
Go to the documentation of this file.
1// rijndael.h - originally written and placed in the public domain by Wei Dai
2
3/// \file rijndael.h
4/// \brief Classes for Rijndael encryption algorithm
5/// \details All key sizes are supported. The library only provides Rijndael with 128-bit blocks,
6/// and not 192-bit or 256-bit blocks
7/// \since Rijndael since Crypto++ 3.1, Intel AES-NI since Crypto++ 5.6.1, ARMv8 AES since Crypto++ 6.0,
8/// Power8 AES since Crypto++ 6.0, ARMv7 AES since Crypto++ 8.0
9
10#ifndef CRYPTOPP_RIJNDAEL_H
11#define CRYPTOPP_RIJNDAEL_H
12
13#include "seckey.h"
14#include "secblock.h"
15
16// Clang 3.3 integrated assembler crash on Linux. Clang 3.4 due to compiler
17// error with .intel_syntax, http://llvm.org/bugs/show_bug.cgi?id=24232
18#if CRYPTOPP_BOOL_X32 || defined(CRYPTOPP_DISABLE_MIXED_ASM)
19# define CRYPTOPP_DISABLE_RIJNDAEL_ASM 1
20#endif
21
22#if CRYPTOPP_BOOL_X64 || CRYPTOPP_BOOL_X32 || CRYPTOPP_BOOL_X86 || CRYPTOPP_BOOL_ARM32 || \
23 CRYPTOPP_BOOL_ARMV8 || CRYPTOPP_BOOL_PPC32 || CRYPTOPP_BOOL_PPC64
24# define CRYPTOPP_RIJNDAEL_ADVANCED_PROCESS_BLOCKS 1
25#endif
26
27NAMESPACE_BEGIN(CryptoPP)
28
29/// \brief Rijndael block cipher information
30/// \details All key sizes are supported. The library only provides Rijndael with 128-bit blocks,
31/// and not 192-bit or 256-bit blocks
32/// \since Rijndael since Crypto++ 3.1, Intel AES-NI since Crypto++ 5.6.1, ARMv8 AES since Crypto++ 6.0,
33/// Power8 AES since Crypto++ 6.0, ARMv7 AES since Crypto++ 8.0
34struct Rijndael_Info : public FixedBlockSize<16>, public VariableKeyLength<16, 16, 32, 8>
35{
36 CRYPTOPP_DLL static const char * CRYPTOPP_API StaticAlgorithmName() {return "AES";}
37};
38
39/// \brief Rijndael block cipher
40/// \details All key sizes are supported. The library only provides Rijndael with 128-bit blocks,
41/// and not 192-bit or 256-bit blocks
42/// \since Rijndael since Crypto++ 3.1, Intel AES-NI since Crypto++ 5.6.1, ARMv8 AES since Crypto++ 6.0,
43/// Power8 AES since Crypto++ 6.0, ARMv7 AES since Crypto++ 8.0
44/// \sa <a href="http://www.cryptopp.com/wiki/Rijndael">Rijndael</a>
45class CRYPTOPP_DLL Rijndael : public Rijndael_Info, public BlockCipherDocumentation
46{
47 /// \brief Rijndael block cipher transformation functions
48 /// \details Provides implementation common to encryption and decryption
49 class CRYPTOPP_DLL CRYPTOPP_NO_VTABLE Base : public BlockCipherImpl<Rijndael_Info>
50 {
51 public:
52 void UncheckedSetKey(const byte *userKey, unsigned int keyLength, const NameValuePairs &params);
53 std::string AlgorithmProvider() const;
54 unsigned int OptimalDataAlignment() const;
55
56 protected:
57 static void FillEncTable();
58 static void FillDecTable();
59
60 // VS2005 workaround: have to put these on separate lines, or error C2487 is triggered in DLL build
61 static const byte Se[256];
62 static const byte Sd[256];
63
64 static const word32 rcon[];
65
66 unsigned int m_rounds;
68 mutable SecByteBlock m_aliasBlock;
69 };
70
71 /// \brief Encryption transformation
72 /// \details Enc provides implementation for encryption transformation. All key sizes are supported.
73 /// The library only provides Rijndael with 128-bit blocks, and not 192-bit or 256-bit blocks
74 /// \since Rijndael since Crypto++ 3.1, Intel AES-NI since Crypto++ 5.6.1, ARMv8 AES since Crypto++ 6.0,
75 /// Power8 AES since Crypto++ 6.0, ARMv7 AES since Crypto++ 8.0
76 class CRYPTOPP_DLL CRYPTOPP_NO_VTABLE Enc : public Base
77 {
78 public:
79 void ProcessAndXorBlock(const byte *inBlock, const byte *xorBlock, byte *outBlock) const;
80#if CRYPTOPP_RIJNDAEL_ADVANCED_PROCESS_BLOCKS
81 size_t AdvancedProcessBlocks(const byte *inBlocks, const byte *xorBlocks, byte *outBlocks, size_t length, word32 flags) const;
82#endif
83 };
84
85 /// \brief Decryption transformation
86 /// \details Dec provides implementation for decryption transformation. All key sizes are supported.
87 /// The library only provides Rijndael with 128-bit blocks, and not 192-bit or 256-bit blocks
88 /// \since Rijndael since Crypto++ 3.1, Intel AES-NI since Crypto++ 5.6.1, ARMv8 AES since Crypto++ 6.0,
89 /// Power8 AES since Crypto++ 6.0, ARMv7 AES since Crypto++ 8.0
90 class CRYPTOPP_DLL CRYPTOPP_NO_VTABLE Dec : public Base
91 {
92 public:
93 void ProcessAndXorBlock(const byte *inBlock, const byte *xorBlock, byte *outBlock) const;
94#if CRYPTOPP_RIJNDAEL_ADVANCED_PROCESS_BLOCKS
95 size_t AdvancedProcessBlocks(const byte *inBlocks, const byte *xorBlocks, byte *outBlocks, size_t length, word32 flags) const;
96#endif
97 };
98
99public:
102};
103
106
107NAMESPACE_END
108
109#endif
Provides a base implementation of Algorithm and SimpleKeyingInterface for block ciphers.
Definition: seckey.h:306
Inherited by algorithms with fixed block size.
Definition: seckey.h:41
Interface for retrieving values given their names.
Definition: cryptlib.h:322
Rijndael block cipher.
Definition: rijndael.h:46
Secure memory block with allocator and cleanup.
Definition: secblock.h:731
SecBlock<byte> typedef.
Definition: secblock.h:1226
Inherited by keyed algorithms with variable key length.
Definition: seckey.h:166
#define CRYPTOPP_API
Win32 calling convention.
Definition: config_dll.h:119
unsigned int word32
32-bit unsigned datatype
Definition: config_int.h:62
Crypto++ library namespace.
Classes and functions for secure memory allocations.
Classes and functions for implementing secret key algorithms.
Provides Encryption and Decryption typedefs used by derived classes to implement a block cipher.
Definition: seckey.h:399
Rijndael block cipher information.
Definition: rijndael.h:35