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 void clear()
override;
27 std::string
name()
const override {
return "SM4"; }
30 std::string provider()
const override;
31 size_t parallelism()
const override;
33 void key_schedule(
const uint8_t[],
size_t)
override;
35 #if defined(BOTAN_HAS_SM4_ARMV8)
36 void sm4_armv8_encrypt(
const uint8_t in[], uint8_t out[],
size_t blocks)
const;
37 void sm4_armv8_decrypt(
const uint8_t in[], uint8_t out[],
size_t blocks)
const;
int(* final)(unsigned char *, CTX *)
#define BOTAN_PUBLIC_API(maj, min)
std::vector< T, secure_allocator< T >> secure_vector
BlockCipher * clone() const override
#define BOTAN_FUTURE_INTERNAL_HEADER(hdr)
std::string name() const override