blob: 7fd7126f593af5ff689fd09eacca89dff5ab996f [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,
Olivier Deprez157378f2022-04-04 15:47:50 +020023 struct rtattr **tb);
Andrew Scullb4b6d4a2019-01-02 15:54:55 +000024int aead_init_geniv(struct crypto_aead *tfm);
25void aead_exit_geniv(struct crypto_aead *tfm);
26
27#endif /* _CRYPTO_INTERNAL_GENIV_H */