Module Name: src
Committed By: riastradh
Date: Thu Aug 20 21:20:37 UTC 2020
Modified Files:
src/sys/external/isc/libsodium/dist/src/libsodium/crypto_core/ed25519/ref10:
ed25519_ref10.c
Log Message:
Reuse temporaries in ge25519_scalarmult to reduce stack usage.
To generate a diff of this commit:
cvs rdiff -u -r1.1.1.1 -r1.2 \
src/sys/external/isc/libsodium/dist/src/libsodium/crypto_core/ed25519/ref10/ed25519_ref10.c
Please note that diffs are not public domain; they are subject to the
copyright notices on the relevant files.
Modified files:
Index: src/sys/external/isc/libsodium/dist/src/libsodium/crypto_core/ed25519/ref10/ed25519_ref10.c
diff -u src/sys/external/isc/libsodium/dist/src/libsodium/crypto_core/ed25519/ref10/ed25519_ref10.c:1.1.1.1 src/sys/external/isc/libsodium/dist/src/libsodium/crypto_core/ed25519/ref10/ed25519_ref10.c:1.2
--- src/sys/external/isc/libsodium/dist/src/libsodium/crypto_core/ed25519/ref10/ed25519_ref10.c:1.1.1.1 Thu Aug 20 21:17:06 2020
+++ src/sys/external/isc/libsodium/dist/src/libsodium/crypto_core/ed25519/ref10/ed25519_ref10.c Thu Aug 20 21:20:37 2020
@@ -755,41 +755,41 @@ ge25519_scalarmult(ge25519_p3 *h, const
signed char carry;
ge25519_p1p1 r;
ge25519_p2 s;
- ge25519_p1p1 t2, t3, t4, t5, t6, t7, t8;
- ge25519_p3 p2, p3, p4, p5, p6, p7, p8;
+ ge25519_p1p1 t1;
+ ge25519_p3 p2, p3, p4, pt;
ge25519_cached pi[8];
ge25519_cached t;
int i;
ge25519_p3_to_cached(&pi[1 - 1], p); /* p */
- ge25519_p3_dbl(&t2, p);
- ge25519_p1p1_to_p3(&p2, &t2);
+ ge25519_p3_dbl(&t1, p);
+ ge25519_p1p1_to_p3(&p2, &t1);
ge25519_p3_to_cached(&pi[2 - 1], &p2); /* 2p = 2*p */
- ge25519_add(&t3, p, &pi[2 - 1]);
- ge25519_p1p1_to_p3(&p3, &t3);
+ ge25519_add(&t1, p, &pi[2 - 1]);
+ ge25519_p1p1_to_p3(&p3, &t1);
ge25519_p3_to_cached(&pi[3 - 1], &p3); /* 3p = 2p+p */
- ge25519_p3_dbl(&t4, &p2);
- ge25519_p1p1_to_p3(&p4, &t4);
+ ge25519_p3_dbl(&t1, &p2);
+ ge25519_p1p1_to_p3(&p4, &t1);
ge25519_p3_to_cached(&pi[4 - 1], &p4); /* 4p = 2*2p */
- ge25519_add(&t5, p, &pi[4 - 1]);
- ge25519_p1p1_to_p3(&p5, &t5);
- ge25519_p3_to_cached(&pi[5 - 1], &p5); /* 5p = 4p+p */
-
- ge25519_p3_dbl(&t6, &p3);
- ge25519_p1p1_to_p3(&p6, &t6);
- ge25519_p3_to_cached(&pi[6 - 1], &p6); /* 6p = 2*3p */
-
- ge25519_add(&t7, p, &pi[6 - 1]);
- ge25519_p1p1_to_p3(&p7, &t7);
- ge25519_p3_to_cached(&pi[7 - 1], &p7); /* 7p = 6p+p */
-
- ge25519_p3_dbl(&t8, &p4);
- ge25519_p1p1_to_p3(&p8, &t8);
- ge25519_p3_to_cached(&pi[8 - 1], &p8); /* 8p = 2*4p */
+ ge25519_add(&t1, p, &pi[4 - 1]);
+ ge25519_p1p1_to_p3(&pt, &t1);
+ ge25519_p3_to_cached(&pi[5 - 1], &pt); /* 5p = 4p+p */
+
+ ge25519_p3_dbl(&t1, &p3);
+ ge25519_p1p1_to_p3(&pt, &t1);
+ ge25519_p3_to_cached(&pi[6 - 1], &pt); /* 6p = 2*3p */
+
+ ge25519_add(&t1, p, &pi[6 - 1]);
+ ge25519_p1p1_to_p3(&pt, &t1);
+ ge25519_p3_to_cached(&pi[7 - 1], &pt); /* 7p = 6p+p */
+
+ ge25519_p3_dbl(&t1, &p4);
+ ge25519_p1p1_to_p3(&pt, &t1);
+ ge25519_p3_to_cached(&pi[8 - 1], &pt); /* 8p = 2*4p */
for (i = 0; i < 32; ++i) {
e[2 * i + 0] = (a[i] >> 0) & 15;