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
parse_interim_algo(__rte_unused const char * key,char * text,__rte_unused struct fips_val * val)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
parse_test_sha_writeback(struct fips_val * val)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
rsp_test_sha_check(struct fips_val * val)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
parse_test_sha_init(void)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