8#ifndef BOTAN_SHACAL2_H_
9#define BOTAN_SHACAL2_H_
11#include <botan/block_cipher.h>
23 void encrypt_n(
const uint8_t in[], uint8_t out[],
size_t blocks)
const override;
24 void decrypt_n(
const uint8_t in[], uint8_t out[],
size_t blocks)
const override;
26 std::string
provider()
const override;
27 void clear()
override;
28 std::string
name()
const override {
return "SHACAL2"; }
33 void key_schedule(
const uint8_t[],
size_t)
override;
35#if defined(BOTAN_HAS_SHACAL2_SIMD)
36 void simd_encrypt_4(
const uint8_t in[], uint8_t out[])
const;
37 void simd_decrypt_4(
const uint8_t in[], uint8_t out[])
const;
40#if defined(BOTAN_HAS_SHACAL2_AVX2)
41 void avx2_encrypt_8(
const uint8_t in[], uint8_t out[])
const;
42 void avx2_decrypt_8(
const uint8_t in[], uint8_t out[])
const;
45#if defined(BOTAN_HAS_SHACAL2_X86)
46 void x86_encrypt_blocks(
const uint8_t in[], uint8_t out[],
size_t blocks)
const;
virtual void decrypt_n(const uint8_t in[], uint8_t out[], size_t blocks) const =0
virtual void encrypt_n(const uint8_t in[], uint8_t out[], size_t blocks) const =0
virtual size_t parallelism() const
virtual std::string provider() const
std::string name() const override
BlockCipher * clone() const override
int(* final)(unsigned char *, CTX *)
#define BOTAN_PUBLIC_API(maj, min)
#define BOTAN_FUTURE_INTERNAL_HEADER(hdr)
std::vector< T, secure_allocator< T > > secure_vector