45 void ( *
final ) (
void *
ctx,
void *
out );
88 void ( *
setiv ) (
void *
ctx,
const void *
iv,
size_t ivlen );
132 int ( *
init ) (
void *
ctx,
const void *
key,
size_t key_len );
180 size_t signature_len );
185 void ( *
final ) (
void *
ctx );
195 const void *public_key,
size_t public_key_len );
214 void *
ctx,
const void *
key,
size_t keylen ) {
219 void *
ctx,
const void *
iv,
size_t ivlen ) {
224 void *
ctx,
const void *
src,
void *dst,
228 #define cipher_encrypt( cipher, ctx, src, dst, len ) do { \ 229 assert ( ( (len) & ( (cipher)->blocksize - 1 ) ) == 0 ); \ 230 cipher_encrypt ( (cipher), (ctx), (src), (dst), (len) ); \ 234 void *
ctx,
const void *
src,
void *dst,
238 #define cipher_decrypt( cipher, ctx, src, dst, len ) do { \ 239 assert ( ( (len) & ( (cipher)->blocksize - 1 ) ) == 0 ); \ 240 cipher_decrypt ( (cipher), (ctx), (src), (dst), (len) ); \ 261 const void *
key,
size_t key_len ) {
289 size_t signature_len ) {
300 size_t public_key_len ) {
320 size_t plaintext_len,
void *ciphertext );
322 size_t ciphertext_len,
void *plaintext );
327 size_t signature_len );
static int is_auth_cipher(struct cipher_algorithm *cipher)
size_t blocksize
Block size.
static void digest_update(struct digest_algorithm *digest, void *ctx, const void *data, size_t len)
void(* decrypt)(void *ctx, const void *src, void *dst, size_t len)
Decrypt data.
struct cipher_algorithm cipher_null
static int pubkey_decrypt(struct pubkey_algorithm *pubkey, void *ctx, const void *data, size_t len, void *out)
static int pubkey_match(struct pubkey_algorithm *pubkey, const void *private_key, size_t private_key_len, const void *public_key, size_t public_key_len)
static void digest_final(struct digest_algorithm *digest, void *ctx, void *out)
void(* init)(void *ctx)
Initialise digest.
int pubkey_null_verify(void *ctx, struct digest_algorithm *digest, const void *value, const void *signature, size_t signature_len)
size_t alignsize
Alignment size.
void cipher_null_setiv(void *ctx, const void *iv, size_t ivlen)
struct golan_eq_context ctx
struct md4_digest digest
Digest of data already processed.
size_t ctxsize
Context size.
struct digest_algorithm digest_null
int(* match)(const void *private_key, size_t private_key_len, const void *public_key, size_t public_key_len)
Check that public key matches private key.
void cipher_null_auth(void *ctx, void *auth)
void(* encrypt)(void *ctx, const void *src, void *dst, size_t len)
Encrypt data.
#define cipher_encrypt(cipher, ctx, src, dst, len)
int(* verify)(void *ctx, struct digest_algorithm *digest, const void *value, const void *signature, size_t signature_len)
Verify signed digest value.
size_t authsize
Authentication tag size.
static size_t pubkey_max_len(struct pubkey_algorithm *pubkey, void *ctx)
size_t blocksize
Block size.
static int pubkey_verify(struct pubkey_algorithm *pubkey, void *ctx, struct digest_algorithm *digest, const void *value, const void *signature, size_t signature_len)
void(* setiv)(void *ctx, const void *iv, size_t ivlen)
Set initialisation vector.
void digest_null_update(void *ctx, const void *src, size_t len)
void(* update)(void *ctx, const void *src, size_t len)
Update digest with new data.
struct pubkey_algorithm pubkey_null
pseudo_bit_t value[0x00020]
int pubkey_null_encrypt(void *ctx, const void *plaintext, size_t plaintext_len, void *ciphertext)
static __always_inline void off_t userptr_t src
static void digest_init(struct digest_algorithm *digest, void *ctx)
int(* encrypt)(void *ctx, const void *data, size_t len, void *out)
Encrypt.
void cipher_null_encrypt(void *ctx, const void *src, void *dst, size_t len)
void(* final)(void *ctx)
Finalise algorithm.
static void cipher_setiv(struct cipher_algorithm *cipher, void *ctx, const void *iv, size_t ivlen)
void(* auth)(void *ctx, void *auth)
Generate authentication tag.
size_t(* max_len)(void *ctx)
Calculate maximum output length.
int pubkey_null_sign(void *ctx, struct digest_algorithm *digest, const void *value, void *signature)
static int is_stream_cipher(struct cipher_algorithm *cipher)
size_t ctxsize
Context size.
#define cipher_decrypt(cipher, ctx, src, dst, len)
int(* decrypt)(void *ctx, const void *data, size_t len, void *out)
Decrypt.
void digest_null_final(void *ctx, void *out)
FILE_LICENCE(GPL2_OR_LATER_OR_UBDL)
size_t ctxsize
Context size.
int(* setkey)(void *ctx, const void *key, size_t keylen)
Set key.
size_t digestsize
Digest size.
const char * name
Algorithm name.
uint8_t iv[12]
Initialisation vector.
static int pubkey_sign(struct pubkey_algorithm *pubkey, void *ctx, struct digest_algorithm *digest, const void *value, void *signature)
int(* init)(void *ctx, const void *key, size_t key_len)
Initialise algorithm.
int cipher_null_setkey(void *ctx, const void *key, size_t keylen)
void cipher_null_decrypt(void *ctx, const void *src, void *dst, size_t len)
A message digest algorithm.
uint8_t data[48]
Additional event data.
int pubkey_null_decrypt(void *ctx, const void *ciphertext, size_t ciphertext_len, void *plaintext)
void digest_null_init(void *ctx)
static int pubkey_encrypt(struct pubkey_algorithm *pubkey, void *ctx, const void *data, size_t len, void *out)
static void pubkey_final(struct pubkey_algorithm *pubkey, void *ctx)
static void cipher_auth(struct cipher_algorithm *cipher, void *ctx, void *auth)
int pubkey_null_init(void *ctx, const void *key, size_t key_len)
const char * name
Algorithm name.
size_t pubkey_null_max_len(void *ctx)
struct private_key private_key
Private key.
const char * name
Algorithm name.
static int cipher_setkey(struct cipher_algorithm *cipher, void *ctx, const void *key, size_t keylen)
static int pubkey_init(struct pubkey_algorithm *pubkey, void *ctx, const void *key, size_t key_len)
static int is_block_cipher(struct cipher_algorithm *cipher)
int(* sign)(void *ctx, struct digest_algorithm *digest, const void *value, void *signature)
Sign digest value.