/* * GCM: Galois/Counter Mode. * * Copyright (c) 2007 Nokia Siemens Networks - Mikko Herranen <mh1@iki.fi> * * This program is free software; you can redistribute it and/or modify it * under the terms of the GNU General Public License version 2 as published * by the Free Software Foundation. */#include<crypto/gf128mul.h>#include<crypto/internal/aead.h>#include<crypto/internal/skcipher.h>#include<crypto/internal/hash.h>#include<crypto/scatterwalk.h>#include<crypto/hash.h>#include"internal.h"#include<linux/completion.h>#include<linux/err.h>#include<linux/init.h>#include<linux/kernel.h>#include<linux/module.h>#include<linux/slab.h>structgcm_instance_ctx{structcrypto_skcipher_spawnctr;structcrypto_ahash_spawnghash;};structcrypto_gcm_ctx{structcrypto_ablkcipher*ctr;structcrypto_ahash*ghash;};structcrypto_rfc4106_ctx{structcrypto_aead*child;u8nonce[4];};structcrypto_rfc4543_ctx{structcrypto_aead*child;u8nonce[4];};structcrypto_rfc4543_req_ctx{u8auth_tag[16];structscatterlistcipher[1];structscatterlistpayload[2];structscatterlistassoc[2];structaead_requestsubreq;};structcrypto_gcm_ghash_ctx{unsignedintcryptlen;structscatterlist*src;void(*complete)(structaead_request*req,interr);};structcrypto_gcm_req_priv_ctx{u8auth_tag[16];u8iauth_tag[16];structscatterlistsrc[2];structscatterlistdst[2];structcrypto_gcm_ghash_ctxghash_ctx;union{structahash_requestahreq;structablkcipher_requestabreq;}u;};structcrypto_gcm_setkey_result{interr;structcompletioncompletion;};staticvoid*gcm_zeroes;staticinlinestructcrypto_gcm_req_priv_ctx*crypto_gcm_reqctx(structaead_request*req){unsignedlongalign=crypto_aead_alignmask(crypto_aead_reqtfm(req));return(void*)PTR_ALIGN