diff options
Diffstat (limited to 'old/botan/src/block/safer/safer_sk.h')
-rw-r--r-- | old/botan/src/block/safer/safer_sk.h | 40 |
1 files changed, 40 insertions, 0 deletions
diff --git a/old/botan/src/block/safer/safer_sk.h b/old/botan/src/block/safer/safer_sk.h new file mode 100644 index 0000000..e52c583 --- /dev/null +++ b/old/botan/src/block/safer/safer_sk.h @@ -0,0 +1,40 @@ +/* +* SAFER-SK +* (C) 1999-2007 Jack Lloyd +* +* Distributed under the terms of the Botan license +*/ + +#ifndef BOTAN_SAFER_SK_H__ +#define BOTAN_SAFER_SK_H__ + +#include <botan/block_cipher.h> + +namespace Botan { + +/* +* SAFER-SK +*/ +class BOTAN_DLL SAFER_SK : public BlockCipher + { + public: + void clear() throw() { EK.clear(); } + std::string name() const; + BlockCipher* clone() const; + SAFER_SK(u32bit); + private: + void enc(const byte[], byte[]) const; + void dec(const byte[], byte[]) const; + void key_schedule(const byte[], u32bit); + + static const byte EXP[256]; + static const byte LOG[512]; + static const byte BIAS[208]; + static const byte KEY_INDEX[208]; + SecureVector<byte> EK; + const u32bit ROUNDS; + }; + +} + +#endif |