summaryrefslogtreecommitdiffstats
path: root/meta-rcar-gen3/recipes-bsp/optee/optee-os
diff options
context:
space:
mode:
authorduythaidang <duy.dang.yw@renesas.com>2019-03-18 11:22:44 +0700
committerThuy Tran <thuy.tran.xh@renesas.com>2019-05-23 16:11:59 +0700
commit55c33ce0a852710bf68e515f992f954b2b8c171b (patch)
treec201587ea27e191fa8180a49f87d723386a3e70b /meta-rcar-gen3/recipes-bsp/optee/optee-os
parent4461b4a5a778f6472ebd65ecf034fe45b301cc07 (diff)
rcar-gen3: optee-os: Apply a patch instead of cherry-picking
This commit modifies to apply a patch instead of cherry-picking. This avoids the error of git config if git is not configured for the current user. Signed-off-by: Duy Dang <duy.dang.yw@renesas.com> Signed-off-by: Thuy Tran <thuy.tran.xh@renesas.com> Signed-off-by: Takamitsu Honda <takamitsu.honda.pv@renesas.com> (cherry picked from commit 0fd211f94a24125dc554055877ff910085e07fe2)
Diffstat (limited to 'meta-rcar-gen3/recipes-bsp/optee/optee-os')
-rw-r--r--meta-rcar-gen3/recipes-bsp/optee/optee-os/0001-core-crypto-arm64-ce-update-AES-CBC-routines.patch178
1 files changed, 178 insertions, 0 deletions
diff --git a/meta-rcar-gen3/recipes-bsp/optee/optee-os/0001-core-crypto-arm64-ce-update-AES-CBC-routines.patch b/meta-rcar-gen3/recipes-bsp/optee/optee-os/0001-core-crypto-arm64-ce-update-AES-CBC-routines.patch
new file mode 100644
index 0000000..570752e
--- /dev/null
+++ b/meta-rcar-gen3/recipes-bsp/optee/optee-os/0001-core-crypto-arm64-ce-update-AES-CBC-routines.patch
@@ -0,0 +1,178 @@
+From e77020396508fc086d7a4d6137388b116e4a662f Mon Sep 17 00:00:00 2001
+From: Jerome Forissier <jerome.forissier@linaro.org>
+Date: Tue, 12 Jun 2018 08:40:03 +0200
+Subject: [PATCH] core: crypto: arm64 ce: update AES CBC routines
+
+Update the Aarch64 Crypto Extension accelerated CBC encryption/decryption
+routines to the latest upstream implementation in the Linux kernel
+(v4.17-rc7).
+
+Signed-off-by: Jerome Forissier <jerome.forissier@linaro.org>
+Tested-by: Jerome Forissier <jerome.forissier@linaro.org> (HiKey960)
+CC: Ard Biesheuvel <ard.biesheuvel@linaro.org>
+Fixes: https://github.com/OP-TEE/optee_os/issues/2355
+Acked-by: Jens Wiklander <jens.wiklander@linaro.org>
+---
+ core/lib/libtomcrypt/src/ciphers/aes_armv8a_ce.c | 8 +--
+ .../src/ciphers/aes_modes_armv8a_ce_a64.S | 70 ++++++++++++----------
+ 2 files changed, 41 insertions(+), 37 deletions(-)
+
+diff --git a/core/lib/libtomcrypt/src/ciphers/aes_armv8a_ce.c b/core/lib/libtomcrypt/src/ciphers/aes_armv8a_ce.c
+index cd99e45..873435e 100644
+--- a/core/lib/libtomcrypt/src/ciphers/aes_armv8a_ce.c
++++ b/core/lib/libtomcrypt/src/ciphers/aes_armv8a_ce.c
+@@ -59,9 +59,9 @@ void ce_aes_ecb_encrypt(u8 out[], u8 const in[], u8 const rk[], int rounds,
+ void ce_aes_ecb_decrypt(u8 out[], u8 const in[], u8 const rk[], int rounds,
+ int blocks, int first);
+ void ce_aes_cbc_encrypt(u8 out[], u8 const in[], u8 const rk[], int rounds,
+- int blocks, u8 iv[], int first);
++ int blocks, u8 iv[]);
+ void ce_aes_cbc_decrypt(u8 out[], u8 const in[], u8 const rk[], int rounds,
+- int blocks, u8 iv[], int first);
++ int blocks, u8 iv[]);
+ void ce_aes_ctr_encrypt(u8 out[], u8 const in[], u8 const rk[], int rounds,
+ int blocks, u8 ctr[], int first);
+ void ce_aes_xts_encrypt(u8 out[], u8 const in[], u8 const rk1[], int rounds,
+@@ -250,7 +250,7 @@ static int aes_cbc_encrypt_nblocks(const unsigned char *pt, unsigned char *ct,
+ rk = (u8 *)skey->rijndael.eK;
+
+ tomcrypt_arm_neon_enable(&state);
+- ce_aes_cbc_encrypt(ct, pt, rk, Nr, blocks, IV, 1);
++ ce_aes_cbc_encrypt(ct, pt, rk, Nr, blocks, IV);
+ tomcrypt_arm_neon_disable(&state);
+
+ return CRYPT_OK;
+@@ -273,7 +273,7 @@ static int aes_cbc_decrypt_nblocks(const unsigned char *ct, unsigned char *pt,
+ rk = (u8 *)skey->rijndael.dK;
+
+ tomcrypt_arm_neon_enable(&state);
+- ce_aes_cbc_decrypt(pt, ct, rk, Nr, blocks, IV, 1);
++ ce_aes_cbc_decrypt(pt, ct, rk, Nr, blocks, IV);
+ tomcrypt_arm_neon_disable(&state);
+
+ return CRYPT_OK;
+diff --git a/core/lib/libtomcrypt/src/ciphers/aes_modes_armv8a_ce_a64.S b/core/lib/libtomcrypt/src/ciphers/aes_modes_armv8a_ce_a64.S
+index 04a4b06..58aa05e 100644
+--- a/core/lib/libtomcrypt/src/ciphers/aes_modes_armv8a_ce_a64.S
++++ b/core/lib/libtomcrypt/src/ciphers/aes_modes_armv8a_ce_a64.S
+@@ -329,55 +329,61 @@ ENDPROC(ce_aes_ecb_decrypt)
+
+ /*
+ * aes_cbc_encrypt(u8 out[], u8 const in[], u8 const rk[], int rounds,
+- * int blocks, u8 iv[], int first)
++ * int blocks, u8 iv[])
+ * aes_cbc_decrypt(u8 out[], u8 const in[], u8 const rk[], int rounds,
+- * int blocks, u8 iv[], int first)
++ * int blocks, u8 iv[])
+ */
+
+ ENTRY(ce_aes_cbc_encrypt)
+- cbz w6, .Lcbcencloop
+-
+- ld1 {v0.16b}, [x5] /* get iv */
+- enc_prepare w3, x2, x5
++ ld1 {v4.16b}, [x5] /* get iv */
++ enc_prepare w3, x2, x6
+
++.Lcbcencloop4x:
++ subs w4, w4, #4
++ bmi .Lcbcenc1x
++ ld1 {v0.16b-v3.16b}, [x1], #64 /* get 4 pt blocks */
++ eor v0.16b, v0.16b, v4.16b /* ..and xor with iv */
++ encrypt_block v0, w3, x2, x6, w7
++ eor v1.16b, v1.16b, v0.16b
++ encrypt_block v1, w3, x2, x6, w7
++ eor v2.16b, v2.16b, v1.16b
++ encrypt_block v2, w3, x2, x6, w7
++ eor v3.16b, v3.16b, v2.16b
++ encrypt_block v3, w3, x2, x6, w7
++ st1 {v0.16b-v3.16b}, [x0], #64
++ mov v4.16b, v3.16b
++ b .Lcbcencloop4x
++.Lcbcenc1x:
++ adds w4, w4, #4
++ beq .Lcbcencout
+ .Lcbcencloop:
+- ld1 {v1.16b}, [x1], #16 /* get next pt block */
+- eor v0.16b, v0.16b, v1.16b /* ..and xor with iv */
+- encrypt_block v0, w3, x2, x5, w6
+- st1 {v0.16b}, [x0], #16
++ ld1 {v0.16b}, [x1], #16 /* get next pt block */
++ eor v4.16b, v4.16b, v0.16b /* ..and xor with iv */
++ encrypt_block v4, w3, x2, x6, w7
++ st1 {v4.16b}, [x0], #16
+ subs w4, w4, #1
+ bne .Lcbcencloop
+- st1 {v0.16b}, [x5] /* save iv for later */
++.Lcbcencout:
++ st1 {v4.16b}, [x5] /* return iv */
+ ret
+ ENDPROC(ce_aes_cbc_encrypt)
+
+
+ ENTRY(ce_aes_cbc_decrypt)
+- FRAME_PUSH
+- cbz w6, .LcbcdecloopNx
++ stp x29, x30, [sp, #-16]!
++ mov x29, sp
+
+ ld1 {v7.16b}, [x5] /* get iv */
+- dec_prepare w3, x2, x5
++ dec_prepare w3, x2, x6
+
+ .LcbcdecloopNx:
+-#if INTERLEAVE >= 2
+- subs w4, w4, #INTERLEAVE
++ subs w4, w4, #4
+ bmi .Lcbcdec1x
+-#if INTERLEAVE == 2
+- ld1 {v0.16b-v1.16b}, [x1], #32 /* get 2 ct blocks */
+- mov v2.16b, v0.16b
+- mov v3.16b, v1.16b
+- do_decrypt_block2x
+- eor v0.16b, v0.16b, v7.16b
+- eor v1.16b, v1.16b, v2.16b
+- mov v7.16b, v3.16b
+- st1 {v0.16b-v1.16b}, [x0], #32
+-#else
+ ld1 {v0.16b-v3.16b}, [x1], #64 /* get 4 ct blocks */
+ mov v4.16b, v0.16b
+ mov v5.16b, v1.16b
+ mov v6.16b, v2.16b
+- do_decrypt_block4x
++ bl aes_decrypt_block4x
+ sub x1, x1, #16
+ eor v0.16b, v0.16b, v7.16b
+ eor v1.16b, v1.16b, v4.16b
+@@ -385,24 +391,22 @@ ENTRY(ce_aes_cbc_decrypt)
+ eor v2.16b, v2.16b, v5.16b
+ eor v3.16b, v3.16b, v6.16b
+ st1 {v0.16b-v3.16b}, [x0], #64
+-#endif
+ b .LcbcdecloopNx
+ .Lcbcdec1x:
+- adds w4, w4, #INTERLEAVE
++ adds w4, w4, #4
+ beq .Lcbcdecout
+-#endif
+ .Lcbcdecloop:
+ ld1 {v1.16b}, [x1], #16 /* get next ct block */
+ mov v0.16b, v1.16b /* ...and copy to v0 */
+- decrypt_block v0, w3, x2, x5, w6
++ decrypt_block v0, w3, x2, x6, w7
+ eor v0.16b, v0.16b, v7.16b /* xor with iv => pt */
+ mov v7.16b, v1.16b /* ct is next iv */
+ st1 {v0.16b}, [x0], #16
+ subs w4, w4, #1
+ bne .Lcbcdecloop
+ .Lcbcdecout:
+- st1 {v1.16b}, [x5] /* save iv for later */
+- FRAME_POP
++ st1 {v7.16b}, [x5] /* return iv */
++ ldp x29, x30, [sp], #16
+ ret
+ ENDPROC(ce_aes_cbc_decrypt)
+
+--
+2.7.4
+