xref: /dpdk/examples/fips_validation/fips_validation.h (revision fc6e6515c7a666475b8be1add18f49d10f255d66)
13d0fad56SMarko Kovacevic /* SPDX-License-Identifier: BSD-3-Clause
23d0fad56SMarko Kovacevic  * Copyright(c) 2018 Intel Corporation
33d0fad56SMarko Kovacevic  */
43d0fad56SMarko Kovacevic 
53d0fad56SMarko Kovacevic #ifndef _FIPS_VALIDATION_H_
63d0fad56SMarko Kovacevic #define _FIPS_VALIDATION_H_
73d0fad56SMarko Kovacevic 
83d0fad56SMarko Kovacevic #define FIPS_PARSE_ERR(fmt, args)					\
93d0fad56SMarko Kovacevic 	RTE_LOG(ERR, USER1, "FIPS parse error" ## fmt ## "\n", ## args)
103d0fad56SMarko Kovacevic 
113d0fad56SMarko Kovacevic #define ERR_MSG_SIZE		128
123d0fad56SMarko Kovacevic #define MAX_CASE_LINE		15
133d0fad56SMarko Kovacevic #define MAX_LINE_CHAR		204800 /*< max number of characters per line */
143d0fad56SMarko Kovacevic #define MAX_NB_TESTS		10240
15952e10cdSFan Zhang #define DEF_MBUF_SEG_SIZE	(UINT16_MAX - sizeof(struct rte_mbuf) - \
16952e10cdSFan Zhang 				RTE_PKTMBUF_HEADROOM)
173d0fad56SMarko Kovacevic #define MAX_STRING_SIZE		64
189275af3bSOlivier Matz #define MAX_FILE_NAME_SIZE	256
19f4797baeSDamian Nowak #define MAX_DIGEST_SIZE		64
203d0fad56SMarko Kovacevic 
213d0fad56SMarko Kovacevic #define POSITIVE_TEST		0
223d0fad56SMarko Kovacevic #define NEGATIVE_TEST		-1
233d0fad56SMarko Kovacevic 
243d0fad56SMarko Kovacevic #define REQ_FILE_PERFIX		"req"
253d0fad56SMarko Kovacevic #define RSP_FILE_PERFIX		"rsp"
263d0fad56SMarko Kovacevic #define FAX_FILE_PERFIX		"fax"
273d0fad56SMarko Kovacevic 
283d0fad56SMarko Kovacevic enum fips_test_algorithms {
29cd255ccfSMarko Kovacevic 		FIPS_TEST_ALGO_AES = 0,
304aaad299SMarko Kovacevic 		FIPS_TEST_ALGO_AES_GCM,
31ac026f46SMarko Kovacevic 		FIPS_TEST_ALGO_AES_CMAC,
32305921f4SMarko Kovacevic 		FIPS_TEST_ALGO_AES_CCM,
33f64adb67SMarko Kovacevic 		FIPS_TEST_ALGO_HMAC,
34527cbf3dSMarko Kovacevic 		FIPS_TEST_ALGO_TDES,
35f4797baeSDamian Nowak 		FIPS_TEST_ALGO_SHA,
36d5a9ea55SSucharitha Sarananaga 		FIPS_TEST_ALGO_AES_XTS,
373d0fad56SMarko Kovacevic 		FIPS_TEST_ALGO_MAX
383d0fad56SMarko Kovacevic };
393d0fad56SMarko Kovacevic 
403d0fad56SMarko Kovacevic enum file_types {
413d0fad56SMarko Kovacevic 	FIPS_TYPE_REQ = 1,
423d0fad56SMarko Kovacevic 	FIPS_TYPE_FAX,
433d0fad56SMarko Kovacevic 	FIPS_TYPE_RSP
443d0fad56SMarko Kovacevic };
453d0fad56SMarko Kovacevic 
463d0fad56SMarko Kovacevic enum fips_test_op {
473d0fad56SMarko Kovacevic 	FIPS_TEST_ENC_AUTH_GEN = 1,
483d0fad56SMarko Kovacevic 	FIPS_TEST_DEC_AUTH_VERIF,
493d0fad56SMarko Kovacevic };
503d0fad56SMarko Kovacevic 
513d0fad56SMarko Kovacevic #define MAX_LINE_PER_VECTOR            16
523d0fad56SMarko Kovacevic 
533d0fad56SMarko Kovacevic struct fips_val {
543d0fad56SMarko Kovacevic 	uint8_t *val;
553d0fad56SMarko Kovacevic 	uint32_t len;
563d0fad56SMarko Kovacevic };
573d0fad56SMarko Kovacevic 
583d0fad56SMarko Kovacevic struct fips_test_vector {
593d0fad56SMarko Kovacevic 	union {
603d0fad56SMarko Kovacevic 		struct {
613d0fad56SMarko Kovacevic 			struct fips_val key;
623d0fad56SMarko Kovacevic 			struct fips_val digest;
633d0fad56SMarko Kovacevic 			struct fips_val auth_aad;
643d0fad56SMarko Kovacevic 			struct fips_val aad;
653d0fad56SMarko Kovacevic 		} cipher_auth;
663d0fad56SMarko Kovacevic 		struct {
673d0fad56SMarko Kovacevic 			struct fips_val key;
683d0fad56SMarko Kovacevic 			struct fips_val digest;
693d0fad56SMarko Kovacevic 			struct fips_val aad;
703d0fad56SMarko Kovacevic 		} aead;
713d0fad56SMarko Kovacevic 	};
723d0fad56SMarko Kovacevic 
733d0fad56SMarko Kovacevic 	struct fips_val pt;
743d0fad56SMarko Kovacevic 	struct fips_val ct;
753d0fad56SMarko Kovacevic 	struct fips_val iv;
763d0fad56SMarko Kovacevic 
773d0fad56SMarko Kovacevic 	enum rte_crypto_op_status status;
783d0fad56SMarko Kovacevic };
793d0fad56SMarko Kovacevic 
803d0fad56SMarko Kovacevic typedef int (*post_prcess_t)(struct fips_val *val);
813d0fad56SMarko Kovacevic 
823d0fad56SMarko Kovacevic typedef int (*parse_callback_t)(const char *key, char *text,
833d0fad56SMarko Kovacevic 		struct fips_val *val);
843d0fad56SMarko Kovacevic 
853d0fad56SMarko Kovacevic struct fips_test_callback {
863d0fad56SMarko Kovacevic 	const char *key;
873d0fad56SMarko Kovacevic 	parse_callback_t cb;
883d0fad56SMarko Kovacevic 	struct fips_val *val;
893d0fad56SMarko Kovacevic };
903d0fad56SMarko Kovacevic 
91cd255ccfSMarko Kovacevic enum fips_aesavs_test_types {
92cd255ccfSMarko Kovacevic 	AESAVS_TYPE_GFXBOX = 1,
93cd255ccfSMarko Kovacevic 	AESAVS_TYPE_KEYSBOX,
94cd255ccfSMarko Kovacevic 	AESAVS_TYPE_VARKEY,
95cd255ccfSMarko Kovacevic 	AESAVS_TYPE_VARTXT,
96cd255ccfSMarko Kovacevic 	AESAVS_TYPE_MMT,
97cd255ccfSMarko Kovacevic 	AESAVS_TYPE_MCT,
98cd255ccfSMarko Kovacevic };
99cd255ccfSMarko Kovacevic 
100527cbf3dSMarko Kovacevic enum fips_tdes_test_types {
101527cbf3dSMarko Kovacevic 	TDES_INVERSE_PERMUTATION = 0,
102527cbf3dSMarko Kovacevic 	TDES_PERMUTATION,
103527cbf3dSMarko Kovacevic 	TDES_SUBSTITUTION_TABLE,
104527cbf3dSMarko Kovacevic 	TDES_VARIABLE_KEY,
105527cbf3dSMarko Kovacevic 	TDES_VARIABLE_TEXT,
106527cbf3dSMarko Kovacevic 	TDES_KAT,
107527cbf3dSMarko Kovacevic 	TDES_MCT, /* Monte Carlo (Modes) Test */
108527cbf3dSMarko Kovacevic 	TDES_MMT /* Multi block Message Test */
109527cbf3dSMarko Kovacevic };
110527cbf3dSMarko Kovacevic 
111efe3a8dbSMichael Shamis enum fips_tdes_test_mode {
112efe3a8dbSMichael Shamis 	TDES_MODE_CBC = 0,
113efe3a8dbSMichael Shamis 	TDES_MODE_ECB
114efe3a8dbSMichael Shamis };
115efe3a8dbSMichael Shamis 
116305921f4SMarko Kovacevic enum fips_ccm_test_types {
117305921f4SMarko Kovacevic 	CCM_VADT	= 1, /* Variable Associated Data Test */
118305921f4SMarko Kovacevic 	CCM_VPT,		 /* Variable Payload Test */
119305921f4SMarko Kovacevic 	CCM_VNT,		 /* Variable Nonce Test */
120305921f4SMarko Kovacevic 	CCM_VTT,		 /* Variable Tag Test */
121305921f4SMarko Kovacevic 	CCM_DVPT,	 /*  Decryption-Verification Process Test */
122305921f4SMarko Kovacevic };
123305921f4SMarko Kovacevic 
124f4797baeSDamian Nowak enum fips_sha_test_types {
125f4797baeSDamian Nowak 	SHA_KAT = 0,
126f4797baeSDamian Nowak 	SHA_MCT
127f4797baeSDamian Nowak };
128f4797baeSDamian Nowak 
129cd255ccfSMarko Kovacevic struct aesavs_interim_data {
130cd255ccfSMarko Kovacevic 	enum fips_aesavs_test_types test_type;
131cd255ccfSMarko Kovacevic 	uint32_t cipher_algo;
132cd255ccfSMarko Kovacevic 	uint32_t key_len;
133cd255ccfSMarko Kovacevic };
134cd255ccfSMarko Kovacevic 
135f64adb67SMarko Kovacevic struct hmac_interim_data {
136f64adb67SMarko Kovacevic 	enum rte_crypto_auth_algorithm algo;
137f64adb67SMarko Kovacevic };
138f64adb67SMarko Kovacevic 
139527cbf3dSMarko Kovacevic struct tdes_interim_data {
140527cbf3dSMarko Kovacevic 	enum fips_tdes_test_types test_type;
141efe3a8dbSMichael Shamis 	enum fips_tdes_test_mode test_mode;
142527cbf3dSMarko Kovacevic 	uint32_t nb_keys;
143527cbf3dSMarko Kovacevic };
144527cbf3dSMarko Kovacevic 
145305921f4SMarko Kovacevic struct ccm_interim_data {
146305921f4SMarko Kovacevic 	enum fips_ccm_test_types test_type;
147305921f4SMarko Kovacevic 	uint32_t aad_len;
148305921f4SMarko Kovacevic 	uint32_t pt_len;
149305921f4SMarko Kovacevic 	uint32_t digest_len;
150305921f4SMarko Kovacevic 	uint32_t key_len;
151305921f4SMarko Kovacevic 	uint32_t iv_len;
152305921f4SMarko Kovacevic };
153305921f4SMarko Kovacevic 
154f4797baeSDamian Nowak struct sha_interim_data {
155f4797baeSDamian Nowak 	enum fips_sha_test_types test_type;
156f4797baeSDamian Nowak 	enum rte_crypto_auth_algorithm algo;
157f4797baeSDamian Nowak };
158f4797baeSDamian Nowak 
159d09abf2dSFan Zhang struct gcm_interim_data {
160d09abf2dSFan Zhang 	uint8_t is_gmac;
161d09abf2dSFan Zhang 	uint8_t gen_iv;
162d09abf2dSFan Zhang };
163d09abf2dSFan Zhang 
1643d0fad56SMarko Kovacevic struct fips_test_interim_info {
1653d0fad56SMarko Kovacevic 	FILE *fp_rd;
1663d0fad56SMarko Kovacevic 	FILE *fp_wr;
1673d0fad56SMarko Kovacevic 	enum file_types file_type;
1683d0fad56SMarko Kovacevic 	enum fips_test_algorithms algo;
1693d0fad56SMarko Kovacevic 	char *one_line_text;
1703d0fad56SMarko Kovacevic 	char *vec[MAX_LINE_PER_VECTOR];
17132440cdfSAyuj Verma 	uint32_t vec_start_off;
1723d0fad56SMarko Kovacevic 	uint32_t nb_vec_lines;
1733d0fad56SMarko Kovacevic 	char device_name[MAX_STRING_SIZE];
1749275af3bSOlivier Matz 	char file_name[MAX_FILE_NAME_SIZE];
17579365018SArchana Muniganti 	float version;
1763d0fad56SMarko Kovacevic 
177cd255ccfSMarko Kovacevic 	union {
178cd255ccfSMarko Kovacevic 		struct aesavs_interim_data aes_data;
179f64adb67SMarko Kovacevic 		struct hmac_interim_data hmac_data;
180527cbf3dSMarko Kovacevic 		struct tdes_interim_data tdes_data;
181305921f4SMarko Kovacevic 		struct ccm_interim_data ccm_data;
182f4797baeSDamian Nowak 		struct sha_interim_data sha_data;
183d09abf2dSFan Zhang 		struct gcm_interim_data gcm_data;
184cd255ccfSMarko Kovacevic 	} interim_info;
185cd255ccfSMarko Kovacevic 
1863d0fad56SMarko Kovacevic 	enum fips_test_op op;
1873d0fad56SMarko Kovacevic 
1883d0fad56SMarko Kovacevic 	const struct fips_test_callback *callbacks;
1893d0fad56SMarko Kovacevic 	const struct fips_test_callback *interim_callbacks;
1903d0fad56SMarko Kovacevic 	const struct fips_test_callback *writeback_callbacks;
1913d0fad56SMarko Kovacevic 
1923d0fad56SMarko Kovacevic 	post_prcess_t parse_writeback;
1933d0fad56SMarko Kovacevic 	post_prcess_t kat_check;
1943d0fad56SMarko Kovacevic };
1953d0fad56SMarko Kovacevic 
1963d0fad56SMarko Kovacevic extern struct fips_test_vector vec;
1973d0fad56SMarko Kovacevic extern struct fips_test_interim_info info;
1983d0fad56SMarko Kovacevic 
1993d0fad56SMarko Kovacevic int
2003d0fad56SMarko Kovacevic fips_test_init(const char *req_file_path, const char *rsp_file_path,
2013d0fad56SMarko Kovacevic 		const char *device_name);
2023d0fad56SMarko Kovacevic 
2033d0fad56SMarko Kovacevic void
2043d0fad56SMarko Kovacevic fips_test_clear(void);
2053d0fad56SMarko Kovacevic 
2063d0fad56SMarko Kovacevic int
2073d0fad56SMarko Kovacevic fips_test_fetch_one_block(void);
2083d0fad56SMarko Kovacevic 
2093d0fad56SMarko Kovacevic int
2103d0fad56SMarko Kovacevic fips_test_parse_one_case(void);
2113d0fad56SMarko Kovacevic 
2123d0fad56SMarko Kovacevic void
2133d0fad56SMarko Kovacevic fips_test_write_one_case(void);
2143d0fad56SMarko Kovacevic 
2153d0fad56SMarko Kovacevic int
216cd255ccfSMarko Kovacevic parse_test_aes_init(void);
217cd255ccfSMarko Kovacevic 
218cd255ccfSMarko Kovacevic int
219527cbf3dSMarko Kovacevic parse_test_tdes_init(void);
220527cbf3dSMarko Kovacevic 
221527cbf3dSMarko Kovacevic int
222f64adb67SMarko Kovacevic parse_test_hmac_init(void);
223f64adb67SMarko Kovacevic 
224f64adb67SMarko Kovacevic int
2254aaad299SMarko Kovacevic parse_test_gcm_init(void);
2264aaad299SMarko Kovacevic 
2274aaad299SMarko Kovacevic int
228ac026f46SMarko Kovacevic parse_test_cmac_init(void);
229ac026f46SMarko Kovacevic 
230ac026f46SMarko Kovacevic int
231305921f4SMarko Kovacevic parse_test_ccm_init(void);
232305921f4SMarko Kovacevic 
233305921f4SMarko Kovacevic int
234f4797baeSDamian Nowak parse_test_sha_init(void);
235f4797baeSDamian Nowak 
236f4797baeSDamian Nowak int
237d5a9ea55SSucharitha Sarananaga parse_test_xts_init(void);
238d5a9ea55SSucharitha Sarananaga 
239d5a9ea55SSucharitha Sarananaga int
2403d0fad56SMarko Kovacevic parser_read_uint8_hex(uint8_t *value, const char *p);
2413d0fad56SMarko Kovacevic 
2423d0fad56SMarko Kovacevic int
2433d0fad56SMarko Kovacevic parse_uint8_hex_str(const char *key, char *src, struct fips_val *val);
2443d0fad56SMarko Kovacevic 
2453d0fad56SMarko Kovacevic int
2463d0fad56SMarko Kovacevic parse_uint8_known_len_hex_str(const char *key, char *src, struct fips_val *val);
2473d0fad56SMarko Kovacevic 
2483d0fad56SMarko Kovacevic int
249*fc6e6515SIbtisam Tariq parser_read_uint16(uint16_t *value, const char *p);
250*fc6e6515SIbtisam Tariq 
251*fc6e6515SIbtisam Tariq int
2523d0fad56SMarko Kovacevic parser_read_uint32_val(const char *key, char *src, struct fips_val *val);
2533d0fad56SMarko Kovacevic 
2543d0fad56SMarko Kovacevic int
2553d0fad56SMarko Kovacevic parser_read_uint32_bit_val(const char *key, char *src, struct fips_val *val);
2563d0fad56SMarko Kovacevic 
2573d0fad56SMarko Kovacevic int
2583d0fad56SMarko Kovacevic parser_read_uint32(uint32_t *value, char *p);
2593d0fad56SMarko Kovacevic 
2603d0fad56SMarko Kovacevic int
2613d0fad56SMarko Kovacevic parser_read_uint32_val(const char *key, char *src, struct fips_val *val);
2623d0fad56SMarko Kovacevic 
2633d0fad56SMarko Kovacevic int
2643d0fad56SMarko Kovacevic writeback_hex_str(const char *key, char *dst, struct fips_val *val);
2653d0fad56SMarko Kovacevic 
2663d0fad56SMarko Kovacevic void
2673d0fad56SMarko Kovacevic parse_write_hex_str(struct fips_val *src);
2683d0fad56SMarko Kovacevic 
2693d0fad56SMarko Kovacevic int
2703d0fad56SMarko Kovacevic update_info_vec(uint32_t count);
2713d0fad56SMarko Kovacevic 
272d09abf2dSFan Zhang typedef int (*fips_test_one_case_t)(void);
273d09abf2dSFan Zhang typedef int (*fips_prepare_op_t)(void);
274d09abf2dSFan Zhang typedef int (*fips_prepare_xform_t)(struct rte_crypto_sym_xform *);
275d09abf2dSFan Zhang 
276d09abf2dSFan Zhang struct fips_test_ops {
277d09abf2dSFan Zhang 	fips_prepare_xform_t prepare_xform;
278d09abf2dSFan Zhang 	fips_prepare_op_t prepare_op;
279d09abf2dSFan Zhang 	fips_test_one_case_t test;
280d09abf2dSFan Zhang };
281d09abf2dSFan Zhang 
282d09abf2dSFan Zhang extern struct fips_test_ops test_ops;
283d09abf2dSFan Zhang 
284d09abf2dSFan Zhang int prepare_aead_op(void);
285d09abf2dSFan Zhang 
286d09abf2dSFan Zhang int prepare_auth_op(void);
287d09abf2dSFan Zhang 
288d09abf2dSFan Zhang int prepare_gcm_xform(struct rte_crypto_sym_xform *xform);
289d09abf2dSFan Zhang 
290d09abf2dSFan Zhang int prepare_gmac_xform(struct rte_crypto_sym_xform *xform);
291d09abf2dSFan Zhang 
2923d0fad56SMarko Kovacevic #endif
293