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