mirror of https://gitee.com/openkylin/linux.git
crypto/arm64: aes-ce-gcm - add missing kernel_neon_begin/end pair
Calling pmull_gcm_encrypt_block() requires kernel_neon_begin() and
kernel_neon_end() to be used since the routine touches the NEON
register file. Add the missing calls.
Also, since NEON register contents are not preserved outside of
a kernel mode NEON region, pass the key schedule array again.
Fixes: 7c50136a8a
("crypto: arm64/aes-ghash - yield NEON after every ...")
Acked-by: Herbert Xu <herbert@gondor.apana.org.au>
Signed-off-by: Ard Biesheuvel <ard.biesheuvel@linaro.org>
Signed-off-by: Will Deacon <will.deacon@arm.com>
This commit is contained in:
parent
acb1872577
commit
c7513c2a27
|
@ -488,9 +488,13 @@ static int gcm_decrypt(struct aead_request *req)
|
||||||
err = skcipher_walk_done(&walk,
|
err = skcipher_walk_done(&walk,
|
||||||
walk.nbytes % AES_BLOCK_SIZE);
|
walk.nbytes % AES_BLOCK_SIZE);
|
||||||
}
|
}
|
||||||
if (walk.nbytes)
|
if (walk.nbytes) {
|
||||||
pmull_gcm_encrypt_block(iv, iv, NULL,
|
kernel_neon_begin();
|
||||||
|
pmull_gcm_encrypt_block(iv, iv, ctx->aes_key.key_enc,
|
||||||
num_rounds(&ctx->aes_key));
|
num_rounds(&ctx->aes_key));
|
||||||
|
kernel_neon_end();
|
||||||
|
}
|
||||||
|
|
||||||
} else {
|
} else {
|
||||||
__aes_arm64_encrypt(ctx->aes_key.key_enc, tag, iv,
|
__aes_arm64_encrypt(ctx->aes_key.key_enc, tag, iv,
|
||||||
num_rounds(&ctx->aes_key));
|
num_rounds(&ctx->aes_key));
|
||||||
|
|
Loading…
Reference in New Issue