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