1 /* SPDX-License-Identifier: BSD-3-Clause
2 * Copyright(c) 2016-2017 Intel Corporation
5 #ifndef TEST_CRYPTODEV_BLOCKCIPHER_H_
6 #define TEST_CRYPTODEV_BLOCKCIPHER_H_
8 #ifndef BLOCKCIPHER_TEST_MSG_LEN
9 #define BLOCKCIPHER_TEST_MSG_LEN 256
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
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 */
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_CCP 0x0040 /* CCP flag */
31 #define BLOCKCIPHER_TEST_TARGET_PMD_VIRTIO 0x0200 /* VIRTIO flag */
32 #define BLOCKCIPHER_TEST_TARGET_PMD_OCTEONTX 0x0100 /* OCTEON TX flag */
33 #define BLOCKCIPHER_TEST_TARGET_PMD_CAAM_JR 0x0400 /* CAAM_JR flag */
35 #define BLOCKCIPHER_TEST_OP_CIPHER (BLOCKCIPHER_TEST_OP_ENCRYPT | \
36 BLOCKCIPHER_TEST_OP_DECRYPT)
38 #define BLOCKCIPHER_TEST_OP_AUTH (BLOCKCIPHER_TEST_OP_AUTH_GEN | \
39 BLOCKCIPHER_TEST_OP_AUTH_VERIFY)
41 #define BLOCKCIPHER_TEST_OP_ENC_AUTH_GEN (BLOCKCIPHER_TEST_OP_ENCRYPT | \
42 BLOCKCIPHER_TEST_OP_AUTH_GEN)
44 #define BLOCKCIPHER_TEST_OP_AUTH_VERIFY_DEC (BLOCKCIPHER_TEST_OP_DECRYPT | \
45 BLOCKCIPHER_TEST_OP_AUTH_VERIFY)
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[] */
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 */
66 struct blockcipher_test_data {
67 enum rte_crypto_cipher_algorithm crypto_algo;
75 uint8_t data[64] __rte_aligned(16);
89 enum rte_crypto_auth_algorithm auth_algo;
98 unsigned int len; /* for qat */
99 unsigned int truncated_len; /* for mb */
104 test_blockcipher_all_tests(struct rte_mempool *mbuf_pool,
105 struct rte_mempool *op_mpool,
106 struct rte_mempool *sess_mpool,
109 enum blockcipher_test_type test_type);
111 #endif /* TEST_CRYPTODEV_BLOCKCIPHER_H_ */