diff --git a/apps/speed.c b/apps/speed.c index 02e7b1f9b2..43c0802295 100644 --- a/apps/speed.c +++ b/apps/speed.c @@ -214,7 +214,11 @@ typedef enum OPTION_choice { } OPTION_CHOICE; const OPTIONS speed_options[] = { - {OPT_HELP_STR, 1, '-', "Usage: %s [options] [algorithm...]\n"}, + {OPT_HELP_STR, 1, '-', + "Usage: %s [options] [algorithm...]\n" + "All +int options consider prefix '0' as base-8 input, " + "prefix '0x'/'0X' as base-16 input.\n" + }, OPT_SECTION("General"), {"help", OPT_HELP, '-', "Display this summary"}, @@ -1543,7 +1547,7 @@ int speed_main(int argc, char **argv) break; case OPT_MULTI: #ifndef NO_FORK - multi = atoi(opt_arg()); + multi = opt_int_arg(); if ((size_t)multi >= SIZE_MAX / sizeof(int)) { BIO_printf(bio_err, "%s: multi argument too large\n", prog); return 0; @@ -1552,7 +1556,7 @@ int speed_main(int argc, char **argv) break; case OPT_ASYNCJOBS: #ifndef OPENSSL_NO_ASYNC - async_jobs = atoi(opt_arg()); + async_jobs = opt_int_arg(); if (!ASYNC_is_capable()) { BIO_printf(bio_err, "%s: async_jobs specified but async not supported\n", @@ -1599,10 +1603,10 @@ int speed_main(int argc, char **argv) case OPT_SECONDS: seconds.sym = seconds.rsa = seconds.dsa = seconds.ecdsa = seconds.ecdh = seconds.eddsa - = seconds.sm2 = seconds.ffdh = atoi(opt_arg()); + = seconds.sm2 = seconds.ffdh = opt_int_arg(); break; case OPT_BYTES: - lengths_single = atoi(opt_arg()); + lengths_single = opt_int_arg(); lengths = &lengths_single; size_num = 1; break;