8 #ifndef BOTAN_SERPENT_H_
9 #define BOTAN_SERPENT_H_
11 #include <botan/block_cipher.h>
24 void encrypt_n(
const uint8_t in[], uint8_t out[],
size_t blocks)
const override;
25 void decrypt_n(
const uint8_t in[], uint8_t out[],
size_t blocks)
const override;
27 void clear()
override;
28 std::string provider()
const override;
29 std::string
name()
const override {
return "Serpent"; }
36 #if defined(BOTAN_HAS_SERPENT_SIMD)
37 void simd_encrypt_4(
const uint8_t in[64], uint8_t out[64])
const;
38 void simd_decrypt_4(
const uint8_t in[64], uint8_t out[64])
const;
41 #if defined(BOTAN_HAS_SERPENT_AVX2)
42 void avx2_encrypt_8(
const uint8_t in[64], uint8_t out[64])
const;
43 void avx2_decrypt_8(
const uint8_t in[64], uint8_t out[64])
const;
46 void key_schedule(
const uint8_t key[],
size_t length)
override;
std::string name() const override
int(* final)(unsigned char *, CTX *)
#define BOTAN_PUBLIC_API(maj, min)
BlockCipher * clone() const override
std::vector< T, secure_allocator< T >> secure_vector
size_t parallelism() const override
#define BOTAN_FUTURE_INTERNAL_HEADER(hdr)