diff options
author | Jack Lloyd <[email protected]> | 2018-05-21 17:50:59 -0400 |
---|---|---|
committer | Jack Lloyd <[email protected]> | 2018-05-21 17:50:59 -0400 |
commit | e37b58c1099d909a26060120512537938fdc4287 (patch) | |
tree | d0550f96a16a548614ec81df6e79cd8c45828e42 /src/lib/math | |
parent | d08ce3d912343a9571d81b605ca04763560f8a00 (diff) |
Speed up DSA param gen
Using Barrett reduction instead of division is ~10x faster.
Diffstat (limited to 'src/lib/math')
-rw-r--r-- | src/lib/math/numbertheory/dsa_gen.cpp | 9 |
1 files changed, 6 insertions, 3 deletions
diff --git a/src/lib/math/numbertheory/dsa_gen.cpp b/src/lib/math/numbertheory/dsa_gen.cpp index 383c24d5c..a5efbc266 100644 --- a/src/lib/math/numbertheory/dsa_gen.cpp +++ b/src/lib/math/numbertheory/dsa_gen.cpp @@ -7,6 +7,7 @@ #include <botan/numthry.h> #include <botan/hash.h> +#include <botan/reducer.h> #include <botan/rng.h> namespace Botan { @@ -80,7 +81,7 @@ bool generate_dsa_primes(RandomNumberGenerator& rng, q.set_bit(qbits-1); q.set_bit(0); - if(!is_prime(q, rng, 126)) + if(!is_prime(q, rng, 128, true)) return false; const size_t n = (pbits-1) / (HASH_SIZE * 8), @@ -89,6 +90,8 @@ bool generate_dsa_primes(RandomNumberGenerator& rng, BigInt X; std::vector<uint8_t> V(HASH_SIZE * (n+1)); + Modular_Reducer mod_2q(2*q); + for(size_t j = 0; j != 4*pbits; ++j) { for(size_t k = 0; k <= n; ++k) @@ -104,9 +107,9 @@ bool generate_dsa_primes(RandomNumberGenerator& rng, V.size() - (HASH_SIZE - 1 - b/8)); X.set_bit(pbits-1); - p = X - (X % (2*q) - 1); + p = X - (mod_2q.reduce(X) - 1); - if(p.bits() == pbits && is_prime(p, rng, 126)) + if(p.bits() == pbits && is_prime(p, rng, 128, true)) return true; } } |