1f4797baeSDamian Nowak /* SPDX-License-Identifier: BSD-3-Clause 2f4797baeSDamian Nowak * Copyright(c) 2019 Intel Corporation 3f4797baeSDamian Nowak */ 4f4797baeSDamian Nowak 5f4797baeSDamian Nowak #include <string.h> 6f4797baeSDamian Nowak #include <time.h> 7f4797baeSDamian Nowak #include <stdio.h> 8f4797baeSDamian Nowak 9f4797baeSDamian Nowak #include <rte_cryptodev.h> 10f4797baeSDamian Nowak 11f4797baeSDamian Nowak #include "fips_validation.h" 12f4797baeSDamian Nowak 13f4797baeSDamian Nowak #define ALGO_PREFIX "[L = " 14f4797baeSDamian Nowak #define MSGLEN_STR "Len = " 15f4797baeSDamian Nowak #define MSG_STR "Msg = " 16f4797baeSDamian Nowak #define MD_STR "MD = " 17f4797baeSDamian Nowak #define SEED_STR "Seed = " 18f4797baeSDamian Nowak #define MCT_STR "Monte" 19f4797baeSDamian Nowak 20f4797baeSDamian Nowak struct plain_hash_size_conversion { 21f4797baeSDamian Nowak const char *str; 22f4797baeSDamian Nowak enum rte_crypto_auth_algorithm algo; 23f4797baeSDamian Nowak } phsc[] = { 24f4797baeSDamian Nowak {"20", RTE_CRYPTO_AUTH_SHA1}, 25f4797baeSDamian Nowak {"28", RTE_CRYPTO_AUTH_SHA224}, 26f4797baeSDamian Nowak {"32", RTE_CRYPTO_AUTH_SHA256}, 27f4797baeSDamian Nowak {"48", RTE_CRYPTO_AUTH_SHA384}, 28f4797baeSDamian Nowak {"64", RTE_CRYPTO_AUTH_SHA512}, 29f4797baeSDamian Nowak }; 30f4797baeSDamian Nowak 31f4797baeSDamian Nowak static int 32*f2fc83b4SThomas Monjalon parse_interim_algo(__rte_unused const char *key, 33f4797baeSDamian Nowak char *text, 34*f2fc83b4SThomas Monjalon __rte_unused struct fips_val *val) 35f4797baeSDamian Nowak { 36f4797baeSDamian Nowak uint32_t i; 37f4797baeSDamian Nowak 38f4797baeSDamian Nowak for (i = 0; i < RTE_DIM(phsc); i++) { 39f4797baeSDamian Nowak if (strstr(text, phsc[i].str)) { 40f4797baeSDamian Nowak info.interim_info.sha_data.algo = phsc[i].algo; 41f4797baeSDamian Nowak parser_read_uint32_val(ALGO_PREFIX, 42f4797baeSDamian Nowak text, &vec.cipher_auth.digest); 43f4797baeSDamian Nowak break; 44f4797baeSDamian Nowak } 45f4797baeSDamian Nowak } 46f4797baeSDamian Nowak 47f4797baeSDamian Nowak if (i == RTE_DIM(phsc)) 48f4797baeSDamian Nowak return -1; 49f4797baeSDamian Nowak 50f4797baeSDamian Nowak return 0; 51f4797baeSDamian Nowak } 52f4797baeSDamian Nowak 53f4797baeSDamian Nowak struct fips_test_callback sha_tests_vectors[] = { 54f4797baeSDamian Nowak {MSGLEN_STR, parser_read_uint32_bit_val, &vec.pt}, 55f4797baeSDamian Nowak {MSG_STR, parse_uint8_known_len_hex_str, &vec.pt}, 56f4797baeSDamian Nowak {SEED_STR, parse_uint8_hex_str, &vec.cipher_auth.digest}, 57f4797baeSDamian Nowak {NULL, NULL, NULL} /**< end pointer */ 58f4797baeSDamian Nowak }; 59f4797baeSDamian Nowak 60f4797baeSDamian Nowak struct fips_test_callback sha_tests_interim_vectors[] = { 61f4797baeSDamian Nowak {ALGO_PREFIX, parse_interim_algo, NULL}, 62f4797baeSDamian Nowak {NULL, NULL, NULL} /**< end pointer */ 63f4797baeSDamian Nowak }; 64f4797baeSDamian Nowak 65f4797baeSDamian Nowak static int 66f4797baeSDamian Nowak parse_test_sha_writeback(struct fips_val *val) // ! 67f4797baeSDamian Nowak { 68f4797baeSDamian Nowak struct fips_val val_local; 69f4797baeSDamian Nowak 70f4797baeSDamian Nowak fprintf(info.fp_wr, "%s", MD_STR); 71f4797baeSDamian Nowak 72f4797baeSDamian Nowak val_local.val = val->val + vec.pt.len; 73f4797baeSDamian Nowak val_local.len = vec.cipher_auth.digest.len; 74f4797baeSDamian Nowak 75f4797baeSDamian Nowak parse_write_hex_str(&val_local); 76f4797baeSDamian Nowak return 0; 77f4797baeSDamian Nowak } 78f4797baeSDamian Nowak 79f4797baeSDamian Nowak static int 80f4797baeSDamian Nowak rsp_test_sha_check(struct fips_val *val) 81f4797baeSDamian Nowak { 82f4797baeSDamian Nowak if (memcmp(val->val + vec.pt.len, vec.cipher_auth.digest.val, 83f4797baeSDamian Nowak vec.cipher_auth.digest.len) == 0) 84f4797baeSDamian Nowak fprintf(info.fp_wr, "Success\n"); 85f4797baeSDamian Nowak else 86f4797baeSDamian Nowak fprintf(info.fp_wr, "Failed\n"); 87f4797baeSDamian Nowak 88f4797baeSDamian Nowak return 0; 89f4797baeSDamian Nowak } 90f4797baeSDamian Nowak 91f4797baeSDamian Nowak int 92f4797baeSDamian Nowak parse_test_sha_init(void) 93f4797baeSDamian Nowak { 94f4797baeSDamian Nowak uint32_t i; 95f4797baeSDamian Nowak 96f4797baeSDamian Nowak info.interim_info.sha_data.test_type = SHA_KAT; 97f4797baeSDamian Nowak for (i = 0; i < info.nb_vec_lines; i++) { 98f4797baeSDamian Nowak char *line = info.vec[i]; 99f4797baeSDamian Nowak if (strstr(line, MCT_STR)) 100f4797baeSDamian Nowak info.interim_info.sha_data.test_type = SHA_MCT; 101f4797baeSDamian Nowak } 102f4797baeSDamian Nowak 103f4797baeSDamian Nowak info.op = FIPS_TEST_ENC_AUTH_GEN; 104f4797baeSDamian Nowak info.parse_writeback = parse_test_sha_writeback; 105f4797baeSDamian Nowak info.callbacks = sha_tests_vectors; 106f4797baeSDamian Nowak info.interim_callbacks = sha_tests_interim_vectors; 107f4797baeSDamian Nowak info.writeback_callbacks = NULL; 108f4797baeSDamian Nowak info.kat_check = rsp_test_sha_check; 109f4797baeSDamian Nowak return 0; 110f4797baeSDamian Nowak } 111