1
2
3
4
5#ifndef _ARMV8_PMD_PRIVATE_H_
6#define _ARMV8_PMD_PRIVATE_H_
7
8#include "AArch64cryptolib.h"
9
10#define CRYPTODEV_NAME_ARMV8_PMD crypto_armv8
11
12
13extern int crypto_armv8_log_type;
14
15#define ARMV8_CRYPTO_LOG_ERR(fmt, args...) \
16 rte_log(RTE_LOG_ERR, crypto_armv8_log_type, \
17 "[%s] %s() line %u: " fmt "\n", \
18 RTE_STR(CRYPTODEV_NAME_ARMV8_PMD), \
19 __func__, __LINE__, ## args)
20
21#define ARMV8_CRYPTO_LOG_INFO(fmt, args...) \
22 rte_log(RTE_LOG_INFO, crypto_armv8_log_type, \
23 "[%s] %s() line %u: " fmt "\n", \
24 RTE_STR(CRYPTODEV_NAME_ARMV8_PMD), \
25 __func__, __LINE__, ## args)
26
27#define ARMV8_CRYPTO_LOG_DBG(fmt, args...) \
28 rte_log(RTE_LOG_DEBUG, crypto_armv8_log_type, \
29 "[%s] %s() line %u: " fmt "\n", \
30 RTE_STR(CRYPTODEV_NAME_ARMV8_PMD), \
31 __func__, __LINE__, ## args)
32
33#define NBBY 8
34#define BYTE_LENGTH(x) ((x) / NBBY)
35
36
37#define DIGEST_LENGTH_MAX 32
38
39
40enum armv8_crypto_chain_order {
41 ARMV8_CRYPTO_CHAIN_CIPHER_AUTH,
42 ARMV8_CRYPTO_CHAIN_AUTH_CIPHER,
43 ARMV8_CRYPTO_CHAIN_NOT_SUPPORTED,
44 ARMV8_CRYPTO_CHAIN_LIST_END = ARMV8_CRYPTO_CHAIN_NOT_SUPPORTED
45};
46
47
48enum armv8_crypto_cipher_operation {
49 ARMV8_CRYPTO_CIPHER_OP_ENCRYPT = RTE_CRYPTO_CIPHER_OP_ENCRYPT,
50 ARMV8_CRYPTO_CIPHER_OP_DECRYPT = RTE_CRYPTO_CIPHER_OP_DECRYPT,
51 ARMV8_CRYPTO_CIPHER_OP_NOT_SUPPORTED,
52 ARMV8_CRYPTO_CIPHER_OP_LIST_END = ARMV8_CRYPTO_CIPHER_OP_NOT_SUPPORTED
53};
54
55enum armv8_crypto_cipher_keylen {
56 ARMV8_CRYPTO_CIPHER_KEYLEN_128,
57 ARMV8_CRYPTO_CIPHER_KEYLEN_192,
58 ARMV8_CRYPTO_CIPHER_KEYLEN_256,
59 ARMV8_CRYPTO_CIPHER_KEYLEN_NOT_SUPPORTED,
60 ARMV8_CRYPTO_CIPHER_KEYLEN_LIST_END =
61 ARMV8_CRYPTO_CIPHER_KEYLEN_NOT_SUPPORTED
62};
63
64
65enum armv8_crypto_auth_mode {
66 ARMV8_CRYPTO_AUTH_AS_AUTH,
67 ARMV8_CRYPTO_AUTH_AS_HMAC,
68 ARMV8_CRYPTO_AUTH_AS_CIPHER,
69 ARMV8_CRYPTO_AUTH_NOT_SUPPORTED,
70 ARMV8_CRYPTO_AUTH_LIST_END = ARMV8_CRYPTO_AUTH_NOT_SUPPORTED
71};
72
73#define CRYPTO_CIPHER_KEYLEN_MAX ARMV8_CRYPTO_CIPHER_KEYLEN_LIST_END
74#define CRYPTO_CIPHER_MAX (RTE_CRYPTO_CIPHER_AES_ECB + 1)
75#define CRYPTO_AUTH_MAX (RTE_CRYPTO_AUTH_SHA512_HMAC + 1)
76
77#define HMAC_IPAD_VALUE (0x36)
78#define HMAC_OPAD_VALUE (0x5C)
79
80#define SHA256_AUTH_KEY_LENGTH (BYTE_LENGTH(256))
81#define SHA256_BLOCK_SIZE (BYTE_LENGTH(512))
82
83#define SHA1_AUTH_KEY_LENGTH (BYTE_LENGTH(160))
84#define SHA1_BLOCK_SIZE (BYTE_LENGTH(512))
85
86#define SHA_AUTH_KEY_MAX SHA256_AUTH_KEY_LENGTH
87#define SHA_BLOCK_MAX SHA256_BLOCK_SIZE
88
89typedef int (*crypto_func_t)(uint8_t *, uint8_t *, uint64_t,
90 uint8_t *, uint8_t *, uint64_t,
91 armv8_cipher_digest_t *);
92
93typedef void (*crypto_key_sched_t)(uint8_t *, const uint8_t *);
94
95
96struct armv8_crypto_private {
97 unsigned int max_nb_qpairs;
98
99};
100
101
102struct armv8_crypto_qp {
103 uint16_t id;
104
105 struct rte_ring *processed_ops;
106
107 struct rte_mempool *sess_mp;
108
109 struct rte_mempool *sess_mp_priv;
110
111 struct rte_cryptodev_stats stats;
112
113 char name[RTE_CRYPTODEV_NAME_MAX_LEN];
114
115 uint8_t temp_digest[DIGEST_LENGTH_MAX];
116
117
118
119
120} __rte_cache_aligned;
121
122
123struct armv8_crypto_session {
124 enum armv8_crypto_chain_order chain_order;
125
126 crypto_func_t crypto_func;
127
128
129
130 struct {
131 enum rte_crypto_cipher_operation direction;
132
133 enum rte_crypto_cipher_algorithm algo;
134
135 struct {
136 uint16_t length;
137 uint16_t offset;
138 } iv;
139
140
141 struct {
142 uint8_t data[256];
143
144 size_t length;
145
146 } key;
147
148 crypto_key_sched_t key_sched;
149
150 } cipher;
151
152
153 struct {
154 enum rte_crypto_auth_operation operation;
155
156 enum armv8_crypto_auth_mode mode;
157
158
159 union {
160 struct {
161
162 } auth;
163
164 struct {
165 uint8_t i_key_pad[SHA_BLOCK_MAX]
166 __rte_cache_aligned;
167
168 uint8_t o_key_pad[SHA_BLOCK_MAX]
169 __rte_cache_aligned;
170
171 uint8_t key[SHA_BLOCK_MAX];
172
173 } hmac;
174 };
175 uint16_t digest_length;
176
177 } auth;
178
179} __rte_cache_aligned;
180
181
182extern int armv8_crypto_set_session_parameters(
183 struct armv8_crypto_session *sess,
184 const struct rte_crypto_sym_xform *xform);
185
186
187extern struct rte_cryptodev_ops *rte_armv8_crypto_pmd_ops;
188
189#endif
190