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