Source-Changes-HG archive

[Date Prev][Date Next][Thread Prev][Thread Next][Date Index][Thread Index][Old Index]

[src/trunk]: src/sys/external/isc/libsodium/dist/src/libsodium/crypto_core/ed...



details:   https://anonhg.NetBSD.org/src/rev/5d1267c76909
branches:  trunk
changeset: 1013063:5d1267c76909
user:      riastradh <riastradh%NetBSD.org@localhost>
date:      Thu Aug 20 21:20:37 2020 +0000

description:
Reuse temporaries in ge25519_scalarmult to reduce stack usage.

diffstat:

 sys/external/isc/libsodium/dist/src/libsodium/crypto_core/ed25519/ref10/ed25519_ref10.c |  40 +++++-----
 1 files changed, 20 insertions(+), 20 deletions(-)

diffs (65 lines):

diff -r 970875b4ae00 -r 5d1267c76909 sys/external/isc/libsodium/dist/src/libsodium/crypto_core/ed25519/ref10/ed25519_ref10.c
--- a/sys/external/isc/libsodium/dist/src/libsodium/crypto_core/ed25519/ref10/ed25519_ref10.c   Thu Aug 20 21:20:16 2020 +0000
+++ b/sys/external/isc/libsodium/dist/src/libsodium/crypto_core/ed25519/ref10/ed25519_ref10.c   Thu Aug 20 21:20:37 2020 +0000
@@ -755,41 +755,41 @@
     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_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(&t6, &p3);
-    ge25519_p1p1_to_p3(&p6, &t6);
-    ge25519_p3_to_cached(&pi[6 - 1], &p6); /* 6p = 2*3p */
+    ge25519_p3_dbl(&t1, &p3);
+    ge25519_p1p1_to_p3(&pt, &t1);
+    ge25519_p3_to_cached(&pi[6 - 1], &pt); /* 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_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(&t8, &p4);
-    ge25519_p1p1_to_p3(&p8, &t8);
-    ge25519_p3_to_cached(&pi[8 - 1], &p8); /* 8p = 2*4p */
+    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;



Home | Main Index | Thread Index | Old Index