summaryrefslogtreecommitdiffstats
path: root/crypto/echainiv.c
diff options
context:
space:
mode:
authorHerbert Xu <herbert@gondor.apana.org.au>2015-05-27 02:37:31 -0400
committerHerbert Xu <herbert@gondor.apana.org.au>2015-05-27 23:23:18 -0400
commit838c9d561aaae4bc3f4b44046ea08b048ecaffe7 (patch)
tree3479da9f199d9d64433f8fdda887431e315c2f00 /crypto/echainiv.c
parent6350449fbf269aa78281b08852e64d5a4845df96 (diff)
crypto: echainiv - Copy AD along with plain text
As the AD does not necessarily exist in the destination buffer it must be copied along with the plain text. Signed-off-by: Herbert Xu <herbert@gondor.apana.org.au>
Diffstat (limited to 'crypto/echainiv.c')
-rw-r--r--crypto/echainiv.c10
1 files changed, 2 insertions, 8 deletions
diff --git a/crypto/echainiv.c b/crypto/echainiv.c
index bd85dcc4fa3d..02d054300a9a 100644
--- a/crypto/echainiv.c
+++ b/crypto/echainiv.c
@@ -228,19 +228,13 @@ static int echainiv_encrypt(struct aead_request *req)
228 info = req->iv; 228 info = req->iv;
229 229
230 if (req->src != req->dst) { 230 if (req->src != req->dst) {
231 struct scatterlist src[2];
232 struct scatterlist dst[2];
233 struct blkcipher_desc desc = { 231 struct blkcipher_desc desc = {
234 .tfm = ctx->null, 232 .tfm = ctx->null,
235 }; 233 };
236 234
237 err = crypto_blkcipher_encrypt( 235 err = crypto_blkcipher_encrypt(
238 &desc, 236 &desc, req->dst, req->src,
239 scatterwalk_ffwd(dst, req->dst, 237 req->assoclen + req->cryptlen);
240 req->assoclen + ivsize),
241 scatterwalk_ffwd(src, req->src,
242 req->assoclen + ivsize),
243 req->cryptlen - ivsize);
244 if (err) 238 if (err)
245 return err; 239 return err;
246 } 240 }