From: Niels Möller Date: Sat, 10 Mar 2018 14:50:34 +0000 (+0100) Subject: New program eccparams. X-Git-Tag: nettle_3.5rc1~78^2~2 X-Git-Url: http://git.ipfire.org/cgi-bin/gitweb.cgi?a=commitdiff_plain;h=98efe78d809d4fb09ffd278d36ef73d987f432d9;p=thirdparty%2Fnettle.git New program eccparams. --- diff --git a/ChangeLog b/ChangeLog index efe70d63..e682a2a5 100644 --- a/ChangeLog +++ b/ChangeLog @@ -1,3 +1,8 @@ +2018-03-10 Niels Möller + + * eccparams.c (main): New program, to list parameter alternatives + for Pippenger's algorithm. + 2018-02-20 Niels Möller * 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 +#include + +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< 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; +}