summaryrefslogtreecommitdiff
path: root/src/lib/libcrypto/dsa/dsa_key.c
diff options
context:
space:
mode:
Diffstat (limited to 'src/lib/libcrypto/dsa/dsa_key.c')
-rw-r--r--src/lib/libcrypto/dsa/dsa_key.c20
1 files changed, 10 insertions, 10 deletions
diff --git a/src/lib/libcrypto/dsa/dsa_key.c b/src/lib/libcrypto/dsa/dsa_key.c
index eaf6da8de7..4732c471ed 100644
--- a/src/lib/libcrypto/dsa/dsa_key.c
+++ b/src/lib/libcrypto/dsa/dsa_key.c
@@ -1,4 +1,4 @@
1/* $OpenBSD: dsa_key.c,v 1.20 2014/10/18 17:20:40 jsing Exp $ */ 1/* $OpenBSD: dsa_key.c,v 1.21 2016/06/21 04:16:53 bcook Exp $ */
2/* Copyright (C) 1995-1998 Eric Young (eay@cryptsoft.com) 2/* Copyright (C) 1995-1998 Eric Young (eay@cryptsoft.com)
3 * All rights reserved. 3 * All rights reserved.
4 * 4 *
@@ -104,18 +104,18 @@ dsa_builtin_keygen(DSA *dsa)
104 pub_key=dsa->pub_key; 104 pub_key=dsa->pub_key;
105 105
106 { 106 {
107 BIGNUM local_prk; 107 BIGNUM *prk = BN_new();
108 BIGNUM *prk;
109 108
110 if ((dsa->flags & DSA_FLAG_NO_EXP_CONSTTIME) == 0) { 109 if (prk == NULL)
111 BN_init(&local_prk); 110 goto err;
112 prk = &local_prk; 111
113 BN_with_flags(prk, priv_key, BN_FLG_CONSTTIME); 112 BN_with_flags(prk, priv_key, BN_FLG_CONSTTIME);
114 } else
115 prk = priv_key;
116 113
117 if (!BN_mod_exp(pub_key, dsa->g, prk, dsa->p, ctx)) 114 if (!BN_mod_exp(pub_key, dsa->g, prk, dsa->p, ctx)) {
115 BN_free(prk);
118 goto err; 116 goto err;
117 }
118 BN_free(prk);
119 } 119 }
120 120
121 dsa->priv_key = priv_key; 121 dsa->priv_key = priv_key;