#ifndef _CRYPTO_GCM_H
#define _CRYPTO_GCM_H
#include <linux/errno.h>
#include <crypto/aes.h>
#include <crypto/gf128mul.h>
#define GCM_AES_IV_SIZE …
#define GCM_RFC4106_IV_SIZE …
#define GCM_RFC4543_IV_SIZE …
static inline int crypto_gcm_check_authsize(unsigned int authsize)
{ … }
static inline int crypto_rfc4106_check_authsize(unsigned int authsize)
{ … }
static inline int crypto_ipsec_check_assoclen(unsigned int assoclen)
{ … }
struct aesgcm_ctx { … };
int aesgcm_expandkey(struct aesgcm_ctx *ctx, const u8 *key,
unsigned int keysize, unsigned int authsize);
void aesgcm_encrypt(const struct aesgcm_ctx *ctx, u8 *dst, const u8 *src,
int crypt_len, const u8 *assoc, int assoc_len,
const u8 iv[GCM_AES_IV_SIZE], u8 *authtag);
bool __must_check aesgcm_decrypt(const struct aesgcm_ctx *ctx, u8 *dst,
const u8 *src, int crypt_len, const u8 *assoc,
int assoc_len, const u8 iv[GCM_AES_IV_SIZE],
const u8 *authtag);
#endif