8#ifndef BOTAN_CAMELLIA_H_
9#define BOTAN_CAMELLIA_H_
11#include <botan/block_cipher.h>
12#include <botan/secmem.h>
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;
24 void clear()
override;
26 std::string
name()
const override {
return "Camellia-128"; }
28 std::string
provider()
const override;
31 std::unique_ptr<BlockCipher>
new_object()
const override {
return std::make_unique<Camellia_128>(); }
36 void key_schedule(std::span<const uint8_t> key)
override;
38#if defined(BOTAN_HAS_CAMELLIA_AVX2_GFNI)
39 static void avx2_gfni_encrypt(
const uint8_t in[], uint8_t out[],
size_t blocks, std::span<const uint64_t> SK);
40 static void avx2_gfni_decrypt(
const uint8_t in[], uint8_t out[],
size_t blocks, std::span<const uint64_t> SK);
43#if defined(BOTAN_HAS_CAMELLIA_AVX512_GFNI)
44 static void avx512_gfni_encrypt(
const uint8_t in[], uint8_t out[],
size_t blocks, std::span<const uint64_t> SK);
45 static void avx512_gfni_decrypt(
const uint8_t in[], uint8_t out[],
size_t blocks, std::span<const uint64_t> SK);
56 void encrypt_n(
const uint8_t in[], uint8_t out[],
size_t blocks)
const override;
57 void decrypt_n(
const uint8_t in[], uint8_t out[],
size_t blocks)
const override;
59 void clear()
override;
61 std::string
name()
const override {
return "Camellia-192"; }
63 std::string
provider()
const override;
66 std::unique_ptr<BlockCipher>
new_object()
const override {
return std::make_unique<Camellia_192>(); }
71 void key_schedule(std::span<const uint8_t> key)
override;
73#if defined(BOTAN_HAS_CAMELLIA_AVX2_GFNI)
74 static void avx2_gfni_encrypt(
const uint8_t in[], uint8_t out[],
size_t blocks, std::span<const uint64_t> SK);
75 static void avx2_gfni_decrypt(
const uint8_t in[], uint8_t out[],
size_t blocks, std::span<const uint64_t> SK);
78#if defined(BOTAN_HAS_CAMELLIA_AVX512_GFNI)
79 static void avx512_gfni_encrypt(
const uint8_t in[], uint8_t out[],
size_t blocks, std::span<const uint64_t> SK);
80 static void avx512_gfni_decrypt(
const uint8_t in[], uint8_t out[],
size_t blocks, std::span<const uint64_t> SK);
91 void encrypt_n(
const uint8_t in[], uint8_t out[],
size_t blocks)
const override;
92 void decrypt_n(
const uint8_t in[], uint8_t out[],
size_t blocks)
const override;
94 void clear()
override;
96 std::string
name()
const override {
return "Camellia-256"; }
98 std::string
provider()
const override;
101 std::unique_ptr<BlockCipher>
new_object()
const override {
return std::make_unique<Camellia_256>(); }
106 void key_schedule(std::span<const uint8_t> key)
override;
108#if defined(BOTAN_HAS_CAMELLIA_AVX2_GFNI)
109 static void avx2_gfni_encrypt(
const uint8_t in[], uint8_t out[],
size_t blocks, std::span<const uint64_t> SK);
110 static void avx2_gfni_decrypt(
const uint8_t in[], uint8_t out[],
size_t blocks, std::span<const uint64_t> SK);
113#if defined(BOTAN_HAS_CAMELLIA_AVX512_GFNI)
114 static void avx512_gfni_encrypt(
const uint8_t in[], uint8_t out[],
size_t blocks, std::span<const uint64_t> SK);
115 static void avx512_gfni_decrypt(
const uint8_t in[], uint8_t out[],
size_t blocks, std::span<const uint64_t> SK);
void decrypt_n(const uint8_t in[], uint8_t out[], size_t blocks) const override
bool has_keying_material() const override
std::unique_ptr< BlockCipher > new_object() const override
size_t parallelism() const override
std::string name() const override
void encrypt_n(const uint8_t in[], uint8_t out[], size_t blocks) const override
std::string provider() const override
std::unique_ptr< BlockCipher > new_object() const override
void encrypt_n(const uint8_t in[], uint8_t out[], size_t blocks) const override
bool has_keying_material() const override
std::string provider() const override
void decrypt_n(const uint8_t in[], uint8_t out[], size_t blocks) const override
size_t parallelism() const override
std::string name() const override
void decrypt_n(const uint8_t in[], uint8_t out[], size_t blocks) const override
bool has_keying_material() const override
std::unique_ptr< BlockCipher > new_object() const override
std::string provider() const override
size_t parallelism() const override
void encrypt_n(const uint8_t in[], uint8_t out[], size_t blocks) const override
std::string name() const override
std::vector< T, secure_allocator< T > > secure_vector