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