summaryrefslogtreecommitdiffstats
diff options
context:
space:
mode:
authorDmitry Belyavskiy <beldmit@gmail.com>2020-12-21 14:23:17 +0100
committerDmitry Belyavskiy <beldmit@gmail.com>2020-12-23 11:10:16 +0100
commit128d25ba6a9e02481381d47e3a5aa915700b9a1e (patch)
tree189e22ee645b481894f55d288192edc5a0ac16b3
parentc4b2c53fadb158bee34aef90d5a7d500aead1f70 (diff)
Fetch provided algorithm once per benchmark
Partially fixes #13578 Reviewed-by: Matt Caswell <matt@openssl.org> (Merged from https://github.com/openssl/openssl/pull/13721)
-rw-r--r--apps/speed.c50
1 files changed, 46 insertions, 4 deletions
diff --git a/apps/speed.c b/apps/speed.c
index 5b944290fc..c8c4f65b47 100644
--- a/apps/speed.c
+++ b/apps/speed.c
@@ -1003,7 +1003,9 @@ static int EVP_Update_loop_aead(void *args)
return count;
}
-static const EVP_MD *evp_md = NULL;
+static EVP_MD *evp_md = NULL;
+static int fetched_alg = 0;
+
static int EVP_Digest_loop(void *args)
{
loopargs_t *tempargs = *(loopargs_t **) args;
@@ -1491,6 +1493,38 @@ static int run_benchmark(int async_jobs,
return error ? -1 : total_op_count;
}
+static EVP_MD *obtain_md(const char *name)
+{
+ EVP_MD *md = NULL;
+
+ /* Look through providers' digests */
+ ERR_set_mark();
+ md = EVP_MD_fetch(NULL, name, NULL);
+ ERR_pop_to_mark();
+ if (md != NULL) {
+ fetched_alg = 1;
+ return md;
+ }
+
+ return (EVP_MD *)EVP_get_digestbyname(name);
+}
+
+static EVP_CIPHER *obtain_cipher(const char *name)
+{
+ EVP_CIPHER *cipher = NULL;
+
+ /* Look through providers' ciphers */
+ ERR_set_mark();
+ cipher = EVP_CIPHER_fetch(NULL, name, NULL);
+ ERR_pop_to_mark();
+ if (cipher != NULL) {
+ fetched_alg = 1;
+ return cipher;
+ }
+
+ return (EVP_CIPHER *)EVP_get_cipherbyname(name);
+}
+
#define stop_it(do_it, test_num)\
memset(do_it + test_num, 0, OSSL_NELEM(do_it) - test_num);
@@ -1500,7 +1534,7 @@ int speed_main(int argc, char **argv)
loopargs_t *loopargs = NULL;
const char *prog;
const char *engine_id = NULL;
- const EVP_CIPHER *evp_cipher = NULL;
+ EVP_CIPHER *evp_cipher = NULL;
double d = 0.0;
OPTION_CHOICE o;
int async_init = 0, multiblock = 0, pr_header = 0;
@@ -1694,10 +1728,14 @@ int speed_main(int argc, char **argv)
usertime = 0;
break;
case OPT_EVP:
+ if (doit[D_EVP]) {
+ BIO_printf(bio_err, "%s: -evp option cannot be used more than once\n", prog);
+ goto opterr;
+ }
evp_md = NULL;
- evp_cipher = EVP_get_cipherbyname(opt_arg());
+ evp_cipher = obtain_cipher(opt_arg());
if (evp_cipher == NULL)
- evp_md = EVP_get_digestbyname(opt_arg());
+ evp_md = obtain_md(opt_arg());
if (evp_cipher == NULL && evp_md == NULL) {
BIO_printf(bio_err,
"%s: %s is an unknown cipher or digest\n",
@@ -4091,6 +4129,10 @@ int speed_main(int argc, char **argv)
}
OPENSSL_free(loopargs);
release_engine(e);
+ if (fetched_alg) {
+ EVP_MD_free(evp_md);
+ EVP_CIPHER_free(evp_cipher);
+ }
return ret;
}