diff options
author | Ard Biesheuvel <ardb@kernel.org> | 2023-07-31 10:40:43 +0200 |
---|---|---|
committer | Alistair Francis <alistair.francis@wdc.com> | 2023-09-11 11:45:54 +1000 |
commit | 9ea17007c4ae4420ccd917eb300c7db49483a5b8 (patch) | |
tree | 9c207d8afbb2d7e1936b02f29b692b78d65defd6 /include/crypto | |
parent | 4cc9f284d5971ecd8055d26ef74c23ef0be8b8f5 (diff) | |
download | qemu-9ea17007c4ae4420ccd917eb300c7db49483a5b8.zip qemu-9ea17007c4ae4420ccd917eb300c7db49483a5b8.tar.gz qemu-9ea17007c4ae4420ccd917eb300c7db49483a5b8.tar.bz2 |
target/riscv: Use existing lookup tables for MixColumns
The AES MixColumns and InvMixColumns operations are relatively
expensive 4x4 matrix multiplications in GF(2^8), which is why C
implementations usually rely on precomputed lookup tables rather than
performing the calculations on demand.
Given that we already carry those tables in QEMU, we can just grab the
right value in the implementation of the RISC-V AES32 instructions. Note
that the tables in question are permuted according to the respective
Sbox, so we can omit the Sbox lookup as well in this case.
Cc: Richard Henderson <richard.henderson@linaro.org>
Cc: Philippe Mathieu-Daudé <philmd@linaro.org>
Cc: Zewen Ye <lustrew@foxmail.com>
Cc: Weiwei Li <liweiwei@iscas.ac.cn>
Cc: Junqiang Wang <wangjunqiang@iscas.ac.cn>
Signed-off-by: Ard Biesheuvel <ardb@kernel.org>
Reviewed-by: Richard Henderson <richard.henderson@linaro.org>
Message-ID: <20230731084043.1791984-1-ardb@kernel.org>
Signed-off-by: Alistair Francis <alistair.francis@wdc.com>
Diffstat (limited to 'include/crypto')
-rw-r--r-- | include/crypto/aes.h | 7 |
1 files changed, 7 insertions, 0 deletions
diff --git a/include/crypto/aes.h b/include/crypto/aes.h index 709d4d2..381f24c 100644 --- a/include/crypto/aes.h +++ b/include/crypto/aes.h @@ -30,4 +30,11 @@ void AES_decrypt(const unsigned char *in, unsigned char *out, extern const uint8_t AES_sbox[256]; extern const uint8_t AES_isbox[256]; +/* +AES_Te0[x] = S [x].[02, 01, 01, 03]; +AES_Td0[x] = Si[x].[0e, 09, 0d, 0b]; +*/ + +extern const uint32_t AES_Te0[256], AES_Td0[256]; + #endif |