xref: /dpdk/examples/fips_validation/fips_validation_sha.c (revision f4797bae00502b9fd3db0bae80cd933f69b33060)
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