blob: 0108c0c7b2edbecd2b54a6584144abd097ef3263 [file] [log] [blame]
David Brazdil0f672f62019-12-10 10:32:29 +00001/* SPDX-License-Identifier: GPL-2.0-or-later */
Andrew Scullb4b6d4a2019-01-02 15:54:55 +00002/*
3 * geniv: IV generation
4 *
5 * Copyright (c) 2015 Herbert Xu <herbert@gondor.apana.org.au>
Andrew Scullb4b6d4a2019-01-02 15:54:55 +00006 */
7
8#ifndef _CRYPTO_INTERNAL_GENIV_H
9#define _CRYPTO_INTERNAL_GENIV_H
10
11#include <crypto/internal/aead.h>
12#include <linux/spinlock.h>
13#include <linux/types.h>
14
15struct aead_geniv_ctx {
16 spinlock_t lock;
17 struct crypto_aead *child;
David Brazdil0f672f62019-12-10 10:32:29 +000018 struct crypto_sync_skcipher *sknull;
Andrew Scullb4b6d4a2019-01-02 15:54:55 +000019 u8 salt[] __attribute__ ((aligned(__alignof__(u32))));
20};
21
22struct aead_instance *aead_geniv_alloc(struct crypto_template *tmpl,
23 struct rtattr **tb, u32 type, u32 mask);
24void aead_geniv_free(struct aead_instance *inst);
25int aead_init_geniv(struct crypto_aead *tfm);
26void aead_exit_geniv(struct crypto_aead *tfm);
27
28#endif /* _CRYPTO_INTERNAL_GENIV_H */