diff options
author | Ulf Möller <ulf@openssl.org> | 2001-02-20 00:43:59 +0000 |
---|---|---|
committer | Ulf Möller <ulf@openssl.org> | 2001-02-20 00:43:59 +0000 |
commit | 12c2fe8d53fd43559ea862c9babfc2abf3c65299 (patch) | |
tree | af83ab96c9aad2bc15a07e4e1a44dfe0e0b0f3e2 /crypto/dsa/dsa_key.c | |
parent | 28143c66e138b843b41280c0b9763f28553dc355 (diff) |
Use BN_rand_range().
Diffstat (limited to 'crypto/dsa/dsa_key.c')
-rw-r--r-- | crypto/dsa/dsa_key.c | 13 |
1 files changed, 3 insertions, 10 deletions
diff --git a/crypto/dsa/dsa_key.c b/crypto/dsa/dsa_key.c index 5f4a8fca92..bd5d0ce567 100644 --- a/crypto/dsa/dsa_key.c +++ b/crypto/dsa/dsa_key.c @@ -68,7 +68,6 @@ int DSA_generate_key(DSA *dsa) { int ok=0; - unsigned int i; BN_CTX *ctx=NULL; BIGNUM *pub_key=NULL,*priv_key=NULL; @@ -81,15 +80,9 @@ int DSA_generate_key(DSA *dsa) else priv_key=dsa->priv_key; - i=BN_num_bits(dsa->q); - for (;;) - { - if (!BN_rand(priv_key,i,0,0)) - goto err; - if (BN_cmp(priv_key,dsa->q) >= 0) - BN_sub(priv_key,priv_key,dsa->q); - if (!BN_is_zero(priv_key)) break; - } + do + if (!BN_rand_range(priv_key,dsa->q)) goto err; + while (BN_is_zero(priv_key)); if (dsa->pub_key == NULL) { |