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