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