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