examples/fips_validation: support TDES parsing
[dpdk.git] / examples / fips_validation / fips_validation.h
index e947de1..69a2116 100644 (file)
@@ -24,6 +24,8 @@
 
 enum fips_test_algorithms {
                FIPS_TEST_ALGO_AES = 0,
+               FIPS_TEST_ALGO_HMAC,
+               FIPS_TEST_ALGO_TDES,
                FIPS_TEST_ALGO_MAX
 };
 
@@ -87,12 +89,32 @@ enum fips_aesavs_test_types {
        AESAVS_TYPE_MCT,
 };
 
+enum fips_tdes_test_types {
+       TDES_INVERSE_PERMUTATION = 0,
+       TDES_PERMUTATION,
+       TDES_SUBSTITUTION_TABLE,
+       TDES_VARIABLE_KEY,
+       TDES_VARIABLE_TEXT,
+       TDES_KAT,
+       TDES_MCT, /* Monte Carlo (Modes) Test */
+       TDES_MMT /* Multi block Message Test */
+};
+
 struct aesavs_interim_data {
        enum fips_aesavs_test_types test_type;
        uint32_t cipher_algo;
        uint32_t key_len;
 };
 
+struct hmac_interim_data {
+       enum rte_crypto_auth_algorithm algo;
+};
+
+struct tdes_interim_data {
+       enum fips_tdes_test_types test_type;
+       uint32_t nb_keys;
+};
+
 struct fips_test_interim_info {
        FILE *fp_rd;
        FILE *fp_wr;
@@ -105,6 +127,8 @@ struct fips_test_interim_info {
 
        union {
                struct aesavs_interim_data aes_data;
+               struct hmac_interim_data hmac_data;
+               struct tdes_interim_data tdes_data;
 
        } interim_info;
 
@@ -140,6 +164,12 @@ fips_test_write_one_case(void);
 int
 parse_test_aes_init(void);
 
+int
+parse_test_tdes_init(void);
+
+int
+parse_test_hmac_init(void);
+
 int
 parser_read_uint8_hex(uint8_t *value, const char *p);