Don't crash if an unrecognised digest is used with dsa_paramgen_md
authorMatt Caswell <matt@openssl.org>
Thu, 29 Mar 2018 16:48:28 +0000 (17:48 +0100)
committerMatt Caswell <matt@openssl.org>
Thu, 5 Apr 2018 16:04:01 +0000 (17:04 +0100)
Reviewed-by: Rich Salz <rsalz@openssl.org>
(Merged from https://github.com/openssl/openssl/pull/5884)

crypto/dsa/dsa_pmeth.c

index 78724839b5249b308f8a3dd4f584ad7c56f22c7b..2d98132a4cac357c7abd19b56e7a1d1f937f4f49 100644 (file)
@@ -230,10 +230,16 @@ static int pkey_dsa_ctrl_str(EVP_PKEY_CTX *ctx,
                                  EVP_PKEY_CTRL_DSA_PARAMGEN_Q_BITS, qbits,
                                  NULL);
     }
-    if (!strcmp(type, "dsa_paramgen_md")) {
+    if (strcmp(type, "dsa_paramgen_md") == 0) {
+        const EVP_MD *md = EVP_get_digestbyname(value);
+
+        if (md == NULL) {
+            DSAerr(DSA_F_PKEY_DSA_CTRL_STR, DSA_R_INVALID_DIGEST_TYPE);
+            return 0;
+        }
         return EVP_PKEY_CTX_ctrl(ctx, EVP_PKEY_DSA, EVP_PKEY_OP_PARAMGEN,
                                  EVP_PKEY_CTRL_DSA_PARAMGEN_MD, 0,
-                                 (void *)EVP_get_digestbyname(value));
+                                 (void *)md);
     }
     return -2;
 }