X-Git-Url: https://git.openssl.org/?p=openssl.git;a=blobdiff_plain;f=apps%2Fdgst.c;h=deb829ae199be5641ad99538741515e3609e7317;hp=147c4f9e61ff89ca7d8b5a5963b43260c0446a67;hb=f03620ea15c4553de375258bc40bbf7a4092da90;hpb=47b2e238e5684eb0a31d363e2c8b949527b59306 diff --git a/apps/dgst.c b/apps/dgst.c index 147c4f9e61..deb829ae19 100644 --- a/apps/dgst.c +++ b/apps/dgst.c @@ -231,8 +231,6 @@ int MAIN(int argc, char **argv) argv++; } - if (md == NULL) - md=EVP_md5(); if(do_verify && !sigfile) { BIO_printf(bio_err, "No signature to verify: use the -signature option\n"); @@ -447,11 +445,16 @@ int MAIN(int argc, char **argv) } } /* we use md as a filter, reading from 'in' */ - else if (!BIO_set_md(bmd,md)) + else { - BIO_printf(bio_err, "Error setting digest %s\n", pname); - ERR_print_errors(bio_err); - goto end; + if (md == NULL) + md = EVP_md5(); + if (!BIO_set_md(bmd,md)) + { + BIO_printf(bio_err, "Error setting digest %s\n", pname); + ERR_print_errors(bio_err); + goto end; + } } if(sigfile && sigkey) { @@ -476,6 +479,13 @@ int MAIN(int argc, char **argv) } inp=BIO_push(bmd,in); + if (md == NULL) + { + EVP_MD_CTX *tctx; + BIO_get_md_ctx(bmd, &tctx); + md = EVP_MD_CTX_md(tctx); + } + if (argc == 0) { BIO_set_fp(in,stdin,BIO_NOCLOSE);