diff options
Diffstat (limited to 'arch/x86/crypto')
| -rw-r--r-- | arch/x86/crypto/aesni-intel_glue.c | 9 | 
1 files changed, 7 insertions, 2 deletions
diff --git a/arch/x86/crypto/aesni-intel_glue.c b/arch/x86/crypto/aesni-intel_glue.c index 7c04d0da709..1b9c22bea8a 100644 --- a/arch/x86/crypto/aesni-intel_glue.c +++ b/arch/x86/crypto/aesni-intel_glue.c @@ -515,6 +515,11 @@ static int xts_aesni_setkey(struct crypto_tfm *tfm, const u8 *key,  } +static void aesni_xts_tweak(void *ctx, u8 *out, const u8 *in) +{ +	aesni_enc(ctx, out, in); +} +  static int xts_encrypt(struct blkcipher_desc *desc, struct scatterlist *dst,  		       struct scatterlist *src, unsigned int nbytes)  { @@ -525,7 +530,7 @@ static int xts_encrypt(struct blkcipher_desc *desc, struct scatterlist *dst,  		.tbuflen = sizeof(buf),  		.tweak_ctx = aes_ctx(ctx->raw_tweak_ctx), -		.tweak_fn = XTS_TWEAK_CAST(aesni_enc), +		.tweak_fn = aesni_xts_tweak,  		.crypt_ctx = aes_ctx(ctx->raw_crypt_ctx),  		.crypt_fn = lrw_xts_encrypt_callback,  	}; @@ -550,7 +555,7 @@ static int xts_decrypt(struct blkcipher_desc *desc, struct scatterlist *dst,  		.tbuflen = sizeof(buf),  		.tweak_ctx = aes_ctx(ctx->raw_tweak_ctx), -		.tweak_fn = XTS_TWEAK_CAST(aesni_enc), +		.tweak_fn = aesni_xts_tweak,  		.crypt_ctx = aes_ctx(ctx->raw_crypt_ctx),  		.crypt_fn = lrw_xts_decrypt_callback,  	};  |