summaryrefslogtreecommitdiffstats
path: root/drivers/crypto/ccp/ccp-dev-v5.c
diff options
context:
space:
mode:
authorArd Biesheuvel <ard.biesheuvel@linaro.org>2017-07-24 12:28:20 +0200
committerHerbert Xu <herbert@gondor.apana.org.au>2017-08-04 03:27:26 +0200
commit7c83d689c71fd6ca8829d4a34416685938368c13 (patch)
tree0f074ccf43f51f14d76fcb5055191d354954b4fb /drivers/crypto/ccp/ccp-dev-v5.c
parentcrypto: arm/aes - avoid expanded lookup tables in the final round (diff)
downloadlinux-7c83d689c71fd6ca8829d4a34416685938368c13.tar.xz
linux-7c83d689c71fd6ca8829d4a34416685938368c13.zip
crypto: arm64/aes - avoid expanded lookup tables in the final round
For the final round, avoid the expanded and padded lookup tables exported by the generic AES driver. Instead, for encryption, we can perform byte loads from the same table we used for the inner rounds, which will still be hot in the caches. For decryption, use the inverse AES Sbox directly, which is 4x smaller than the inverse lookup table exported by the generic driver. This should significantly reduce the Dcache footprint of our code, which makes the code more robust against timing attacks. It does not introduce any additional module dependencies, given that we already rely on the core AES module for the shared key expansion routines. It also frees up register x18, which is not available as a scratch register on all platforms, which and so avoiding it improves shareability of this code. Signed-off-by: Ard Biesheuvel <ard.biesheuvel@linaro.org> Signed-off-by: Herbert Xu <herbert@gondor.apana.org.au>
Diffstat (limited to 'drivers/crypto/ccp/ccp-dev-v5.c')
0 files changed, 0 insertions, 0 deletions