xref: /dpdk/examples/fips_validation/fips_validation.h (revision 8d70a19417ad70accc3e138190875ff8f2baae8c)
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 
8*8d70a194SDavid Marchand #ifdef USE_JANSSON
9f556293fSBrandon Lo #include <jansson.h>
10*8d70a194SDavid Marchand #endif /* USE_JANSSON */
11f556293fSBrandon Lo 
123d0fad56SMarko Kovacevic #define FIPS_PARSE_ERR(fmt, args)					\
133d0fad56SMarko Kovacevic 	RTE_LOG(ERR, USER1, "FIPS parse error" ## fmt ## "\n", ## args)
143d0fad56SMarko Kovacevic 
153d0fad56SMarko Kovacevic #define ERR_MSG_SIZE		128
163d0fad56SMarko Kovacevic #define MAX_CASE_LINE		15
173d0fad56SMarko Kovacevic #define MAX_LINE_CHAR		204800 /*< max number of characters per line */
183d0fad56SMarko Kovacevic #define MAX_NB_TESTS		10240
19952e10cdSFan Zhang #define DEF_MBUF_SEG_SIZE	(UINT16_MAX - sizeof(struct rte_mbuf) - \
20952e10cdSFan Zhang 				RTE_PKTMBUF_HEADROOM)
213d0fad56SMarko Kovacevic #define MAX_STRING_SIZE		64
229275af3bSOlivier Matz #define MAX_FILE_NAME_SIZE	256
23f4797baeSDamian Nowak #define MAX_DIGEST_SIZE		64
243d0fad56SMarko Kovacevic 
253d0fad56SMarko Kovacevic #define POSITIVE_TEST		0
263d0fad56SMarko Kovacevic #define NEGATIVE_TEST		-1
273d0fad56SMarko Kovacevic 
28f556293fSBrandon Lo #define REQ_FILE_PREFIX		"req"
29f556293fSBrandon Lo #define RSP_FILE_PREFIX		"rsp"
30f556293fSBrandon Lo #define FAX_FILE_PREFIX		"fax"
31f556293fSBrandon Lo #define JSON_FILE_PREFIX	"json"
32f556293fSBrandon Lo 
33f556293fSBrandon Lo #define ACVVERSION			"1.0"
343d0fad56SMarko Kovacevic 
353d0fad56SMarko Kovacevic enum fips_test_algorithms {
36cd255ccfSMarko Kovacevic 		FIPS_TEST_ALGO_AES = 0,
374aaad299SMarko Kovacevic 		FIPS_TEST_ALGO_AES_GCM,
38ac026f46SMarko Kovacevic 		FIPS_TEST_ALGO_AES_CMAC,
39305921f4SMarko Kovacevic 		FIPS_TEST_ALGO_AES_CCM,
40f64adb67SMarko Kovacevic 		FIPS_TEST_ALGO_HMAC,
41527cbf3dSMarko Kovacevic 		FIPS_TEST_ALGO_TDES,
42f4797baeSDamian Nowak 		FIPS_TEST_ALGO_SHA,
43d5a9ea55SSucharitha Sarananaga 		FIPS_TEST_ALGO_AES_XTS,
443d0fad56SMarko Kovacevic 		FIPS_TEST_ALGO_MAX
453d0fad56SMarko Kovacevic };
463d0fad56SMarko Kovacevic 
473d0fad56SMarko Kovacevic enum file_types {
483d0fad56SMarko Kovacevic 	FIPS_TYPE_REQ = 1,
493d0fad56SMarko Kovacevic 	FIPS_TYPE_FAX,
50f556293fSBrandon Lo 	FIPS_TYPE_RSP,
51f556293fSBrandon Lo 	FIPS_TYPE_JSON,
523d0fad56SMarko Kovacevic };
533d0fad56SMarko Kovacevic 
543d0fad56SMarko Kovacevic enum fips_test_op {
553d0fad56SMarko Kovacevic 	FIPS_TEST_ENC_AUTH_GEN = 1,
563d0fad56SMarko Kovacevic 	FIPS_TEST_DEC_AUTH_VERIF,
573d0fad56SMarko Kovacevic };
583d0fad56SMarko Kovacevic 
593d0fad56SMarko Kovacevic #define MAX_LINE_PER_VECTOR            16
603d0fad56SMarko Kovacevic 
613d0fad56SMarko Kovacevic struct fips_val {
623d0fad56SMarko Kovacevic 	uint8_t *val;
633d0fad56SMarko Kovacevic 	uint32_t len;
643d0fad56SMarko Kovacevic };
653d0fad56SMarko Kovacevic 
663d0fad56SMarko Kovacevic struct fips_test_vector {
673d0fad56SMarko Kovacevic 	union {
683d0fad56SMarko Kovacevic 		struct {
693d0fad56SMarko Kovacevic 			struct fips_val key;
703d0fad56SMarko Kovacevic 			struct fips_val digest;
713d0fad56SMarko Kovacevic 			struct fips_val auth_aad;
723d0fad56SMarko Kovacevic 			struct fips_val aad;
733d0fad56SMarko Kovacevic 		} cipher_auth;
743d0fad56SMarko Kovacevic 		struct {
753d0fad56SMarko Kovacevic 			struct fips_val key;
763d0fad56SMarko Kovacevic 			struct fips_val digest;
773d0fad56SMarko Kovacevic 			struct fips_val aad;
783d0fad56SMarko Kovacevic 		} aead;
793d0fad56SMarko Kovacevic 	};
803d0fad56SMarko Kovacevic 
813d0fad56SMarko Kovacevic 	struct fips_val pt;
823d0fad56SMarko Kovacevic 	struct fips_val ct;
833d0fad56SMarko Kovacevic 	struct fips_val iv;
843d0fad56SMarko Kovacevic 
853d0fad56SMarko Kovacevic 	enum rte_crypto_op_status status;
863d0fad56SMarko Kovacevic };
873d0fad56SMarko Kovacevic 
883d0fad56SMarko Kovacevic typedef int (*post_prcess_t)(struct fips_val *val);
893d0fad56SMarko Kovacevic 
903d0fad56SMarko Kovacevic typedef int (*parse_callback_t)(const char *key, char *text,
913d0fad56SMarko Kovacevic 		struct fips_val *val);
923d0fad56SMarko Kovacevic 
933d0fad56SMarko Kovacevic struct fips_test_callback {
943d0fad56SMarko Kovacevic 	const char *key;
953d0fad56SMarko Kovacevic 	parse_callback_t cb;
963d0fad56SMarko Kovacevic 	struct fips_val *val;
973d0fad56SMarko Kovacevic };
983d0fad56SMarko Kovacevic 
99cd255ccfSMarko Kovacevic enum fips_aesavs_test_types {
100cd255ccfSMarko Kovacevic 	AESAVS_TYPE_GFXBOX = 1,
101cd255ccfSMarko Kovacevic 	AESAVS_TYPE_KEYSBOX,
102cd255ccfSMarko Kovacevic 	AESAVS_TYPE_VARKEY,
103cd255ccfSMarko Kovacevic 	AESAVS_TYPE_VARTXT,
104cd255ccfSMarko Kovacevic 	AESAVS_TYPE_MMT,
105cd255ccfSMarko Kovacevic 	AESAVS_TYPE_MCT,
1068b8546aaSGowrishankar Muthukrishnan 	AESAVS_TYPE_AFT,
107cd255ccfSMarko Kovacevic };
108cd255ccfSMarko Kovacevic 
109527cbf3dSMarko Kovacevic enum fips_tdes_test_types {
110527cbf3dSMarko Kovacevic 	TDES_INVERSE_PERMUTATION = 0,
111527cbf3dSMarko Kovacevic 	TDES_PERMUTATION,
112527cbf3dSMarko Kovacevic 	TDES_SUBSTITUTION_TABLE,
113527cbf3dSMarko Kovacevic 	TDES_VARIABLE_KEY,
114527cbf3dSMarko Kovacevic 	TDES_VARIABLE_TEXT,
115527cbf3dSMarko Kovacevic 	TDES_KAT,
116527cbf3dSMarko Kovacevic 	TDES_MCT, /* Monte Carlo (Modes) Test */
117527cbf3dSMarko Kovacevic 	TDES_MMT /* Multi block Message Test */
118527cbf3dSMarko Kovacevic };
119527cbf3dSMarko Kovacevic 
120efe3a8dbSMichael Shamis enum fips_tdes_test_mode {
121efe3a8dbSMichael Shamis 	TDES_MODE_CBC = 0,
122efe3a8dbSMichael Shamis 	TDES_MODE_ECB
123efe3a8dbSMichael Shamis };
124efe3a8dbSMichael Shamis 
125305921f4SMarko Kovacevic enum fips_ccm_test_types {
126305921f4SMarko Kovacevic 	CCM_VADT	= 1, /* Variable Associated Data Test */
127305921f4SMarko Kovacevic 	CCM_VPT,		 /* Variable Payload Test */
128305921f4SMarko Kovacevic 	CCM_VNT,		 /* Variable Nonce Test */
129305921f4SMarko Kovacevic 	CCM_VTT,		 /* Variable Tag Test */
130305921f4SMarko Kovacevic 	CCM_DVPT,	 /*  Decryption-Verification Process Test */
131305921f4SMarko Kovacevic };
132305921f4SMarko Kovacevic 
133f4797baeSDamian Nowak enum fips_sha_test_types {
134f4797baeSDamian Nowak 	SHA_KAT = 0,
135f4797baeSDamian Nowak 	SHA_MCT
136f4797baeSDamian Nowak };
137f4797baeSDamian Nowak 
138cd255ccfSMarko Kovacevic struct aesavs_interim_data {
139cd255ccfSMarko Kovacevic 	enum fips_aesavs_test_types test_type;
140cd255ccfSMarko Kovacevic 	uint32_t cipher_algo;
141cd255ccfSMarko Kovacevic 	uint32_t key_len;
142cd255ccfSMarko Kovacevic };
143cd255ccfSMarko Kovacevic 
144f64adb67SMarko Kovacevic struct hmac_interim_data {
145f64adb67SMarko Kovacevic 	enum rte_crypto_auth_algorithm algo;
146f64adb67SMarko Kovacevic };
147f64adb67SMarko Kovacevic 
148527cbf3dSMarko Kovacevic struct tdes_interim_data {
149527cbf3dSMarko Kovacevic 	enum fips_tdes_test_types test_type;
150efe3a8dbSMichael Shamis 	enum fips_tdes_test_mode test_mode;
151527cbf3dSMarko Kovacevic 	uint32_t nb_keys;
152527cbf3dSMarko Kovacevic };
153527cbf3dSMarko Kovacevic 
154305921f4SMarko Kovacevic struct ccm_interim_data {
155305921f4SMarko Kovacevic 	enum fips_ccm_test_types test_type;
156305921f4SMarko Kovacevic 	uint32_t aad_len;
157305921f4SMarko Kovacevic 	uint32_t pt_len;
158305921f4SMarko Kovacevic 	uint32_t digest_len;
159305921f4SMarko Kovacevic 	uint32_t key_len;
160305921f4SMarko Kovacevic 	uint32_t iv_len;
161305921f4SMarko Kovacevic };
162305921f4SMarko Kovacevic 
163f4797baeSDamian Nowak struct sha_interim_data {
164f4797baeSDamian Nowak 	enum fips_sha_test_types test_type;
165f4797baeSDamian Nowak 	enum rte_crypto_auth_algorithm algo;
166f4797baeSDamian Nowak };
167f4797baeSDamian Nowak 
168d09abf2dSFan Zhang struct gcm_interim_data {
169d09abf2dSFan Zhang 	uint8_t is_gmac;
170d09abf2dSFan Zhang 	uint8_t gen_iv;
171d09abf2dSFan Zhang };
172d09abf2dSFan Zhang 
173*8d70a194SDavid Marchand #ifdef USE_JANSSON
174f556293fSBrandon Lo struct fips_test_json_info {
175f556293fSBrandon Lo 	/* Information used for reading from json */
176f556293fSBrandon Lo 	json_t *json_root;
177f556293fSBrandon Lo 	json_t *json_vector_set;
178f556293fSBrandon Lo 	json_t *json_test_group;
179f556293fSBrandon Lo 	json_t *json_test_case;
180f556293fSBrandon Lo 	/* Location of json write output */
181f556293fSBrandon Lo 	json_t *json_write_root;
182f556293fSBrandon Lo 	json_t *json_write_group;
183f556293fSBrandon Lo 	json_t *json_write_set;
184f556293fSBrandon Lo 	json_t *json_write_case;
185f556293fSBrandon Lo 	/* Other info */
186f556293fSBrandon Lo 	uint8_t is_sample;
187f556293fSBrandon Lo };
188*8d70a194SDavid Marchand #endif /* USE_JANSSON */
189f556293fSBrandon Lo 
1903d0fad56SMarko Kovacevic struct fips_test_interim_info {
1913d0fad56SMarko Kovacevic 	FILE *fp_rd;
1923d0fad56SMarko Kovacevic 	FILE *fp_wr;
1933d0fad56SMarko Kovacevic 	enum file_types file_type;
1943d0fad56SMarko Kovacevic 	enum fips_test_algorithms algo;
1953d0fad56SMarko Kovacevic 	char *one_line_text;
1963d0fad56SMarko Kovacevic 	char *vec[MAX_LINE_PER_VECTOR];
19732440cdfSAyuj Verma 	uint32_t vec_start_off;
1983d0fad56SMarko Kovacevic 	uint32_t nb_vec_lines;
1993d0fad56SMarko Kovacevic 	char device_name[MAX_STRING_SIZE];
2009275af3bSOlivier Matz 	char file_name[MAX_FILE_NAME_SIZE];
20179365018SArchana Muniganti 	float version;
2023d0fad56SMarko Kovacevic 
203cd255ccfSMarko Kovacevic 	union {
204cd255ccfSMarko Kovacevic 		struct aesavs_interim_data aes_data;
205f64adb67SMarko Kovacevic 		struct hmac_interim_data hmac_data;
206527cbf3dSMarko Kovacevic 		struct tdes_interim_data tdes_data;
207305921f4SMarko Kovacevic 		struct ccm_interim_data ccm_data;
208f4797baeSDamian Nowak 		struct sha_interim_data sha_data;
209d09abf2dSFan Zhang 		struct gcm_interim_data gcm_data;
210cd255ccfSMarko Kovacevic 	} interim_info;
211cd255ccfSMarko Kovacevic 
2123d0fad56SMarko Kovacevic 	enum fips_test_op op;
2133d0fad56SMarko Kovacevic 
2143d0fad56SMarko Kovacevic 	const struct fips_test_callback *callbacks;
2153d0fad56SMarko Kovacevic 	const struct fips_test_callback *interim_callbacks;
2163d0fad56SMarko Kovacevic 	const struct fips_test_callback *writeback_callbacks;
2173d0fad56SMarko Kovacevic 
2183d0fad56SMarko Kovacevic 	post_prcess_t parse_writeback;
2193d0fad56SMarko Kovacevic 	post_prcess_t kat_check;
2203d0fad56SMarko Kovacevic };
2213d0fad56SMarko Kovacevic 
2223d0fad56SMarko Kovacevic extern struct fips_test_vector vec;
2233d0fad56SMarko Kovacevic extern struct fips_test_interim_info info;
2243d0fad56SMarko Kovacevic 
225*8d70a194SDavid Marchand #ifdef USE_JANSSON
226f556293fSBrandon Lo extern struct fips_test_json_info json_info;
227*8d70a194SDavid Marchand #endif /* USE_JANSSON */
228f556293fSBrandon Lo 
2293d0fad56SMarko Kovacevic int
2303d0fad56SMarko Kovacevic fips_test_init(const char *req_file_path, const char *rsp_file_path,
2313d0fad56SMarko Kovacevic 		const char *device_name);
2323d0fad56SMarko Kovacevic 
2333d0fad56SMarko Kovacevic void
2343d0fad56SMarko Kovacevic fips_test_clear(void);
2353d0fad56SMarko Kovacevic 
2363d0fad56SMarko Kovacevic int
2373d0fad56SMarko Kovacevic fips_test_fetch_one_block(void);
2383d0fad56SMarko Kovacevic 
2393d0fad56SMarko Kovacevic int
2403d0fad56SMarko Kovacevic fips_test_parse_one_case(void);
2413d0fad56SMarko Kovacevic 
2423d0fad56SMarko Kovacevic void
2433d0fad56SMarko Kovacevic fips_test_write_one_case(void);
2443d0fad56SMarko Kovacevic 
245*8d70a194SDavid Marchand #ifdef USE_JANSSON
246f556293fSBrandon Lo int
247f556293fSBrandon Lo fips_test_parse_one_json_vector_set(void);
248f556293fSBrandon Lo 
249f556293fSBrandon Lo int
250f556293fSBrandon Lo fips_test_parse_one_json_group(void);
251f556293fSBrandon Lo 
252f556293fSBrandon Lo int
253f556293fSBrandon Lo fips_test_parse_one_json_case(void);
254b09aac2dSBrandon Lo 
255b09aac2dSBrandon Lo int
256b09aac2dSBrandon Lo parse_test_gcm_json_init(void);
257443c93d8SBrandon Lo 
258443c93d8SBrandon Lo int
259443c93d8SBrandon Lo parse_test_hmac_json_init(void);
260443c93d8SBrandon Lo 
261443c93d8SBrandon Lo int
262443c93d8SBrandon Lo parse_test_hmac_json_algorithm(void);
263d3b50557SBrandon Lo 
264d3b50557SBrandon Lo int
265d3b50557SBrandon Lo parse_test_cmac_json_init(void);
2668b8546aaSGowrishankar Muthukrishnan 
2678b8546aaSGowrishankar Muthukrishnan int
2688b8546aaSGowrishankar Muthukrishnan parse_test_aes_json_init(void);
269*8d70a194SDavid Marchand #endif /* USE_JANSSON */
270f556293fSBrandon Lo 
2713d0fad56SMarko Kovacevic int
272cd255ccfSMarko Kovacevic parse_test_aes_init(void);
273cd255ccfSMarko Kovacevic 
274cd255ccfSMarko Kovacevic int
275527cbf3dSMarko Kovacevic parse_test_tdes_init(void);
276527cbf3dSMarko Kovacevic 
277527cbf3dSMarko Kovacevic int
278f64adb67SMarko Kovacevic parse_test_hmac_init(void);
279f64adb67SMarko Kovacevic 
280f64adb67SMarko Kovacevic int
2814aaad299SMarko Kovacevic parse_test_gcm_init(void);
2824aaad299SMarko Kovacevic 
2834aaad299SMarko Kovacevic int
284ac026f46SMarko Kovacevic parse_test_cmac_init(void);
285ac026f46SMarko Kovacevic 
286ac026f46SMarko Kovacevic int
287305921f4SMarko Kovacevic parse_test_ccm_init(void);
288305921f4SMarko Kovacevic 
289305921f4SMarko Kovacevic int
290f4797baeSDamian Nowak parse_test_sha_init(void);
291f4797baeSDamian Nowak 
292f4797baeSDamian Nowak int
293d5a9ea55SSucharitha Sarananaga parse_test_xts_init(void);
294d5a9ea55SSucharitha Sarananaga 
295d5a9ea55SSucharitha Sarananaga int
2963d0fad56SMarko Kovacevic parser_read_uint8_hex(uint8_t *value, const char *p);
2973d0fad56SMarko Kovacevic 
2983d0fad56SMarko Kovacevic int
2993d0fad56SMarko Kovacevic parse_uint8_hex_str(const char *key, char *src, struct fips_val *val);
3003d0fad56SMarko Kovacevic 
3013d0fad56SMarko Kovacevic int
3023d0fad56SMarko Kovacevic parse_uint8_known_len_hex_str(const char *key, char *src, struct fips_val *val);
3033d0fad56SMarko Kovacevic 
3043d0fad56SMarko Kovacevic int
305fc6e6515SIbtisam Tariq parser_read_uint16(uint16_t *value, const char *p);
306fc6e6515SIbtisam Tariq 
307fc6e6515SIbtisam Tariq int
3083d0fad56SMarko Kovacevic parser_read_uint32_val(const char *key, char *src, struct fips_val *val);
3093d0fad56SMarko Kovacevic 
3103d0fad56SMarko Kovacevic int
3113d0fad56SMarko Kovacevic parser_read_uint32_bit_val(const char *key, char *src, struct fips_val *val);
3123d0fad56SMarko Kovacevic 
3133d0fad56SMarko Kovacevic int
3143d0fad56SMarko Kovacevic parser_read_uint32(uint32_t *value, char *p);
3153d0fad56SMarko Kovacevic 
3163d0fad56SMarko Kovacevic int
3173d0fad56SMarko Kovacevic parser_read_uint32_val(const char *key, char *src, struct fips_val *val);
3183d0fad56SMarko Kovacevic 
3193d0fad56SMarko Kovacevic int
3203d0fad56SMarko Kovacevic writeback_hex_str(const char *key, char *dst, struct fips_val *val);
3213d0fad56SMarko Kovacevic 
3223d0fad56SMarko Kovacevic void
3233d0fad56SMarko Kovacevic parse_write_hex_str(struct fips_val *src);
3243d0fad56SMarko Kovacevic 
3253d0fad56SMarko Kovacevic int
3263d0fad56SMarko Kovacevic update_info_vec(uint32_t count);
3273d0fad56SMarko Kovacevic 
328d09abf2dSFan Zhang typedef int (*fips_test_one_case_t)(void);
329d09abf2dSFan Zhang typedef int (*fips_prepare_op_t)(void);
330d09abf2dSFan Zhang typedef int (*fips_prepare_xform_t)(struct rte_crypto_sym_xform *);
331d09abf2dSFan Zhang 
332d09abf2dSFan Zhang struct fips_test_ops {
333d09abf2dSFan Zhang 	fips_prepare_xform_t prepare_xform;
334d09abf2dSFan Zhang 	fips_prepare_op_t prepare_op;
335d09abf2dSFan Zhang 	fips_test_one_case_t test;
336d09abf2dSFan Zhang };
337d09abf2dSFan Zhang 
338d09abf2dSFan Zhang extern struct fips_test_ops test_ops;
339d09abf2dSFan Zhang 
340d09abf2dSFan Zhang int prepare_aead_op(void);
341d09abf2dSFan Zhang 
342d09abf2dSFan Zhang int prepare_auth_op(void);
343d09abf2dSFan Zhang 
344d09abf2dSFan Zhang int prepare_gcm_xform(struct rte_crypto_sym_xform *xform);
345d09abf2dSFan Zhang 
346d09abf2dSFan Zhang int prepare_gmac_xform(struct rte_crypto_sym_xform *xform);
347d09abf2dSFan Zhang 
3483d0fad56SMarko Kovacevic #endif
349