summaryrefslogtreecommitdiffhomepage
path: root/src/crypto/zinc/chacha20
diff options
context:
space:
mode:
Diffstat (limited to 'src/crypto/zinc/chacha20')
-rw-r--r--src/crypto/zinc/chacha20/chacha20-mips.S87
1 files changed, 48 insertions, 39 deletions
diff --git a/src/crypto/zinc/chacha20/chacha20-mips.S b/src/crypto/zinc/chacha20/chacha20-mips.S
index 7e2b5e8..8796da3 100644
--- a/src/crypto/zinc/chacha20/chacha20-mips.S
+++ b/src/crypto/zinc/chacha20/chacha20-mips.S
@@ -49,7 +49,7 @@
* They are used to handling the last bytes which are not multiple of 4.
*/
#define SAVED_X X15
-#define SAVED_CA $ra
+#define SAVED_CA $fp
#define PTR_LAST_ROUND $v1
#define IS_UNALIGNED $fp
@@ -166,25 +166,23 @@ CONCAT3(.Lchacha20_mips_xor_aligned_, PLUS_ONE(x), _b: ;) \
#define JMPTBL_ALIGNED(x) \
.Lchacha20_mips_jmptbl_aligned_ ## x: ; \
.set noreorder; \
+ b .Lchacha20_mips_xor_aligned_ ## x ## _b; \
.if (x == 12); \
- move SAVED_CA, NONCE_0; \
+ addu SAVED_X, X ## x, NONCE_0; \
.else; \
- lw SAVED_CA, (x*4)(STATE); \
+ addu SAVED_X, X ## x, SAVED_CA; \
.endif; \
- b .Lchacha20_mips_xor_aligned_ ## x ## _b; \
- move SAVED_X, X ## x; \
.set reorder
#define JMPTBL_UNALIGNED(x) \
.Lchacha20_mips_jmptbl_unaligned_ ## x: ; \
.set noreorder; \
+ b .Lchacha20_mips_xor_unaligned_ ## x ## _b; \
.if (x == 12); \
- move SAVED_CA, NONCE_0; \
+ addu SAVED_X, X ## x, NONCE_0; \
.else; \
- lw SAVED_CA, (x*4)(STATE);\
+ addu SAVED_X, X ## x, SAVED_CA; \
.endif; \
- b .Lchacha20_mips_xor_unaligned_ ## x ## _b; \
- move SAVED_X, X ## x; \
.set reorder
#define AXR(A, B, C, D, K, L, M, N, V, W, Y, Z, S) \
@@ -219,17 +217,16 @@ chacha20_mips:
ins PTR_LAST_ROUND, $zero, 0, 6
addu PTR_LAST_ROUND, OUT
- /* Save s0-s7, ra, fp */
- sw $ra, 0($sp)
- sw $fp, 4($sp)
- sw $s0, 8($sp)
- sw $s1, 12($sp)
- sw $s2, 16($sp)
- sw $s3, 20($sp)
- sw $s4, 24($sp)
- sw $s5, 28($sp)
- sw $s6, 32($sp)
- sw $s7, 36($sp)
+ /* Save s0-s7, fp */
+ sw $s0, 0($sp)
+ sw $s1, 4($sp)
+ sw $s2, 8($sp)
+ sw $s3, 12($sp)
+ sw $s4, 16($sp)
+ sw $s5, 20($sp)
+ sw $s6, 24($sp)
+ sw $s7, 28($sp)
+ sw $fp, 32($sp)
lw NONCE_0, 48(STATE)
@@ -293,31 +290,45 @@ chacha20_mips:
/* Last round? No, do a full block. */
bne OUT, PTR_LAST_ROUND, .Lchacha20_mips_xor_aligned_16_b
- /* Calculate lower half jump table addr and offset */
- ins T0, $at, 2, 6
+ /* Calculate lower half jump table offset */
+ ins T0, $at, 1, 6
/* Full block? Jump */
beqz BYTES, .Lchacha20_mips_xor_aligned_16_b
- subu T0, $at
+ /* Add STATE with offset */
+ addu T1, STATE, $at
+
+ /* Add lower half jump table addr */
addiu T0, %lo(.Lchacha20_mips_jmptbl_aligned_0)
+
+ /* Read value from STATE */
+ lw SAVED_CA, 0(T1)
+
jr T0
.Loop_chacha20_unaligned:
/* Load upper half of jump table addr */
lui T0, %hi(.Lchacha20_mips_jmptbl_unaligned_0)
- /* Last round? no jump */
+ /* Last round? No, do a full block. */
bne OUT, PTR_LAST_ROUND, .Lchacha20_mips_xor_unaligned_16_b
- /* Calculate lower half jump table addr and offset */
- ins T0, $at, 2, 6
+ /* Calculate lower half jump table offset */
+ ins T0, $at, 1, 6
/* Full block? Jump */
beqz BYTES, .Lchacha20_mips_xor_unaligned_16_b
- subu T0, $at
+ /* Add STATE with offset */
+ addu T1, STATE, $at
+
+ /* Add lower half jump table addr */
addiu T0, %lo(.Lchacha20_mips_jmptbl_unaligned_0)
+
+ /* Read value from STATE */
+ lw SAVED_CA, 0(T1)
+
jr T0
/* Aligned code path
@@ -336,16 +347,15 @@ chacha20_mips:
sw NONCE_0, 48(STATE)
/* Restore used registers */
- lw $ra, 0($sp)
- lw $fp, 4($sp)
- lw $s0, 8($sp)
- lw $s1, 12($sp)
- lw $s2, 16($sp)
- lw $s3, 20($sp)
- lw $s4, 24($sp)
- lw $s5, 28($sp)
- lw $s6, 32($sp)
- lw $s7, 36($sp)
+ lw $s0, 0($sp)
+ lw $s1, 4($sp)
+ lw $s2, 8($sp)
+ lw $s3, 12($sp)
+ lw $s4, 16($sp)
+ lw $s5, 20($sp)
+ lw $s6, 24($sp)
+ lw $s7, 28($sp)
+ lw $fp, 32($sp)
.Lchacha20_mips_end:
addiu $sp, STACK_SIZE
jr $ra
@@ -368,9 +378,8 @@ chacha20_mips:
.set reorder
.Lchacha20_mips_xor_bytes:
- addu OUT, $at
addu IN, $at
- addu SAVED_X, SAVED_CA
+ addu OUT, $at
/* First byte */
lbu T1, 0(IN)
andi $at, BYTES, 2