summaryrefslogtreecommitdiff
path: root/apps/dhparam.c
diff options
context:
space:
mode:
authorPawel Kowalski <p.kowalski2@partner.samsung.com>2017-11-24 11:26:53 +0100
committerPawel Kowalski <p.kowalski2@partner.samsung.com>2017-11-24 11:26:53 +0100
commit16a871c1cbcffb9c2ba93e253f496a3254354653 (patch)
tree7a99d2e60b78cc135ee14320af84ada6b3229474 /apps/dhparam.c
parent42400a3c53dd8996817c46cb390e8320c800f6cf (diff)
downloadopenssl-16a871c1cbcffb9c2ba93e253f496a3254354653.tar.gz
openssl-16a871c1cbcffb9c2ba93e253f496a3254354653.tar.bz2
openssl-16a871c1cbcffb9c2ba93e253f496a3254354653.zip
Imported Upstream version 1.0.2mupstream/1.0.2m
Diffstat (limited to 'apps/dhparam.c')
-rw-r--r--apps/dhparam.c24
1 files changed, 18 insertions, 6 deletions
diff --git a/apps/dhparam.c b/apps/dhparam.c
index 1210adb..bd91234 100644
--- a/apps/dhparam.c
+++ b/apps/dhparam.c
@@ -381,10 +381,19 @@ int MAIN(int argc, char **argv)
} else
# endif
{
- if (informat == FORMAT_ASN1)
+ if (informat == FORMAT_ASN1) {
+ /*
+ * We have no PEM header to determine what type of DH params it
+ * is. We'll just try both.
+ */
dh = d2i_DHparams_bio(in, NULL);
- else /* informat == FORMAT_PEM */
+ /* BIO_reset() returns 0 for success for file BIOs only!!! */
+ if (dh == NULL && BIO_reset(in) == 0)
+ dh = d2i_DHxparams_bio(in, NULL);
+ } else {
+ /* informat == FORMAT_PEM */
dh = PEM_read_bio_DHparams(in, NULL, NULL, NULL);
+ }
if (dh == NULL) {
BIO_printf(bio_err, "unable to load DH parameters\n");
@@ -484,10 +493,13 @@ int MAIN(int argc, char **argv)
}
if (!noout) {
- if (outformat == FORMAT_ASN1)
- i = i2d_DHparams_bio(out, dh);
- else if (outformat == FORMAT_PEM) {
- if (dh->q)
+ if (outformat == FORMAT_ASN1) {
+ if (dh->q != NULL)
+ i = i2d_DHxparams_bio(out, dh);
+ else
+ i = i2d_DHparams_bio(out, dh);
+ } else if (outformat == FORMAT_PEM) {
+ if (dh->q != NULL)
i = PEM_write_bio_DHxparams(out, dh);
else
i = PEM_write_bio_DHparams(out, dh);