X-Git-Url: https://git.distorted.org.uk/~mdw/catacomb/blobdiff_plain/24d2e65e3b6f122620b997b00dfe4900e57de7a9..178c254085727e7ee6e026e69a1f18cd0ab674e0:/progs/perftest.c diff --git a/progs/perftest.c b/progs/perftest.c index 9e5d7f03..5fa6b7fa 100644 --- a/progs/perftest.c +++ b/progs/perftest.c @@ -496,7 +496,9 @@ static void *ksched_init(opts *o) die(1, "must specify encryption scheme name"); if ((c->c = gcipher_byname(o->name)) == 0) die(1, "encryption scheme `%s' not known", o->name); - c->ksz = keysz(o->gbits/8, c->c->keysz); + c->ksz = keysz(o->fbits/8, c->c->keysz); + if (o->fbits%8 || (o->fbits && c->ksz != o->fbits/8)) + die(1, "bad key size %u for %s", o->fbits, o->name); c->k = xmalloc(c->ksz); rand_get(RAND_GLOBAL, c->k, c->ksz); return (c); @@ -526,7 +528,9 @@ static void *enc_init(opts *o) die(1, "must specify encryption scheme name"); if ((cc = gcipher_byname(o->name)) == 0) die(1, "encryption scheme `%s' not known", o->name); - ksz = keysz(0, cc->keysz); + ksz = keysz(o->fbits/8, cc->keysz); + if (o->fbits%8 || (o->fbits && ksz != o->fbits/8)) + die(1, "bad key size %u for %s", o->fbits, o->name); k = xmalloc(ksz); rand_get(RAND_GLOBAL, k, ksz); c->c = GC_INIT(cc, k, ksz); @@ -673,11 +677,12 @@ Options:\n\ -l, --list [ITEM...] List all the various names of things.\n\ \n\ -C, --name=NAME Select curve/DH-group/enc/hash name.\n\ --b, --field-bits Field size for g-prime and rsa.\n\ +-b, --field-bits Field size for g-prime and rsa;\n\ + key bits for ksched and enc.\n\ -q, --no-check Don't check field/group for validity.\n\ --B, --group-bits Group size for g-prime; key size for ksched;\n\ - data size for enc and hash.\n\ --n, --factors=COUNT Number of factors for {exp,mul}-sim.\n\ +-B, --group-bits Group size for g-prime; data size for enc and hash.\n\ +-n, --factors=COUNT Number of factors for {exp,mul}-sim;\n\ + inner iterations for enc and hash.\n\ -i, --intervals=COUNT Number of intervals to run for. [0; forever]\n\ -k, --batch=COUNT Number of operations to batch between timer checks.\n\ -t, --time=TIME Length of an interval in seconds. [1]\n\