xref: /dpdk/app/test/test_cryptodev_blockcipher.h (revision 200bc52e5aa0d72e70464c9cd22b55cf536ed13c)
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 
35 #define BLOCKCIPHER_TEST_OP_CIPHER	(BLOCKCIPHER_TEST_OP_ENCRYPT | \
36 					BLOCKCIPHER_TEST_OP_DECRYPT)
37 
38 #define BLOCKCIPHER_TEST_OP_AUTH	(BLOCKCIPHER_TEST_OP_AUTH_GEN | \
39 					BLOCKCIPHER_TEST_OP_AUTH_VERIFY)
40 
41 #define BLOCKCIPHER_TEST_OP_ENC_AUTH_GEN	(BLOCKCIPHER_TEST_OP_ENCRYPT | \
42 					BLOCKCIPHER_TEST_OP_AUTH_GEN)
43 
44 #define BLOCKCIPHER_TEST_OP_AUTH_VERIFY_DEC	(BLOCKCIPHER_TEST_OP_DECRYPT | \
45 					BLOCKCIPHER_TEST_OP_AUTH_VERIFY)
46 
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[] */
56 };
57 
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 */
62 	uint8_t feature_mask;
63 	uint32_t pmd_mask;
64 };
65 
66 struct blockcipher_test_data {
67 	enum rte_crypto_cipher_algorithm crypto_algo;
68 
69 	struct {
70 		uint8_t data[64];
71 		unsigned int len;
72 	} cipher_key;
73 
74 	struct {
75 		uint8_t data[64] __rte_aligned(16);
76 		unsigned int len;
77 	} iv;
78 
79 	struct {
80 		const uint8_t *data;
81 		unsigned int len;
82 	} plaintext;
83 
84 	struct {
85 		const uint8_t *data;
86 		unsigned int len;
87 	} ciphertext;
88 
89 	enum rte_crypto_auth_algorithm auth_algo;
90 
91 	struct {
92 		uint8_t data[128];
93 		unsigned int len;
94 	} auth_key;
95 
96 	struct {
97 		uint8_t data[128];
98 		unsigned int len;		/* for qat */
99 		unsigned int truncated_len;	/* for mb */
100 	} digest;
101 
102 	unsigned int cipher_offset;
103 	unsigned int auth_offset;
104 };
105 
106 int
107 test_blockcipher_all_tests(struct rte_mempool *mbuf_pool,
108 	struct rte_mempool *op_mpool,
109 	struct rte_mempool *sess_mpool,
110 	struct rte_mempool *sess_priv_mpool,
111 	uint8_t dev_id,
112 	int driver_id,
113 	enum blockcipher_test_type test_type);
114 
115 #endif /* TEST_CRYPTODEV_BLOCKCIPHER_H_ */
116