xref: /dpdk/examples/fips_validation/fips_validation.h (revision f4797bae00502b9fd3db0bae80cd933f69b33060)
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
153d0fad56SMarko Kovacevic #define MAX_BUF_SIZE		2048
163d0fad56SMarko Kovacevic #define MAX_STRING_SIZE		64
17*f4797baeSDamian Nowak #define MAX_DIGEST_SIZE		64
183d0fad56SMarko Kovacevic 
193d0fad56SMarko Kovacevic #define POSITIVE_TEST		0
203d0fad56SMarko Kovacevic #define NEGATIVE_TEST		-1
213d0fad56SMarko Kovacevic 
223d0fad56SMarko Kovacevic #define REQ_FILE_PERFIX		"req"
233d0fad56SMarko Kovacevic #define RSP_FILE_PERFIX		"rsp"
243d0fad56SMarko Kovacevic #define FAX_FILE_PERFIX		"fax"
253d0fad56SMarko Kovacevic 
263d0fad56SMarko Kovacevic enum fips_test_algorithms {
27cd255ccfSMarko Kovacevic 		FIPS_TEST_ALGO_AES = 0,
284aaad299SMarko Kovacevic 		FIPS_TEST_ALGO_AES_GCM,
29ac026f46SMarko Kovacevic 		FIPS_TEST_ALGO_AES_CMAC,
30305921f4SMarko Kovacevic 		FIPS_TEST_ALGO_AES_CCM,
31f64adb67SMarko Kovacevic 		FIPS_TEST_ALGO_HMAC,
32527cbf3dSMarko Kovacevic 		FIPS_TEST_ALGO_TDES,
33*f4797baeSDamian Nowak 		FIPS_TEST_ALGO_SHA,
343d0fad56SMarko Kovacevic 		FIPS_TEST_ALGO_MAX
353d0fad56SMarko Kovacevic };
363d0fad56SMarko Kovacevic 
373d0fad56SMarko Kovacevic enum file_types {
383d0fad56SMarko Kovacevic 	FIPS_TYPE_REQ = 1,
393d0fad56SMarko Kovacevic 	FIPS_TYPE_FAX,
403d0fad56SMarko Kovacevic 	FIPS_TYPE_RSP
413d0fad56SMarko Kovacevic };
423d0fad56SMarko Kovacevic 
433d0fad56SMarko Kovacevic enum fips_test_op {
443d0fad56SMarko Kovacevic 	FIPS_TEST_ENC_AUTH_GEN = 1,
453d0fad56SMarko Kovacevic 	FIPS_TEST_DEC_AUTH_VERIF,
463d0fad56SMarko Kovacevic };
473d0fad56SMarko Kovacevic 
483d0fad56SMarko Kovacevic #define MAX_LINE_PER_VECTOR            16
493d0fad56SMarko Kovacevic 
503d0fad56SMarko Kovacevic struct fips_val {
513d0fad56SMarko Kovacevic 	uint8_t *val;
523d0fad56SMarko Kovacevic 	uint32_t len;
533d0fad56SMarko Kovacevic };
543d0fad56SMarko Kovacevic 
553d0fad56SMarko Kovacevic struct fips_test_vector {
563d0fad56SMarko Kovacevic 	union {
573d0fad56SMarko Kovacevic 		struct {
583d0fad56SMarko Kovacevic 			struct fips_val key;
593d0fad56SMarko Kovacevic 			struct fips_val digest;
603d0fad56SMarko Kovacevic 			struct fips_val auth_aad;
613d0fad56SMarko Kovacevic 			struct fips_val aad;
623d0fad56SMarko Kovacevic 		} cipher_auth;
633d0fad56SMarko Kovacevic 		struct {
643d0fad56SMarko Kovacevic 			struct fips_val key;
653d0fad56SMarko Kovacevic 			struct fips_val digest;
663d0fad56SMarko Kovacevic 			struct fips_val aad;
673d0fad56SMarko Kovacevic 		} aead;
683d0fad56SMarko Kovacevic 	};
693d0fad56SMarko Kovacevic 
703d0fad56SMarko Kovacevic 	struct fips_val pt;
713d0fad56SMarko Kovacevic 	struct fips_val ct;
723d0fad56SMarko Kovacevic 	struct fips_val iv;
733d0fad56SMarko Kovacevic 
743d0fad56SMarko Kovacevic 	enum rte_crypto_op_status status;
753d0fad56SMarko Kovacevic };
763d0fad56SMarko Kovacevic 
773d0fad56SMarko Kovacevic typedef int (*post_prcess_t)(struct fips_val *val);
783d0fad56SMarko Kovacevic 
793d0fad56SMarko Kovacevic typedef int (*parse_callback_t)(const char *key, char *text,
803d0fad56SMarko Kovacevic 		struct fips_val *val);
813d0fad56SMarko Kovacevic 
823d0fad56SMarko Kovacevic struct fips_test_callback {
833d0fad56SMarko Kovacevic 	const char *key;
843d0fad56SMarko Kovacevic 	parse_callback_t cb;
853d0fad56SMarko Kovacevic 	struct fips_val *val;
863d0fad56SMarko Kovacevic };
873d0fad56SMarko Kovacevic 
88cd255ccfSMarko Kovacevic enum fips_aesavs_test_types {
89cd255ccfSMarko Kovacevic 	AESAVS_TYPE_GFXBOX = 1,
90cd255ccfSMarko Kovacevic 	AESAVS_TYPE_KEYSBOX,
91cd255ccfSMarko Kovacevic 	AESAVS_TYPE_VARKEY,
92cd255ccfSMarko Kovacevic 	AESAVS_TYPE_VARTXT,
93cd255ccfSMarko Kovacevic 	AESAVS_TYPE_MMT,
94cd255ccfSMarko Kovacevic 	AESAVS_TYPE_MCT,
95cd255ccfSMarko Kovacevic };
96cd255ccfSMarko Kovacevic 
97527cbf3dSMarko Kovacevic enum fips_tdes_test_types {
98527cbf3dSMarko Kovacevic 	TDES_INVERSE_PERMUTATION = 0,
99527cbf3dSMarko Kovacevic 	TDES_PERMUTATION,
100527cbf3dSMarko Kovacevic 	TDES_SUBSTITUTION_TABLE,
101527cbf3dSMarko Kovacevic 	TDES_VARIABLE_KEY,
102527cbf3dSMarko Kovacevic 	TDES_VARIABLE_TEXT,
103527cbf3dSMarko Kovacevic 	TDES_KAT,
104527cbf3dSMarko Kovacevic 	TDES_MCT, /* Monte Carlo (Modes) Test */
105527cbf3dSMarko Kovacevic 	TDES_MMT /* Multi block Message Test */
106527cbf3dSMarko Kovacevic };
107527cbf3dSMarko Kovacevic 
108305921f4SMarko Kovacevic enum fips_ccm_test_types {
109305921f4SMarko Kovacevic 	CCM_VADT	= 1, /* Variable Associated Data Test */
110305921f4SMarko Kovacevic 	CCM_VPT,		 /* Variable Payload Test */
111305921f4SMarko Kovacevic 	CCM_VNT,		 /* Variable Nonce Test */
112305921f4SMarko Kovacevic 	CCM_VTT,		 /* Variable Tag Test */
113305921f4SMarko Kovacevic 	CCM_DVPT,	 /*  Decryption-Verification Process Test */
114305921f4SMarko Kovacevic };
115305921f4SMarko Kovacevic 
116*f4797baeSDamian Nowak enum fips_sha_test_types {
117*f4797baeSDamian Nowak 	SHA_KAT = 0,
118*f4797baeSDamian Nowak 	SHA_MCT
119*f4797baeSDamian Nowak };
120*f4797baeSDamian Nowak 
121cd255ccfSMarko Kovacevic struct aesavs_interim_data {
122cd255ccfSMarko Kovacevic 	enum fips_aesavs_test_types test_type;
123cd255ccfSMarko Kovacevic 	uint32_t cipher_algo;
124cd255ccfSMarko Kovacevic 	uint32_t key_len;
125cd255ccfSMarko Kovacevic };
126cd255ccfSMarko Kovacevic 
127f64adb67SMarko Kovacevic struct hmac_interim_data {
128f64adb67SMarko Kovacevic 	enum rte_crypto_auth_algorithm algo;
129f64adb67SMarko Kovacevic };
130f64adb67SMarko Kovacevic 
131527cbf3dSMarko Kovacevic struct tdes_interim_data {
132527cbf3dSMarko Kovacevic 	enum fips_tdes_test_types test_type;
133527cbf3dSMarko Kovacevic 	uint32_t nb_keys;
134527cbf3dSMarko Kovacevic };
135527cbf3dSMarko Kovacevic 
136305921f4SMarko Kovacevic struct ccm_interim_data {
137305921f4SMarko Kovacevic 	enum fips_ccm_test_types test_type;
138305921f4SMarko Kovacevic 	uint32_t aad_len;
139305921f4SMarko Kovacevic 	uint32_t pt_len;
140305921f4SMarko Kovacevic 	uint32_t digest_len;
141305921f4SMarko Kovacevic 	uint32_t key_len;
142305921f4SMarko Kovacevic 	uint32_t iv_len;
143305921f4SMarko Kovacevic };
144305921f4SMarko Kovacevic 
145*f4797baeSDamian Nowak struct sha_interim_data {
146*f4797baeSDamian Nowak 	enum fips_sha_test_types test_type;
147*f4797baeSDamian Nowak 	enum rte_crypto_auth_algorithm algo;
148*f4797baeSDamian Nowak };
149*f4797baeSDamian Nowak 
1503d0fad56SMarko Kovacevic struct fips_test_interim_info {
1513d0fad56SMarko Kovacevic 	FILE *fp_rd;
1523d0fad56SMarko Kovacevic 	FILE *fp_wr;
1533d0fad56SMarko Kovacevic 	enum file_types file_type;
1543d0fad56SMarko Kovacevic 	enum fips_test_algorithms algo;
1553d0fad56SMarko Kovacevic 	char *one_line_text;
1563d0fad56SMarko Kovacevic 	char *vec[MAX_LINE_PER_VECTOR];
1573d0fad56SMarko Kovacevic 	uint32_t nb_vec_lines;
1583d0fad56SMarko Kovacevic 	char device_name[MAX_STRING_SIZE];
1593d0fad56SMarko Kovacevic 
160cd255ccfSMarko Kovacevic 	union {
161cd255ccfSMarko Kovacevic 		struct aesavs_interim_data aes_data;
162f64adb67SMarko Kovacevic 		struct hmac_interim_data hmac_data;
163527cbf3dSMarko Kovacevic 		struct tdes_interim_data tdes_data;
164305921f4SMarko Kovacevic 		struct ccm_interim_data ccm_data;
165*f4797baeSDamian Nowak 		struct sha_interim_data sha_data;
166cd255ccfSMarko Kovacevic 	} interim_info;
167cd255ccfSMarko Kovacevic 
1683d0fad56SMarko Kovacevic 	enum fips_test_op op;
1693d0fad56SMarko Kovacevic 
1703d0fad56SMarko Kovacevic 	const struct fips_test_callback *callbacks;
1713d0fad56SMarko Kovacevic 	const struct fips_test_callback *interim_callbacks;
1723d0fad56SMarko Kovacevic 	const struct fips_test_callback *writeback_callbacks;
1733d0fad56SMarko Kovacevic 
1743d0fad56SMarko Kovacevic 	post_prcess_t parse_writeback;
1753d0fad56SMarko Kovacevic 	post_prcess_t kat_check;
1763d0fad56SMarko Kovacevic };
1773d0fad56SMarko Kovacevic 
1783d0fad56SMarko Kovacevic extern struct fips_test_vector vec;
1793d0fad56SMarko Kovacevic extern struct fips_test_interim_info info;
1803d0fad56SMarko Kovacevic 
1813d0fad56SMarko Kovacevic int
1823d0fad56SMarko Kovacevic fips_test_init(const char *req_file_path, const char *rsp_file_path,
1833d0fad56SMarko Kovacevic 		const char *device_name);
1843d0fad56SMarko Kovacevic 
1853d0fad56SMarko Kovacevic void
1863d0fad56SMarko Kovacevic fips_test_clear(void);
1873d0fad56SMarko Kovacevic 
1883d0fad56SMarko Kovacevic int
1893d0fad56SMarko Kovacevic fips_test_fetch_one_block(void);
1903d0fad56SMarko Kovacevic 
1913d0fad56SMarko Kovacevic int
1923d0fad56SMarko Kovacevic fips_test_parse_one_case(void);
1933d0fad56SMarko Kovacevic 
1943d0fad56SMarko Kovacevic void
1953d0fad56SMarko Kovacevic fips_test_write_one_case(void);
1963d0fad56SMarko Kovacevic 
1973d0fad56SMarko Kovacevic int
198cd255ccfSMarko Kovacevic parse_test_aes_init(void);
199cd255ccfSMarko Kovacevic 
200cd255ccfSMarko Kovacevic int
201527cbf3dSMarko Kovacevic parse_test_tdes_init(void);
202527cbf3dSMarko Kovacevic 
203527cbf3dSMarko Kovacevic int
204f64adb67SMarko Kovacevic parse_test_hmac_init(void);
205f64adb67SMarko Kovacevic 
206f64adb67SMarko Kovacevic int
2074aaad299SMarko Kovacevic parse_test_gcm_init(void);
2084aaad299SMarko Kovacevic 
2094aaad299SMarko Kovacevic int
210ac026f46SMarko Kovacevic parse_test_cmac_init(void);
211ac026f46SMarko Kovacevic 
212ac026f46SMarko Kovacevic int
213305921f4SMarko Kovacevic parse_test_ccm_init(void);
214305921f4SMarko Kovacevic 
215305921f4SMarko Kovacevic int
216*f4797baeSDamian Nowak parse_test_sha_init(void);
217*f4797baeSDamian Nowak 
218*f4797baeSDamian Nowak int
2193d0fad56SMarko Kovacevic parser_read_uint8_hex(uint8_t *value, const char *p);
2203d0fad56SMarko Kovacevic 
2213d0fad56SMarko Kovacevic int
2223d0fad56SMarko Kovacevic parse_uint8_hex_str(const char *key, char *src, struct fips_val *val);
2233d0fad56SMarko Kovacevic 
2243d0fad56SMarko Kovacevic int
2253d0fad56SMarko Kovacevic parse_uint8_known_len_hex_str(const char *key, char *src, struct fips_val *val);
2263d0fad56SMarko Kovacevic 
2273d0fad56SMarko Kovacevic int
2283d0fad56SMarko Kovacevic parser_read_uint32_val(const char *key, char *src, struct fips_val *val);
2293d0fad56SMarko Kovacevic 
2303d0fad56SMarko Kovacevic int
2313d0fad56SMarko Kovacevic parser_read_uint32_bit_val(const char *key, char *src, struct fips_val *val);
2323d0fad56SMarko Kovacevic 
2333d0fad56SMarko Kovacevic int
2343d0fad56SMarko Kovacevic parser_read_uint32(uint32_t *value, char *p);
2353d0fad56SMarko Kovacevic 
2363d0fad56SMarko Kovacevic int
2373d0fad56SMarko Kovacevic parser_read_uint32_val(const char *key, char *src, struct fips_val *val);
2383d0fad56SMarko Kovacevic 
2393d0fad56SMarko Kovacevic int
2403d0fad56SMarko Kovacevic writeback_hex_str(const char *key, char *dst, struct fips_val *val);
2413d0fad56SMarko Kovacevic 
2423d0fad56SMarko Kovacevic void
2433d0fad56SMarko Kovacevic parse_write_hex_str(struct fips_val *src);
2443d0fad56SMarko Kovacevic 
2453d0fad56SMarko Kovacevic int
2463d0fad56SMarko Kovacevic update_info_vec(uint32_t count);
2473d0fad56SMarko Kovacevic 
2483d0fad56SMarko Kovacevic #endif
249