summaryrefslogtreecommitdiff
diff options
context:
space:
mode:
authorNiels Möller <nisse@lysator.liu.se>2018-03-10 15:50:34 +0100
committerNiels Möller <nisse@lysator.liu.se>2018-03-10 15:50:34 +0100
commit98efe78d809d4fb09ffd278d36ef73d987f432d9 (patch)
tree9894cc8f85db19f6d7635f594e03fde67fa3129c
parentbe5b2eda8461cbe2f586b82fc04a245e4d18da99 (diff)
downloadnettle-98efe78d809d4fb09ffd278d36ef73d987f432d9.tar.gz
New program eccparams.
-rw-r--r--ChangeLog5
-rw-r--r--Makefile.in4
-rw-r--r--eccparams.c38
3 files changed, 47 insertions, 0 deletions
diff --git a/ChangeLog b/ChangeLog
index efe70d63..e682a2a5 100644
--- a/ChangeLog
+++ b/ChangeLog
@@ -1,3 +1,8 @@
+2018-03-10 Niels Möller <nisse@lysator.liu.se>
+
+ * eccparams.c (main): New program, to list parameter alternatives
+ for Pippenger's algorithm.
+
2018-02-20 Niels Möller <nisse@lysator.liu.se>
* testsuite/cmac-test.c (test_cmac_hash): Deallocate ctx properly.
diff --git a/Makefile.in b/Makefile.in
index de12bb3f..56992cfe 100644
--- a/Makefile.in
+++ b/Makefile.in
@@ -305,6 +305,10 @@ eccdata$(EXEEXT_FOR_BUILD): eccdata.c mini-gmp.c mini-gmp.h
$(CC_FOR_BUILD) `test -f eccdata.c || echo '$(srcdir)/'`eccdata.c \
-o eccdata$(EXEEXT_FOR_BUILD)
+eccparams$(EXEEXT_FOR_BUILD): eccparams.c
+ $(CC_FOR_BUILD) `test -f eccparams.c || echo '$(srcdir)/'`eccparams.c \
+ -o eccparams$(EXEEXT_FOR_BUILD)
+
# desCore rules
# It seems using $(srcdir)/ doesn't work with GNU make 3.79.1
# des_headers = $(srcdir)/rotors.h $(srcdir)/keymap.h
diff --git a/eccparams.c b/eccparams.c
new file mode 100644
index 00000000..60829770
--- /dev/null
+++ b/eccparams.c
@@ -0,0 +1,38 @@
+#include <stdio.h>
+#include <stdlib.h>
+
+int
+main (int argc, char **argv)
+{
+ unsigned bits;
+ unsigned max;
+ unsigned c;
+ if (argc < 3)
+ {
+ usage:
+ fprintf(stderr, "Usage: %s: exp-bits max-entries\n", argv[0]);
+ return EXIT_FAILURE;
+ }
+ bits = atoi(argv[1]);
+ if (bits < 2)
+ goto usage;
+ max = atoi(argv[2]);
+ if ( max < 2)
+ goto usage;
+
+ for (c = 3; (1<<c) <= max; c++)
+ {
+ unsigned b;
+ for (b = 1;; b++)
+ {
+ unsigned s = (1<<c) * b;
+ unsigned k;
+ if (s > max)
+ break;
+ k = (bits + (c*b) - 1) / (c * b);
+ printf("k = %2u, c = %2u, S = %3u, T = %3u (%3u A + %2u D)\n",
+ k, c, s, (b+1)*k, b*k, k);
+ }
+ }
+ return 0;
+}