Blame SOURCES/nss-fipstest-tls12-prf.patch

3d912a
# HG changeset patch
3d912a
# User Tomas Mraz <tmraz@fedoraproject.org>
3d912a
# Date 1560861770 -7200
3d912a
#      Tue Jun 18 14:42:50 2019 +0200
3d912a
# Node ID 6ef49fe67d6227a1d290da5537ec0dade379a15a
3d912a
# Parent  ebc93d6daeaa9001d31fd18b5199779da99ae9aa
3d912a
Bug 1559906, fipstest: use CKM_TLS12_MASTER_KEY_DERIVE in TLS test, r=rrelyea
3d912a
3d912a
This also lets us CAVS tests more than just SHA256.
3d912a
3d912a
diff --git a/cmd/fipstest/fipstest.c b/cmd/fipstest/fipstest.c
3d912a
--- a/cmd/fipstest/fipstest.c
3d912a
+++ b/cmd/fipstest/fipstest.c
3d912a
@@ -6669,12 +6669,13 @@ tls(char *reqfn)
3d912a
 
3d912a
     CK_MECHANISM master_mech = { CKM_TLS_MASTER_KEY_DERIVE, NULL, 0 };
3d912a
     CK_MECHANISM key_block_mech = { CKM_TLS_KEY_AND_MAC_DERIVE, NULL, 0 };
3d912a
-    CK_SSL3_MASTER_KEY_DERIVE_PARAMS master_params;
3d912a
-    CK_SSL3_KEY_MAT_PARAMS key_block_params;
3d912a
+    CK_TLS12_MASTER_KEY_DERIVE_PARAMS master_params;
3d912a
+    CK_TLS12_KEY_MAT_PARAMS key_block_params;
3d912a
     CK_SSL3_KEY_MAT_OUT key_material;
3d912a
     CK_RV crv;
3d912a
 
3d912a
     /* set up PKCS #11 parameters */
3d912a
+    master_params.prfHashMechanism = CKM_SHA256;
3d912a
     master_params.pVersion = NULL;
3d912a
     master_params.RandomInfo.pClientRandom = clientHello_random;
3d912a
     master_params.RandomInfo.ulClientRandomLen = sizeof(clientHello_random);
3d912a
@@ -6682,6 +6683,7 @@ tls(char *reqfn)
3d912a
     master_params.RandomInfo.ulServerRandomLen = sizeof(serverHello_random);
3d912a
     master_mech.pParameter = (void *)&master_params;
3d912a
     master_mech.ulParameterLen = sizeof(master_params);
3d912a
+    key_block_params.prfHashMechanism = CKM_SHA256;
3d912a
     key_block_params.ulMacSizeInBits = 0;
3d912a
     key_block_params.ulKeySizeInBits = 0;
3d912a
     key_block_params.ulIVSizeInBits = 0;
3d912a
@@ -6724,13 +6726,39 @@ tls(char *reqfn)
3d912a
         if (buf[0] == '[') {
3d912a
             if (strncmp(buf, "[TLS", 4) == 0) {
3d912a
                 if (buf[7] == '0') {
3d912a
+                    /* CK_SSL3_MASTER_KEY_DERIVE_PARAMS is a subset of
3d912a
+                     * CK_TLS12_MASTER_KEY_DERIVE_PARAMS and
3d912a
+                     * CK_SSL3_KEY_MAT_PARAMS is a subset of
3d912a
+                     * CK_TLS12_KEY_MAT_PARAMS. The latter params have
3d912a
+                     * an extra prfHashMechanism field at the end. */
3d912a
                     master_mech.mechanism = CKM_TLS_MASTER_KEY_DERIVE;
3d912a
                     key_block_mech.mechanism = CKM_TLS_KEY_AND_MAC_DERIVE;
3d912a
+                    master_mech.ulParameterLen = sizeof(CK_SSL3_MASTER_KEY_DERIVE_PARAMS);
3d912a
+                    key_block_mech.ulParameterLen = sizeof(CK_SSL3_KEY_MAT_PARAMS);
3d912a
                 } else if (buf[7] == '2') {
3d912a
-                    master_mech.mechanism =
3d912a
-                        CKM_NSS_TLS_MASTER_KEY_DERIVE_SHA256;
3d912a
-                    key_block_mech.mechanism =
3d912a
-                        CKM_NSS_TLS_KEY_AND_MAC_DERIVE_SHA256;
3d912a
+                    if (strncmp(&buf[10], "SHA-1", 5) == 0) {
3d912a
+                        master_params.prfHashMechanism = CKM_SHA_1;
3d912a
+                        key_block_params.prfHashMechanism = CKM_SHA_1;
3d912a
+                    } else if (strncmp(&buf[10], "SHA-224", 7) == 0) {
3d912a
+                        master_params.prfHashMechanism = CKM_SHA224;
3d912a
+                        key_block_params.prfHashMechanism = CKM_SHA224;
3d912a
+                    } else if (strncmp(&buf[10], "SHA-256", 7) == 0) {
3d912a
+                        master_params.prfHashMechanism = CKM_SHA256;
3d912a
+                        key_block_params.prfHashMechanism = CKM_SHA256;
3d912a
+                    } else if (strncmp(&buf[10], "SHA-384", 7) == 0) {
3d912a
+                        master_params.prfHashMechanism = CKM_SHA384;
3d912a
+                        key_block_params.prfHashMechanism = CKM_SHA384;
3d912a
+                    } else if (strncmp(&buf[10], "SHA-512", 7) == 0) {
3d912a
+                        master_params.prfHashMechanism = CKM_SHA512;
3d912a
+                        key_block_params.prfHashMechanism = CKM_SHA512;
3d912a
+                    } else {
3d912a
+                        fprintf(tlsresp, "ERROR: Unable to find prf Hash type");
3d912a
+                        goto loser;
3d912a
+                    }
3d912a
+                    master_mech.mechanism = CKM_TLS12_MASTER_KEY_DERIVE;
3d912a
+                    key_block_mech.mechanism = CKM_TLS12_KEY_AND_MAC_DERIVE;
3d912a
+                    master_mech.ulParameterLen = sizeof(master_params);
3d912a
+                    key_block_mech.ulParameterLen = sizeof(key_block_params);
3d912a
                 } else {
3d912a
                     fprintf(stderr, "Unknown TLS type %x\n",
3d912a
                             (unsigned int)buf[0]);