summaryrefslogtreecommitdiffstats
path: root/key.c
diff options
context:
space:
mode:
authorDamien Miller <djm@mindrot.org>2010-11-20 15:15:49 +1100
committerDamien Miller <djm@mindrot.org>2010-11-20 15:15:49 +1100
commit4499f4cc20eee7e0f67b35f5a5c6078bf07dcbc0 (patch)
treef4d827008f691988ecb163d0748648e10f2b0c25 /key.c
parent7a221a159188eceeea366d4f58345d2bdccaeb8d (diff)
- djm@cvs.openbsd.org 2010/11/10 01:33:07
[kexdhc.c kexdhs.c kexgexc.c kexgexs.c key.c moduli.c] use only libcrypto APIs that are retained with OPENSSL_NO_DEPRECATED. these have been around for years by this time. ok markus
Diffstat (limited to 'key.c')
-rw-r--r--key.c26
1 files changed, 17 insertions, 9 deletions
diff --git a/key.c b/key.c
index c71bf5b0..1defb113 100644
--- a/key.c
+++ b/key.c
@@ -1,4 +1,4 @@
-/* $OpenBSD: key.c,v 1.94 2010/10/28 11:22:09 djm Exp $ */
+/* $OpenBSD: key.c,v 1.95 2010/11/10 01:33:07 djm Exp $ */
/*
* read_bignum():
* Copyright (c) 1995 Tatu Ylonen <ylo@cs.hut.fi>, Espoo, Finland
@@ -1013,25 +1013,33 @@ key_size(const Key *k)
static RSA *
rsa_generate_private_key(u_int bits)
{
- RSA *private;
+ RSA *private = RSA_new();
+ BIGNUM *f4 = BN_new();
- private = RSA_generate_key(bits, RSA_F4, NULL, NULL);
if (private == NULL)
- fatal("rsa_generate_private_key: key generation failed.");
+ fatal("%s: RSA_new failed", __func__);
+ if (f4 == NULL)
+ fatal("%s: BN_new failed", __func__);
+ if (!BN_set_word(f4, RSA_F4))
+ fatal("%s: BN_new failed", __func__);
+ if (!RSA_generate_key_ex(private, bits, f4, NULL))
+ fatal("%s: key generation failed.", __func__);
+ BN_free(f4);
return private;
}
static DSA*
dsa_generate_private_key(u_int bits)
{
- DSA *private = DSA_generate_parameters(bits, NULL, 0, NULL, NULL, NULL, NULL);
+ DSA *private = DSA_new();
if (private == NULL)
- fatal("dsa_generate_private_key: DSA_generate_parameters failed");
+ fatal("%s: DSA_new failed", __func__);
+ if (!DSA_generate_parameters_ex(private, bits, NULL, 0, NULL,
+ NULL, NULL))
+ fatal("%s: DSA_generate_parameters failed", __func__);
if (!DSA_generate_key(private))
- fatal("dsa_generate_private_key: DSA_generate_key failed.");
- if (private == NULL)
- fatal("dsa_generate_private_key: NULL.");
+ fatal("%s: DSA_generate_key failed.", __func__);
return private;
}