1 /* SPDX-License-Identifier: BSD-3-Clause 2 * Copyright(c) 2016-2017 Intel Corporation 3 */ 4 5 #ifndef TEST_CRYPTODEV_BLOCKCIPHER_H_ 6 #define TEST_CRYPTODEV_BLOCKCIPHER_H_ 7 8 #ifndef BLOCKCIPHER_TEST_MSG_LEN 9 #define BLOCKCIPHER_TEST_MSG_LEN 256 10 #endif 11 12 #define BLOCKCIPHER_TEST_OP_ENCRYPT 0x01 13 #define BLOCKCIPHER_TEST_OP_DECRYPT 0x02 14 #define BLOCKCIPHER_TEST_OP_AUTH_GEN 0x04 15 #define BLOCKCIPHER_TEST_OP_AUTH_VERIFY 0x08 16 17 #define BLOCKCIPHER_TEST_FEATURE_OOP 0x01 18 #define BLOCKCIPHER_TEST_FEATURE_SESSIONLESS 0x02 19 #define BLOCKCIPHER_TEST_FEATURE_STOPPER 0x04 /* stop upon failing */ 20 #define BLOCKCIPHER_TEST_FEATURE_SG 0x08 /* Scatter Gather */ 21 22 #define BLOCKCIPHER_TEST_TARGET_PMD_MB 0x0001 /* Multi-buffer flag */ 23 #define BLOCKCIPHER_TEST_TARGET_PMD_QAT 0x0002 /* QAT flag */ 24 #define BLOCKCIPHER_TEST_TARGET_PMD_OPENSSL 0x0004 /* SW OPENSSL flag */ 25 #define BLOCKCIPHER_TEST_TARGET_PMD_ARMV8 0x0008 /* ARMv8 flag */ 26 #define BLOCKCIPHER_TEST_TARGET_PMD_SCHEDULER 0x0010 /* Scheduler */ 27 #define BLOCKCIPHER_TEST_TARGET_PMD_DPAA2_SEC 0x0020 /* DPAA2_SEC flag */ 28 #define BLOCKCIPHER_TEST_TARGET_PMD_DPAA_SEC 0x0040 /* DPAA_SEC flag */ 29 #define BLOCKCIPHER_TEST_TARGET_PMD_MVSAM 0x0080 /* Marvell flag */ 30 #define BLOCKCIPHER_TEST_TARGET_PMD_OCTEONTX 0x0100 /* OCTEON TX flag */ 31 #define BLOCKCIPHER_TEST_TARGET_PMD_VIRTIO 0x0200 /* VIRTIO flag */ 32 #define BLOCKCIPHER_TEST_TARGET_PMD_CAAM_JR 0x0400 /* CAAM_JR flag */ 33 #define BLOCKCIPHER_TEST_TARGET_PMD_CCP 0x0800 /* CCP flag */ 34 35 #define BLOCKCIPHER_TEST_OP_CIPHER (BLOCKCIPHER_TEST_OP_ENCRYPT | \ 36 BLOCKCIPHER_TEST_OP_DECRYPT) 37 38 #define BLOCKCIPHER_TEST_OP_AUTH (BLOCKCIPHER_TEST_OP_AUTH_GEN | \ 39 BLOCKCIPHER_TEST_OP_AUTH_VERIFY) 40 41 #define BLOCKCIPHER_TEST_OP_ENC_AUTH_GEN (BLOCKCIPHER_TEST_OP_ENCRYPT | \ 42 BLOCKCIPHER_TEST_OP_AUTH_GEN) 43 44 #define BLOCKCIPHER_TEST_OP_AUTH_VERIFY_DEC (BLOCKCIPHER_TEST_OP_DECRYPT | \ 45 BLOCKCIPHER_TEST_OP_AUTH_VERIFY) 46 47 enum blockcipher_test_type { 48 BLKCIPHER_AES_CHAIN_TYPE, /* use aes_chain_test_cases[] */ 49 BLKCIPHER_AES_CIPHERONLY_TYPE, /* use aes_cipheronly_test_cases[] */ 50 BLKCIPHER_AES_DOCSIS_TYPE, /* use aes_docsis_test_cases[] */ 51 BLKCIPHER_3DES_CHAIN_TYPE, /* use triple_des_chain_test_cases[] */ 52 BLKCIPHER_3DES_CIPHERONLY_TYPE, /* triple_des_cipheronly_test_cases[] */ 53 BLKCIPHER_AUTHONLY_TYPE, /* use hash_test_cases[] */ 54 BLKCIPHER_DES_CIPHERONLY_TYPE, /* use des_cipheronly_test_cases[] */ 55 BLKCIPHER_DES_DOCSIS_TYPE /* use des_docsis_test_cases[] */ 56 }; 57 58 struct blockcipher_test_case { 59 const char *test_descr; /* test description */ 60 const struct blockcipher_test_data *test_data; 61 uint8_t op_mask; /* operation mask */ 62 uint8_t feature_mask; 63 uint32_t pmd_mask; 64 }; 65 66 struct blockcipher_test_data { 67 enum rte_crypto_cipher_algorithm crypto_algo; 68 69 struct { 70 uint8_t data[64]; 71 unsigned int len; 72 } cipher_key; 73 74 struct { 75 uint8_t data[64] __rte_aligned(16); 76 unsigned int len; 77 } iv; 78 79 struct { 80 const uint8_t *data; 81 unsigned int len; 82 } plaintext; 83 84 struct { 85 const uint8_t *data; 86 unsigned int len; 87 } ciphertext; 88 89 enum rte_crypto_auth_algorithm auth_algo; 90 91 struct { 92 uint8_t data[128]; 93 unsigned int len; 94 } auth_key; 95 96 struct { 97 uint8_t data[128]; 98 unsigned int len; /* for qat */ 99 unsigned int truncated_len; /* for mb */ 100 } digest; 101 102 unsigned int cipher_offset; 103 unsigned int auth_offset; 104 }; 105 106 int 107 test_blockcipher_all_tests(struct rte_mempool *mbuf_pool, 108 struct rte_mempool *op_mpool, 109 struct rte_mempool *sess_mpool, 110 struct rte_mempool *sess_priv_mpool, 111 uint8_t dev_id, 112 int driver_id, 113 enum blockcipher_test_type test_type); 114 115 #endif /* TEST_CRYPTODEV_BLOCKCIPHER_H_ */ 116