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