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 #define BLOCKCIPHER_TEST_TARGET_PMD_NULL 0x1000 /* NULL flag */ 35 #define BLOCKCIPHER_TEST_TARGET_PMD_NITROX 0x2000 /* NITROX flag */ 36 #define BLOCKCIPHER_TEST_TARGET_PMD_OCTEONTX2 0x4000 /* OCTEON TX2 flag */ 37 38 #define BLOCKCIPHER_TEST_OP_CIPHER (BLOCKCIPHER_TEST_OP_ENCRYPT | \ 39 BLOCKCIPHER_TEST_OP_DECRYPT) 40 41 #define BLOCKCIPHER_TEST_OP_AUTH (BLOCKCIPHER_TEST_OP_AUTH_GEN | \ 42 BLOCKCIPHER_TEST_OP_AUTH_VERIFY) 43 44 #define BLOCKCIPHER_TEST_OP_ENC_AUTH_GEN (BLOCKCIPHER_TEST_OP_ENCRYPT | \ 45 BLOCKCIPHER_TEST_OP_AUTH_GEN) 46 47 #define BLOCKCIPHER_TEST_OP_AUTH_VERIFY_DEC (BLOCKCIPHER_TEST_OP_DECRYPT | \ 48 BLOCKCIPHER_TEST_OP_AUTH_VERIFY) 49 50 enum blockcipher_test_type { 51 BLKCIPHER_AES_CHAIN_TYPE, /* use aes_chain_test_cases[] */ 52 BLKCIPHER_AES_CIPHERONLY_TYPE, /* use aes_cipheronly_test_cases[] */ 53 BLKCIPHER_AES_DOCSIS_TYPE, /* use aes_docsis_test_cases[] */ 54 BLKCIPHER_3DES_CHAIN_TYPE, /* use triple_des_chain_test_cases[] */ 55 BLKCIPHER_3DES_CIPHERONLY_TYPE, /* triple_des_cipheronly_test_cases[] */ 56 BLKCIPHER_AUTHONLY_TYPE, /* use hash_test_cases[] */ 57 BLKCIPHER_DES_CIPHERONLY_TYPE, /* use des_cipheronly_test_cases[] */ 58 BLKCIPHER_DES_DOCSIS_TYPE /* use des_docsis_test_cases[] */ 59 }; 60 61 struct blockcipher_test_case { 62 const char *test_descr; /* test description */ 63 const struct blockcipher_test_data *test_data; 64 uint8_t op_mask; /* operation mask */ 65 uint8_t feature_mask; 66 uint32_t pmd_mask; 67 }; 68 69 struct blockcipher_test_data { 70 enum rte_crypto_cipher_algorithm crypto_algo; 71 72 struct { 73 uint8_t data[64]; 74 unsigned int len; 75 } cipher_key; 76 77 struct { 78 uint8_t data[64] __rte_aligned(16); 79 unsigned int len; 80 } iv; 81 82 struct { 83 const uint8_t *data; 84 unsigned int len; 85 } plaintext; 86 87 struct { 88 const uint8_t *data; 89 unsigned int len; 90 } ciphertext; 91 92 enum rte_crypto_auth_algorithm auth_algo; 93 94 struct { 95 uint8_t data[128]; 96 unsigned int len; 97 } auth_key; 98 99 struct { 100 uint8_t data[128]; 101 unsigned int len; /* for qat */ 102 unsigned int truncated_len; /* for mb */ 103 } digest; 104 105 unsigned int cipher_offset; 106 unsigned int auth_offset; 107 }; 108 109 int 110 test_blockcipher_all_tests(struct rte_mempool *mbuf_pool, 111 struct rte_mempool *op_mpool, 112 struct rte_mempool *sess_mpool, 113 struct rte_mempool *sess_priv_mpool, 114 uint8_t dev_id, 115 int driver_id, 116 enum blockcipher_test_type test_type); 117 118 #endif /* TEST_CRYPTODEV_BLOCKCIPHER_H_ */ 119