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 88d70a194SDavid Marchand #ifdef USE_JANSSON 9f556293fSBrandon Lo #include <jansson.h> 108d70a194SDavid 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, 3775777166SGowrishankar Muthukrishnan FIPS_TEST_ALGO_AES_CBC, 384aaad299SMarko Kovacevic FIPS_TEST_ALGO_AES_GCM, 39ac026f46SMarko Kovacevic FIPS_TEST_ALGO_AES_CMAC, 40305921f4SMarko Kovacevic FIPS_TEST_ALGO_AES_CCM, 41f8e431edSGowrishankar Muthukrishnan FIPS_TEST_ALGO_AES_XTS, 42f64adb67SMarko Kovacevic FIPS_TEST_ALGO_HMAC, 43527cbf3dSMarko Kovacevic FIPS_TEST_ALGO_TDES, 44f4797baeSDamian Nowak FIPS_TEST_ALGO_SHA, 453d0fad56SMarko Kovacevic FIPS_TEST_ALGO_MAX 463d0fad56SMarko Kovacevic }; 473d0fad56SMarko Kovacevic 483d0fad56SMarko Kovacevic enum file_types { 493d0fad56SMarko Kovacevic FIPS_TYPE_REQ = 1, 503d0fad56SMarko Kovacevic FIPS_TYPE_FAX, 51f556293fSBrandon Lo FIPS_TYPE_RSP, 52f556293fSBrandon Lo FIPS_TYPE_JSON, 533d0fad56SMarko Kovacevic }; 543d0fad56SMarko Kovacevic 553d0fad56SMarko Kovacevic enum fips_test_op { 563d0fad56SMarko Kovacevic FIPS_TEST_ENC_AUTH_GEN = 1, 573d0fad56SMarko Kovacevic FIPS_TEST_DEC_AUTH_VERIF, 583d0fad56SMarko Kovacevic }; 593d0fad56SMarko Kovacevic 603d0fad56SMarko Kovacevic #define MAX_LINE_PER_VECTOR 16 613d0fad56SMarko Kovacevic 623d0fad56SMarko Kovacevic struct fips_val { 633d0fad56SMarko Kovacevic uint8_t *val; 643d0fad56SMarko Kovacevic uint32_t len; 653d0fad56SMarko Kovacevic }; 663d0fad56SMarko Kovacevic 673d0fad56SMarko Kovacevic struct fips_test_vector { 683d0fad56SMarko Kovacevic union { 693d0fad56SMarko Kovacevic struct { 703d0fad56SMarko Kovacevic struct fips_val key; 713d0fad56SMarko Kovacevic struct fips_val digest; 723d0fad56SMarko Kovacevic struct fips_val auth_aad; 733d0fad56SMarko Kovacevic struct fips_val aad; 743d0fad56SMarko Kovacevic } cipher_auth; 753d0fad56SMarko Kovacevic struct { 763d0fad56SMarko Kovacevic struct fips_val key; 773d0fad56SMarko Kovacevic struct fips_val digest; 783d0fad56SMarko Kovacevic struct fips_val aad; 793d0fad56SMarko Kovacevic } aead; 803d0fad56SMarko Kovacevic }; 813d0fad56SMarko Kovacevic 823d0fad56SMarko Kovacevic struct fips_val pt; 833d0fad56SMarko Kovacevic struct fips_val ct; 843d0fad56SMarko Kovacevic struct fips_val iv; 853d0fad56SMarko Kovacevic 863d0fad56SMarko Kovacevic enum rte_crypto_op_status status; 873d0fad56SMarko Kovacevic }; 883d0fad56SMarko Kovacevic 893d0fad56SMarko Kovacevic typedef int (*post_prcess_t)(struct fips_val *val); 903d0fad56SMarko Kovacevic 913d0fad56SMarko Kovacevic typedef int (*parse_callback_t)(const char *key, char *text, 923d0fad56SMarko Kovacevic struct fips_val *val); 933d0fad56SMarko Kovacevic 943d0fad56SMarko Kovacevic struct fips_test_callback { 953d0fad56SMarko Kovacevic const char *key; 963d0fad56SMarko Kovacevic parse_callback_t cb; 973d0fad56SMarko Kovacevic struct fips_val *val; 983d0fad56SMarko Kovacevic }; 993d0fad56SMarko Kovacevic 100cd255ccfSMarko Kovacevic enum fips_aesavs_test_types { 101cd255ccfSMarko Kovacevic AESAVS_TYPE_GFXBOX = 1, 102cd255ccfSMarko Kovacevic AESAVS_TYPE_KEYSBOX, 103cd255ccfSMarko Kovacevic AESAVS_TYPE_VARKEY, 104cd255ccfSMarko Kovacevic AESAVS_TYPE_VARTXT, 105cd255ccfSMarko Kovacevic AESAVS_TYPE_MMT, 106cd255ccfSMarko Kovacevic AESAVS_TYPE_MCT, 1078b8546aaSGowrishankar Muthukrishnan AESAVS_TYPE_AFT, 108cd255ccfSMarko Kovacevic }; 109cd255ccfSMarko Kovacevic 110527cbf3dSMarko Kovacevic enum fips_tdes_test_types { 111527cbf3dSMarko Kovacevic TDES_INVERSE_PERMUTATION = 0, 112527cbf3dSMarko Kovacevic TDES_PERMUTATION, 113527cbf3dSMarko Kovacevic TDES_SUBSTITUTION_TABLE, 114527cbf3dSMarko Kovacevic TDES_VARIABLE_KEY, 115527cbf3dSMarko Kovacevic TDES_VARIABLE_TEXT, 116527cbf3dSMarko Kovacevic TDES_KAT, 11764569ffaSGowrishankar Muthukrishnan TDES_AFT, /* Functional Test */ 118527cbf3dSMarko Kovacevic TDES_MCT, /* Monte Carlo (Modes) Test */ 119527cbf3dSMarko Kovacevic TDES_MMT /* Multi block Message Test */ 120527cbf3dSMarko Kovacevic }; 121527cbf3dSMarko Kovacevic 122efe3a8dbSMichael Shamis enum fips_tdes_test_mode { 123efe3a8dbSMichael Shamis TDES_MODE_CBC = 0, 124efe3a8dbSMichael Shamis TDES_MODE_ECB 125efe3a8dbSMichael Shamis }; 126efe3a8dbSMichael Shamis 127305921f4SMarko Kovacevic enum fips_ccm_test_types { 128305921f4SMarko Kovacevic CCM_VADT = 1, /* Variable Associated Data Test */ 129305921f4SMarko Kovacevic CCM_VPT, /* Variable Payload Test */ 130305921f4SMarko Kovacevic CCM_VNT, /* Variable Nonce Test */ 131305921f4SMarko Kovacevic CCM_VTT, /* Variable Tag Test */ 132305921f4SMarko Kovacevic CCM_DVPT, /* Decryption-Verification Process Test */ 133305921f4SMarko Kovacevic }; 134305921f4SMarko Kovacevic 135f4797baeSDamian Nowak enum fips_sha_test_types { 136f4797baeSDamian Nowak SHA_KAT = 0, 137d5c24714SGowrishankar Muthukrishnan SHA_AFT, 138f4797baeSDamian Nowak SHA_MCT 139f4797baeSDamian Nowak }; 140f4797baeSDamian Nowak 141cd255ccfSMarko Kovacevic struct aesavs_interim_data { 142cd255ccfSMarko Kovacevic enum fips_aesavs_test_types test_type; 143cd255ccfSMarko Kovacevic uint32_t cipher_algo; 144cd255ccfSMarko Kovacevic uint32_t key_len; 145cd255ccfSMarko Kovacevic }; 146cd255ccfSMarko Kovacevic 147f64adb67SMarko Kovacevic struct hmac_interim_data { 148f64adb67SMarko Kovacevic enum rte_crypto_auth_algorithm algo; 149f64adb67SMarko Kovacevic }; 150f64adb67SMarko Kovacevic 151527cbf3dSMarko Kovacevic struct tdes_interim_data { 152527cbf3dSMarko Kovacevic enum fips_tdes_test_types test_type; 153efe3a8dbSMichael Shamis enum fips_tdes_test_mode test_mode; 154527cbf3dSMarko Kovacevic uint32_t nb_keys; 155527cbf3dSMarko Kovacevic }; 156527cbf3dSMarko Kovacevic 157305921f4SMarko Kovacevic struct ccm_interim_data { 158305921f4SMarko Kovacevic enum fips_ccm_test_types test_type; 159305921f4SMarko Kovacevic uint32_t aad_len; 160305921f4SMarko Kovacevic uint32_t pt_len; 161305921f4SMarko Kovacevic uint32_t digest_len; 162305921f4SMarko Kovacevic uint32_t key_len; 163305921f4SMarko Kovacevic uint32_t iv_len; 164305921f4SMarko Kovacevic }; 165305921f4SMarko Kovacevic 166f4797baeSDamian Nowak struct sha_interim_data { 167f4797baeSDamian Nowak enum fips_sha_test_types test_type; 168f4797baeSDamian Nowak enum rte_crypto_auth_algorithm algo; 169f4797baeSDamian Nowak }; 170f4797baeSDamian Nowak 171d09abf2dSFan Zhang struct gcm_interim_data { 172d09abf2dSFan Zhang uint8_t is_gmac; 173d09abf2dSFan Zhang uint8_t gen_iv; 174d09abf2dSFan Zhang }; 175d09abf2dSFan Zhang 176f8e431edSGowrishankar Muthukrishnan enum xts_tweak_modes { 177f8e431edSGowrishankar Muthukrishnan XTS_TWEAK_MODE_HEX = 0, 178f8e431edSGowrishankar Muthukrishnan XTS_TWEAK_MODE_NUMBER 179f8e431edSGowrishankar Muthukrishnan }; 180f8e431edSGowrishankar Muthukrishnan 181f8e431edSGowrishankar Muthukrishnan struct xts_interim_data { 182f8e431edSGowrishankar Muthukrishnan enum xts_tweak_modes tweak_mode; 183f8e431edSGowrishankar Muthukrishnan }; 184f8e431edSGowrishankar Muthukrishnan 1858d70a194SDavid Marchand #ifdef USE_JANSSON 186f556293fSBrandon Lo struct fips_test_json_info { 187f556293fSBrandon Lo /* Information used for reading from json */ 188f556293fSBrandon Lo json_t *json_root; 189f556293fSBrandon Lo json_t *json_vector_set; 190f556293fSBrandon Lo json_t *json_test_group; 191f556293fSBrandon Lo json_t *json_test_case; 192f556293fSBrandon Lo /* Location of json write output */ 193f556293fSBrandon Lo json_t *json_write_root; 194f556293fSBrandon Lo json_t *json_write_group; 195f556293fSBrandon Lo json_t *json_write_set; 196f556293fSBrandon Lo json_t *json_write_case; 197f556293fSBrandon Lo /* Other info */ 198f556293fSBrandon Lo uint8_t is_sample; 199f556293fSBrandon Lo }; 2008d70a194SDavid Marchand #endif /* USE_JANSSON */ 201f556293fSBrandon Lo 2023d0fad56SMarko Kovacevic struct fips_test_interim_info { 2033d0fad56SMarko Kovacevic FILE *fp_rd; 2043d0fad56SMarko Kovacevic FILE *fp_wr; 2053d0fad56SMarko Kovacevic enum file_types file_type; 2063d0fad56SMarko Kovacevic enum fips_test_algorithms algo; 2073d0fad56SMarko Kovacevic char *one_line_text; 2083d0fad56SMarko Kovacevic char *vec[MAX_LINE_PER_VECTOR]; 20932440cdfSAyuj Verma uint32_t vec_start_off; 2103d0fad56SMarko Kovacevic uint32_t nb_vec_lines; 2113d0fad56SMarko Kovacevic char device_name[MAX_STRING_SIZE]; 2129275af3bSOlivier Matz char file_name[MAX_FILE_NAME_SIZE]; 21379365018SArchana Muniganti float version; 2143d0fad56SMarko Kovacevic 215cd255ccfSMarko Kovacevic union { 216cd255ccfSMarko Kovacevic struct aesavs_interim_data aes_data; 217f64adb67SMarko Kovacevic struct hmac_interim_data hmac_data; 218527cbf3dSMarko Kovacevic struct tdes_interim_data tdes_data; 219305921f4SMarko Kovacevic struct ccm_interim_data ccm_data; 220f4797baeSDamian Nowak struct sha_interim_data sha_data; 221d09abf2dSFan Zhang struct gcm_interim_data gcm_data; 222f8e431edSGowrishankar Muthukrishnan struct xts_interim_data xts_data; 223cd255ccfSMarko Kovacevic } interim_info; 224cd255ccfSMarko Kovacevic 2253d0fad56SMarko Kovacevic enum fips_test_op op; 2263d0fad56SMarko Kovacevic 2273d0fad56SMarko Kovacevic const struct fips_test_callback *callbacks; 2283d0fad56SMarko Kovacevic const struct fips_test_callback *interim_callbacks; 2293d0fad56SMarko Kovacevic const struct fips_test_callback *writeback_callbacks; 2303d0fad56SMarko Kovacevic 2310bd998fbSGowrishankar Muthukrishnan post_prcess_t parse_interim_writeback; 2323d0fad56SMarko Kovacevic post_prcess_t parse_writeback; 2333d0fad56SMarko Kovacevic post_prcess_t kat_check; 2343d0fad56SMarko Kovacevic }; 2353d0fad56SMarko Kovacevic 2363d0fad56SMarko Kovacevic extern struct fips_test_vector vec; 2373d0fad56SMarko Kovacevic extern struct fips_test_interim_info info; 2383d0fad56SMarko Kovacevic 2398d70a194SDavid Marchand #ifdef USE_JANSSON 240f556293fSBrandon Lo extern struct fips_test_json_info json_info; 2418d70a194SDavid Marchand #endif /* USE_JANSSON */ 242f556293fSBrandon Lo 2433d0fad56SMarko Kovacevic int 2443d0fad56SMarko Kovacevic fips_test_init(const char *req_file_path, const char *rsp_file_path, 2453d0fad56SMarko Kovacevic const char *device_name); 2463d0fad56SMarko Kovacevic 2473d0fad56SMarko Kovacevic void 2483d0fad56SMarko Kovacevic fips_test_clear(void); 2493d0fad56SMarko Kovacevic 2503d0fad56SMarko Kovacevic int 2513d0fad56SMarko Kovacevic fips_test_fetch_one_block(void); 2523d0fad56SMarko Kovacevic 2533d0fad56SMarko Kovacevic int 2543d0fad56SMarko Kovacevic fips_test_parse_one_case(void); 2553d0fad56SMarko Kovacevic 2563d0fad56SMarko Kovacevic void 2573d0fad56SMarko Kovacevic fips_test_write_one_case(void); 2583d0fad56SMarko Kovacevic 2598d70a194SDavid Marchand #ifdef USE_JANSSON 260f556293fSBrandon Lo int 261f556293fSBrandon Lo fips_test_parse_one_json_vector_set(void); 262f556293fSBrandon Lo 263f556293fSBrandon Lo int 264f556293fSBrandon Lo fips_test_parse_one_json_group(void); 265f556293fSBrandon Lo 266f556293fSBrandon Lo int 267f556293fSBrandon Lo fips_test_parse_one_json_case(void); 268b09aac2dSBrandon Lo 269b09aac2dSBrandon Lo int 270b09aac2dSBrandon Lo parse_test_gcm_json_init(void); 271443c93d8SBrandon Lo 272443c93d8SBrandon Lo int 273443c93d8SBrandon Lo parse_test_hmac_json_init(void); 274443c93d8SBrandon Lo 275443c93d8SBrandon Lo int 276443c93d8SBrandon Lo parse_test_hmac_json_algorithm(void); 277d3b50557SBrandon Lo 278d3b50557SBrandon Lo int 279d3b50557SBrandon Lo parse_test_cmac_json_init(void); 2808b8546aaSGowrishankar Muthukrishnan 2818b8546aaSGowrishankar Muthukrishnan int 2828b8546aaSGowrishankar Muthukrishnan parse_test_aes_json_init(void); 283f8e431edSGowrishankar Muthukrishnan 284f8e431edSGowrishankar Muthukrishnan int 285f8e431edSGowrishankar Muthukrishnan parse_test_xts_json_init(void); 286d5c24714SGowrishankar Muthukrishnan 287d5c24714SGowrishankar Muthukrishnan int 288d5c24714SGowrishankar Muthukrishnan parse_test_sha_json_init(void); 289d5c24714SGowrishankar Muthukrishnan 290d5c24714SGowrishankar Muthukrishnan int 291d5c24714SGowrishankar Muthukrishnan parse_test_sha_json_algorithm(void); 292d5c24714SGowrishankar Muthukrishnan 293d5c24714SGowrishankar Muthukrishnan int 294d5c24714SGowrishankar Muthukrishnan parse_test_sha_json_test_type(void); 29564569ffaSGowrishankar Muthukrishnan 29664569ffaSGowrishankar Muthukrishnan int 29764569ffaSGowrishankar Muthukrishnan parse_test_tdes_json_init(void); 2988d70a194SDavid Marchand #endif /* USE_JANSSON */ 299f556293fSBrandon Lo 3003d0fad56SMarko Kovacevic int 301cd255ccfSMarko Kovacevic parse_test_aes_init(void); 302cd255ccfSMarko Kovacevic 303cd255ccfSMarko Kovacevic int 304527cbf3dSMarko Kovacevic parse_test_tdes_init(void); 305527cbf3dSMarko Kovacevic 306527cbf3dSMarko Kovacevic int 307f64adb67SMarko Kovacevic parse_test_hmac_init(void); 308f64adb67SMarko Kovacevic 309f64adb67SMarko Kovacevic int 3104aaad299SMarko Kovacevic parse_test_gcm_init(void); 3114aaad299SMarko Kovacevic 3124aaad299SMarko Kovacevic int 313ac026f46SMarko Kovacevic parse_test_cmac_init(void); 314ac026f46SMarko Kovacevic 315ac026f46SMarko Kovacevic int 316305921f4SMarko Kovacevic parse_test_ccm_init(void); 317305921f4SMarko Kovacevic 318305921f4SMarko Kovacevic int 319f4797baeSDamian Nowak parse_test_sha_init(void); 320f4797baeSDamian Nowak 321f4797baeSDamian Nowak int 322d5a9ea55SSucharitha Sarananaga parse_test_xts_init(void); 323d5a9ea55SSucharitha Sarananaga 324d5a9ea55SSucharitha Sarananaga int 3253d0fad56SMarko Kovacevic parser_read_uint8_hex(uint8_t *value, const char *p); 3263d0fad56SMarko Kovacevic 3273d0fad56SMarko Kovacevic int 3283d0fad56SMarko Kovacevic parse_uint8_hex_str(const char *key, char *src, struct fips_val *val); 3293d0fad56SMarko Kovacevic 3303d0fad56SMarko Kovacevic int 3313d0fad56SMarko Kovacevic parse_uint8_known_len_hex_str(const char *key, char *src, struct fips_val *val); 3323d0fad56SMarko Kovacevic 3333d0fad56SMarko Kovacevic int 334fc6e6515SIbtisam Tariq parser_read_uint16(uint16_t *value, const char *p); 335fc6e6515SIbtisam Tariq 336fc6e6515SIbtisam Tariq int 3373d0fad56SMarko Kovacevic parser_read_uint32_val(const char *key, char *src, struct fips_val *val); 3383d0fad56SMarko Kovacevic 3393d0fad56SMarko Kovacevic int 3403d0fad56SMarko Kovacevic parser_read_uint32_bit_val(const char *key, char *src, struct fips_val *val); 3413d0fad56SMarko Kovacevic 3423d0fad56SMarko Kovacevic int 3433d0fad56SMarko Kovacevic parser_read_uint32(uint32_t *value, char *p); 3443d0fad56SMarko Kovacevic 3453d0fad56SMarko Kovacevic int 3463d0fad56SMarko Kovacevic parser_read_uint32_val(const char *key, char *src, struct fips_val *val); 3473d0fad56SMarko Kovacevic 3483d0fad56SMarko Kovacevic int 3493d0fad56SMarko Kovacevic writeback_hex_str(const char *key, char *dst, struct fips_val *val); 3503d0fad56SMarko Kovacevic 3513d0fad56SMarko Kovacevic void 3523d0fad56SMarko Kovacevic parse_write_hex_str(struct fips_val *src); 3533d0fad56SMarko Kovacevic 3543d0fad56SMarko Kovacevic int 3553d0fad56SMarko Kovacevic update_info_vec(uint32_t count); 3563d0fad56SMarko Kovacevic 357d09abf2dSFan Zhang typedef int (*fips_test_one_case_t)(void); 358d09abf2dSFan Zhang typedef int (*fips_prepare_op_t)(void); 359d09abf2dSFan Zhang typedef int (*fips_prepare_xform_t)(struct rte_crypto_sym_xform *); 360d09abf2dSFan Zhang 361d09abf2dSFan Zhang struct fips_test_ops { 362d09abf2dSFan Zhang fips_prepare_xform_t prepare_xform; 363d09abf2dSFan Zhang fips_prepare_op_t prepare_op; 364d09abf2dSFan Zhang fips_test_one_case_t test; 365d09abf2dSFan Zhang }; 366d09abf2dSFan Zhang 367d09abf2dSFan Zhang extern struct fips_test_ops test_ops; 368d09abf2dSFan Zhang 369d09abf2dSFan Zhang int prepare_aead_op(void); 370d09abf2dSFan Zhang 371d09abf2dSFan Zhang int prepare_auth_op(void); 372d09abf2dSFan Zhang 373d09abf2dSFan Zhang int prepare_gcm_xform(struct rte_crypto_sym_xform *xform); 374d09abf2dSFan Zhang 375d09abf2dSFan Zhang int prepare_gmac_xform(struct rte_crypto_sym_xform *xform); 376d09abf2dSFan Zhang 377*8bc8ba43SGowrishankar Muthukrishnan int parse_test_sha_hash_size(enum rte_crypto_auth_algorithm algo); 378*8bc8ba43SGowrishankar Muthukrishnan 3793d0fad56SMarko Kovacevic #endif 380