1 /* SPDX-License-Identifier: BSD-3-Clause
2 * Copyright(c) 2018 Cavium Networks
3 * Copyright (c) 2019 Intel Corporation
4 */
5
6 #ifndef RTE_EXEC_ENV_WINDOWS
7
8 #include <rte_bus_vdev.h>
9 #include <rte_common.h>
10 #include <rte_hexdump.h>
11 #include <rte_mbuf.h>
12 #include <rte_malloc.h>
13 #include <rte_memcpy.h>
14 #include <rte_pause.h>
15
16 #include <rte_cryptodev.h>
17 #include <rte_crypto.h>
18
19 #include "test_cryptodev.h"
20 #include "test_cryptodev_dh_test_vectors.h"
21 #include "test_cryptodev_dsa_test_vectors.h"
22 #include "test_cryptodev_ecdsa_test_vectors.h"
23 #include "test_cryptodev_ecpm_test_vectors.h"
24 #include "test_cryptodev_mod_test_vectors.h"
25 #include "test_cryptodev_rsa_test_vectors.h"
26 #include "test_cryptodev_asym_util.h"
27 #include "test.h"
28
29 #define TEST_NUM_BUFS 10
30 #define TEST_NUM_SESSIONS 4
31
32 #ifndef TEST_DATA_SIZE
33 #define TEST_DATA_SIZE 4096
34 #endif
35 #define ASYM_TEST_MSG_LEN 256
36 #define TEST_VECTOR_SIZE 256
37
38 static int gbl_driver_id;
39 struct crypto_testsuite_params_asym {
40 struct rte_mempool *op_mpool;
41 struct rte_mempool *session_mpool;
42 struct rte_cryptodev_config conf;
43 struct rte_cryptodev_qp_conf qp_conf;
44 uint8_t valid_devs[RTE_CRYPTO_MAX_DEVS];
45 uint8_t valid_dev_count;
46 };
47
48 struct crypto_unittest_params {
49 void *sess;
50 struct rte_crypto_op *op;
51 };
52
53 union test_case_structure {
54 struct modex_test_data modex;
55 struct modinv_test_data modinv;
56 struct rsa_test_data_2 rsa_data;
57 };
58
59 struct test_cases_array {
60 uint32_t size;
61 const void *address[TEST_VECTOR_SIZE];
62 };
63 static struct test_cases_array test_vector = {0, { NULL } };
64
65 static uint32_t test_index;
66
67 static struct crypto_testsuite_params_asym testsuite_params = { NULL };
68
69 static int
queue_ops_rsa_sign_verify(void * sess)70 queue_ops_rsa_sign_verify(void *sess)
71 {
72 struct crypto_testsuite_params_asym *ts_params = &testsuite_params;
73 struct rte_mempool *op_mpool = ts_params->op_mpool;
74 uint8_t dev_id = ts_params->valid_devs[0];
75 struct rte_crypto_op *op, *result_op;
76 struct rte_crypto_asym_op *asym_op;
77 uint8_t output_buf[TEST_DATA_SIZE];
78 int status = TEST_SUCCESS;
79
80 /* Set up crypto op data structure */
81 op = rte_crypto_op_alloc(op_mpool, RTE_CRYPTO_OP_TYPE_ASYMMETRIC);
82 if (!op) {
83 RTE_LOG(ERR, USER1, "Failed to allocate asymmetric crypto "
84 "operation struct\n");
85 return TEST_FAILED;
86 }
87
88 asym_op = op->asym;
89
90 /* Compute sign on the test vector */
91 asym_op->rsa.op_type = RTE_CRYPTO_ASYM_OP_SIGN;
92
93 asym_op->rsa.message.data = rsaplaintext.data;
94 asym_op->rsa.message.length = rsaplaintext.len;
95 asym_op->rsa.sign.length = 0;
96 asym_op->rsa.sign.data = output_buf;
97 asym_op->rsa.pad = RTE_CRYPTO_RSA_PADDING_PKCS1_5;
98
99 debug_hexdump(stdout, "message", asym_op->rsa.message.data,
100 asym_op->rsa.message.length);
101
102 /* Attach asymmetric crypto session to crypto operations */
103 rte_crypto_op_attach_asym_session(op, sess);
104
105 RTE_LOG(DEBUG, USER1, "Process ASYM operation\n");
106
107 /* Process crypto operation */
108 if (rte_cryptodev_enqueue_burst(dev_id, 0, &op, 1) != 1) {
109 RTE_LOG(ERR, USER1, "Error sending packet for sign\n");
110 status = TEST_FAILED;
111 goto error_exit;
112 }
113
114 while (rte_cryptodev_dequeue_burst(dev_id, 0, &result_op, 1) == 0)
115 rte_pause();
116
117 if (result_op == NULL) {
118 RTE_LOG(ERR, USER1, "Failed to process sign op\n");
119 status = TEST_FAILED;
120 goto error_exit;
121 }
122
123 debug_hexdump(stdout, "signed message", asym_op->rsa.sign.data,
124 asym_op->rsa.sign.length);
125 asym_op = result_op->asym;
126
127 /* Verify sign */
128 asym_op->rsa.op_type = RTE_CRYPTO_ASYM_OP_VERIFY;
129 asym_op->rsa.pad = RTE_CRYPTO_RSA_PADDING_PKCS1_5;
130
131 /* Process crypto operation */
132 if (rte_cryptodev_enqueue_burst(dev_id, 0, &op, 1) != 1) {
133 RTE_LOG(ERR, USER1, "Error sending packet for verify\n");
134 status = TEST_FAILED;
135 goto error_exit;
136 }
137
138 while (rte_cryptodev_dequeue_burst(dev_id, 0, &result_op, 1) == 0)
139 rte_pause();
140
141 if (result_op == NULL) {
142 RTE_LOG(ERR, USER1, "Failed to process verify op\n");
143 status = TEST_FAILED;
144 goto error_exit;
145 }
146
147 status = TEST_SUCCESS;
148 if (result_op->status != RTE_CRYPTO_OP_STATUS_SUCCESS) {
149 RTE_LOG(ERR, USER1, "Failed to process sign-verify op\n");
150 status = TEST_FAILED;
151 }
152
153 error_exit:
154
155 rte_crypto_op_free(op);
156
157 return status;
158 }
159
160 static int
queue_ops_rsa_enc_dec(void * sess)161 queue_ops_rsa_enc_dec(void *sess)
162 {
163 struct crypto_testsuite_params_asym *ts_params = &testsuite_params;
164 struct rte_mempool *op_mpool = ts_params->op_mpool;
165 uint8_t dev_id = ts_params->valid_devs[0];
166 struct rte_crypto_op *op, *result_op;
167 struct rte_crypto_asym_op *asym_op;
168 uint8_t cipher_buf[TEST_DATA_SIZE] = {0};
169 int ret, status = TEST_SUCCESS;
170
171 /* Set up crypto op data structure */
172 op = rte_crypto_op_alloc(op_mpool, RTE_CRYPTO_OP_TYPE_ASYMMETRIC);
173 if (!op) {
174 RTE_LOG(ERR, USER1, "Failed to allocate asymmetric crypto "
175 "operation struct\n");
176 return TEST_FAILED;
177 }
178
179 asym_op = op->asym;
180
181 /* Compute encryption on the test vector */
182 asym_op->rsa.op_type = RTE_CRYPTO_ASYM_OP_ENCRYPT;
183
184 asym_op->rsa.message.data = rsaplaintext.data;
185 asym_op->rsa.cipher.data = cipher_buf;
186 asym_op->rsa.cipher.length = 0;
187 asym_op->rsa.message.length = rsaplaintext.len;
188 asym_op->rsa.pad = RTE_CRYPTO_RSA_PADDING_PKCS1_5;
189
190 debug_hexdump(stdout, "message", asym_op->rsa.message.data,
191 asym_op->rsa.message.length);
192
193 /* Attach asymmetric crypto session to crypto operations */
194 rte_crypto_op_attach_asym_session(op, sess);
195
196 RTE_LOG(DEBUG, USER1, "Process ASYM operation\n");
197
198 /* Process crypto operation */
199 if (rte_cryptodev_enqueue_burst(dev_id, 0, &op, 1) != 1) {
200 RTE_LOG(ERR, USER1, "Error sending packet for encryption\n");
201 status = TEST_FAILED;
202 goto error_exit;
203 }
204
205 while (rte_cryptodev_dequeue_burst(dev_id, 0, &result_op, 1) == 0)
206 rte_pause();
207
208 if (result_op == NULL) {
209 RTE_LOG(ERR, USER1, "Failed to process encryption op\n");
210 status = TEST_FAILED;
211 goto error_exit;
212 }
213 debug_hexdump(stdout, "encrypted message", asym_op->rsa.message.data,
214 asym_op->rsa.message.length);
215
216 /* Use the resulted output as decryption Input vector*/
217 asym_op = result_op->asym;
218 asym_op->rsa.message.length = 0;
219 asym_op->rsa.op_type = RTE_CRYPTO_ASYM_OP_DECRYPT;
220 asym_op->rsa.pad = RTE_CRYPTO_RSA_PADDING_PKCS1_5;
221
222 /* Process crypto operation */
223 if (rte_cryptodev_enqueue_burst(dev_id, 0, &op, 1) != 1) {
224 RTE_LOG(ERR, USER1, "Error sending packet for decryption\n");
225 status = TEST_FAILED;
226 goto error_exit;
227 }
228
229 while (rte_cryptodev_dequeue_burst(dev_id, 0, &result_op, 1) == 0)
230 rte_pause();
231
232 if (result_op == NULL) {
233 RTE_LOG(ERR, USER1, "Failed to process decryption op\n");
234 status = TEST_FAILED;
235 goto error_exit;
236 }
237 status = TEST_SUCCESS;
238 ret = rsa_verify(&rsaplaintext, result_op);
239 if (ret)
240 status = TEST_FAILED;
241
242 error_exit:
243
244 rte_crypto_op_free(op);
245
246 return status;
247 }
248 static int
test_cryptodev_asym_ver(struct rte_crypto_op * op,struct rte_crypto_asym_xform * xform_tc,union test_case_structure * data_tc,struct rte_crypto_op * result_op)249 test_cryptodev_asym_ver(struct rte_crypto_op *op,
250 struct rte_crypto_asym_xform *xform_tc,
251 union test_case_structure *data_tc,
252 struct rte_crypto_op *result_op)
253 {
254 int status = TEST_FAILED;
255 int ret = 0;
256 uint8_t *data_expected = NULL, *data_received = NULL;
257 size_t data_size = 0;
258
259 switch (data_tc->modex.xform_type) {
260 case RTE_CRYPTO_ASYM_XFORM_MODEX:
261 data_expected = data_tc->modex.reminder.data;
262 data_received = result_op->asym->modex.result.data;
263 data_size = result_op->asym->modex.result.length;
264 break;
265 case RTE_CRYPTO_ASYM_XFORM_MODINV:
266 data_expected = data_tc->modinv.inverse.data;
267 data_received = result_op->asym->modinv.result.data;
268 data_size = result_op->asym->modinv.result.length;
269 break;
270 case RTE_CRYPTO_ASYM_XFORM_RSA:
271 if (op->asym->rsa.op_type == RTE_CRYPTO_ASYM_OP_ENCRYPT) {
272 data_size = xform_tc->rsa.n.length;
273 data_received = result_op->asym->rsa.cipher.data;
274 data_expected = data_tc->rsa_data.ct.data;
275 } else if (op->asym->rsa.op_type == RTE_CRYPTO_ASYM_OP_DECRYPT) {
276 data_size = xform_tc->rsa.n.length;
277 data_expected = data_tc->rsa_data.pt.data;
278 data_received = result_op->asym->rsa.message.data;
279 } else if (op->asym->rsa.op_type == RTE_CRYPTO_ASYM_OP_SIGN) {
280 data_size = xform_tc->rsa.n.length;
281 data_expected = data_tc->rsa_data.sign.data;
282 data_received = result_op->asym->rsa.sign.data;
283 } else if (op->asym->rsa.op_type == RTE_CRYPTO_ASYM_OP_VERIFY) {
284 data_size = xform_tc->rsa.n.length;
285 data_expected = data_tc->rsa_data.pt.data;
286 data_received = result_op->asym->rsa.cipher.data;
287 }
288 break;
289 case RTE_CRYPTO_ASYM_XFORM_DH:
290 case RTE_CRYPTO_ASYM_XFORM_DSA:
291 case RTE_CRYPTO_ASYM_XFORM_NONE:
292 case RTE_CRYPTO_ASYM_XFORM_UNSPECIFIED:
293 default:
294 break;
295 }
296 ret = memcmp(data_expected, data_received, data_size);
297 if (!ret && data_size)
298 status = TEST_SUCCESS;
299
300 return status;
301 }
302
303 static int
test_cryptodev_asym_op(struct crypto_testsuite_params_asym * ts_params,union test_case_structure * data_tc,char * test_msg,int sessionless,enum rte_crypto_asym_op_type type,enum rte_crypto_rsa_priv_key_type key_type)304 test_cryptodev_asym_op(struct crypto_testsuite_params_asym *ts_params,
305 union test_case_structure *data_tc,
306 char *test_msg, int sessionless, enum rte_crypto_asym_op_type type,
307 enum rte_crypto_rsa_priv_key_type key_type)
308 {
309 struct rte_crypto_asym_op *asym_op = NULL;
310 struct rte_crypto_op *op = NULL;
311 struct rte_crypto_op *result_op = NULL;
312 struct rte_crypto_asym_xform xform_tc;
313 void *sess = NULL;
314 struct rte_cryptodev_asym_capability_idx cap_idx;
315 const struct rte_cryptodev_asymmetric_xform_capability *capability;
316 uint8_t dev_id = ts_params->valid_devs[0];
317 uint8_t input[TEST_DATA_SIZE] = {0};
318 uint8_t *result = NULL;
319
320 int ret, status = TEST_SUCCESS;
321
322 xform_tc.next = NULL;
323 xform_tc.xform_type = data_tc->modex.xform_type;
324
325 cap_idx.type = xform_tc.xform_type;
326 capability = rte_cryptodev_asym_capability_get(dev_id, &cap_idx);
327
328 if (capability == NULL) {
329 RTE_LOG(INFO, USER1,
330 "Device doesn't support MODEX. Test Skipped\n");
331 return TEST_SKIPPED;
332 }
333
334 /* Generate crypto op data structure */
335 op = rte_crypto_op_alloc(ts_params->op_mpool,
336 RTE_CRYPTO_OP_TYPE_ASYMMETRIC);
337
338 if (!op) {
339 snprintf(test_msg, ASYM_TEST_MSG_LEN,
340 "line %u FAILED: %s",
341 __LINE__, "Failed to allocate asymmetric crypto "
342 "operation struct");
343 status = TEST_FAILED;
344 goto error_exit;
345 }
346
347 asym_op = op->asym;
348
349 switch (xform_tc.xform_type) {
350 case RTE_CRYPTO_ASYM_XFORM_MODEX:
351 result = rte_zmalloc(NULL, data_tc->modex.result_len, 0);
352 xform_tc.modex.modulus.data = data_tc->modex.modulus.data;
353 xform_tc.modex.modulus.length = data_tc->modex.modulus.len;
354 xform_tc.modex.exponent.data = data_tc->modex.exponent.data;
355 xform_tc.modex.exponent.length = data_tc->modex.exponent.len;
356 memcpy(input, data_tc->modex.base.data,
357 data_tc->modex.base.len);
358 asym_op->modex.base.data = input;
359 asym_op->modex.base.length = data_tc->modex.base.len;
360 asym_op->modex.result.data = result;
361 asym_op->modex.result.length = data_tc->modex.result_len;
362 if (rte_cryptodev_asym_xform_capability_check_modlen(capability,
363 xform_tc.modex.modulus.length)) {
364 snprintf(test_msg, ASYM_TEST_MSG_LEN,
365 "line %u "
366 "FAILED: %s", __LINE__,
367 "Invalid MODULUS length specified");
368 status = TEST_FAILED;
369 goto error_exit;
370 }
371 break;
372 case RTE_CRYPTO_ASYM_XFORM_MODINV:
373 result = rte_zmalloc(NULL, data_tc->modinv.result_len, 0);
374 xform_tc.modinv.modulus.data = data_tc->modinv.modulus.data;
375 xform_tc.modinv.modulus.length = data_tc->modinv.modulus.len;
376 memcpy(input, data_tc->modinv.base.data,
377 data_tc->modinv.base.len);
378 asym_op->modinv.base.data = input;
379 asym_op->modinv.base.length = data_tc->modinv.base.len;
380 asym_op->modinv.result.data = result;
381 asym_op->modinv.result.length = data_tc->modinv.result_len;
382 if (rte_cryptodev_asym_xform_capability_check_modlen(capability,
383 xform_tc.modinv.modulus.length)) {
384 snprintf(test_msg, ASYM_TEST_MSG_LEN,
385 "line %u "
386 "FAILED: %s", __LINE__,
387 "Invalid MODULUS length specified");
388 status = TEST_FAILED;
389 goto error_exit;
390 }
391 break;
392 case RTE_CRYPTO_ASYM_XFORM_RSA:
393 result = rte_zmalloc(NULL, data_tc->rsa_data.n.len, 0);
394 op->asym->rsa.op_type = type;
395 xform_tc.rsa.e.data = data_tc->rsa_data.e.data;
396 xform_tc.rsa.e.length = data_tc->rsa_data.e.len;
397 xform_tc.rsa.n.data = data_tc->rsa_data.n.data;
398 xform_tc.rsa.n.length = data_tc->rsa_data.n.len;
399
400 if (key_type == RTE_RSA_KEY_TYPE_EXP) {
401 xform_tc.rsa.d.data = data_tc->rsa_data.d.data;
402 xform_tc.rsa.d.length = data_tc->rsa_data.d.len;
403 } else {
404 xform_tc.rsa.qt.p.data = data_tc->rsa_data.p.data;
405 xform_tc.rsa.qt.p.length = data_tc->rsa_data.p.len;
406 xform_tc.rsa.qt.q.data = data_tc->rsa_data.q.data;
407 xform_tc.rsa.qt.q.length = data_tc->rsa_data.q.len;
408 xform_tc.rsa.qt.dP.data = data_tc->rsa_data.dP.data;
409 xform_tc.rsa.qt.dP.length = data_tc->rsa_data.dP.len;
410 xform_tc.rsa.qt.dQ.data = data_tc->rsa_data.dQ.data;
411 xform_tc.rsa.qt.dQ.length = data_tc->rsa_data.dQ.len;
412 xform_tc.rsa.qt.qInv.data = data_tc->rsa_data.qInv.data;
413 xform_tc.rsa.qt.qInv.length = data_tc->rsa_data.qInv.len;
414 }
415
416 xform_tc.rsa.key_type = key_type;
417 op->asym->rsa.pad = data_tc->rsa_data.padding;
418
419 if (op->asym->rsa.op_type == RTE_CRYPTO_ASYM_OP_ENCRYPT) {
420 asym_op->rsa.message.data = data_tc->rsa_data.pt.data;
421 asym_op->rsa.message.length = data_tc->rsa_data.pt.len;
422 asym_op->rsa.cipher.data = result;
423 asym_op->rsa.cipher.length = data_tc->rsa_data.n.len;
424 } else if (op->asym->rsa.op_type == RTE_CRYPTO_ASYM_OP_DECRYPT) {
425 asym_op->rsa.message.data = result;
426 asym_op->rsa.message.length = data_tc->rsa_data.n.len;
427 asym_op->rsa.cipher.data = data_tc->rsa_data.ct.data;
428 asym_op->rsa.cipher.length = data_tc->rsa_data.ct.len;
429 } else if (op->asym->rsa.op_type == RTE_CRYPTO_ASYM_OP_SIGN) {
430 asym_op->rsa.sign.data = result;
431 asym_op->rsa.sign.length = data_tc->rsa_data.n.len;
432 asym_op->rsa.message.data = data_tc->rsa_data.pt.data;
433 asym_op->rsa.message.length = data_tc->rsa_data.pt.len;
434 } else if (op->asym->rsa.op_type == RTE_CRYPTO_ASYM_OP_VERIFY) {
435 asym_op->rsa.cipher.data = result;
436 asym_op->rsa.cipher.length = data_tc->rsa_data.n.len;
437 asym_op->rsa.sign.data = data_tc->rsa_data.sign.data;
438 asym_op->rsa.sign.length = data_tc->rsa_data.sign.len;
439 }
440 break;
441 case RTE_CRYPTO_ASYM_XFORM_DH:
442 case RTE_CRYPTO_ASYM_XFORM_DSA:
443 case RTE_CRYPTO_ASYM_XFORM_NONE:
444 case RTE_CRYPTO_ASYM_XFORM_UNSPECIFIED:
445 default:
446 snprintf(test_msg, ASYM_TEST_MSG_LEN,
447 "line %u "
448 "FAILED: %s", __LINE__,
449 "Invalid ASYM algorithm specified");
450 status = TEST_FAILED;
451 goto error_exit;
452 }
453
454 if (!sessionless) {
455 ret = rte_cryptodev_asym_session_create(dev_id, &xform_tc,
456 ts_params->session_mpool, &sess);
457 if (ret < 0) {
458 snprintf(test_msg, ASYM_TEST_MSG_LEN,
459 "line %u "
460 "FAILED: %s", __LINE__,
461 "Session creation failed");
462 status = (ret == -ENOTSUP) ? TEST_SKIPPED : TEST_FAILED;
463 goto error_exit;
464 }
465
466 rte_crypto_op_attach_asym_session(op, sess);
467 } else {
468 asym_op->xform = &xform_tc;
469 op->sess_type = RTE_CRYPTO_OP_SESSIONLESS;
470 }
471 RTE_LOG(DEBUG, USER1, "Process ASYM operation");
472
473 /* Process crypto operation */
474 if (rte_cryptodev_enqueue_burst(dev_id, 0, &op, 1) != 1) {
475 snprintf(test_msg, ASYM_TEST_MSG_LEN,
476 "line %u FAILED: %s",
477 __LINE__, "Error sending packet for operation");
478 status = TEST_FAILED;
479 goto error_exit;
480 }
481
482 while (rte_cryptodev_dequeue_burst(dev_id, 0, &result_op, 1) == 0)
483 rte_pause();
484
485 if (result_op == NULL) {
486 snprintf(test_msg, ASYM_TEST_MSG_LEN,
487 "line %u FAILED: %s",
488 __LINE__, "Failed to process asym crypto op");
489 status = TEST_FAILED;
490 goto error_exit;
491 }
492
493 if (test_cryptodev_asym_ver(op, &xform_tc, data_tc, result_op) != TEST_SUCCESS) {
494 snprintf(test_msg, ASYM_TEST_MSG_LEN,
495 "line %u FAILED: %s",
496 __LINE__, "Verification failed ");
497 status = TEST_FAILED;
498 goto error_exit;
499 }
500
501 if (!sessionless)
502 snprintf(test_msg, ASYM_TEST_MSG_LEN, "PASS");
503 else
504 snprintf(test_msg, ASYM_TEST_MSG_LEN, "SESSIONLESS PASS");
505
506 error_exit:
507 if (sess != NULL)
508 rte_cryptodev_asym_session_free(dev_id, sess);
509
510 if (op != NULL)
511 rte_crypto_op_free(op);
512
513 rte_free(result);
514
515 return status;
516 }
517
518 static int
test_one_case(const void * test_case,int sessionless)519 test_one_case(const void *test_case, int sessionless)
520 {
521 int status = TEST_SUCCESS, i = 0;
522 char test_msg[ASYM_TEST_MSG_LEN + 1];
523
524 /* Map the case to union */
525 union test_case_structure tc;
526 memcpy(&tc, test_case, sizeof(tc));
527
528 if (tc.modex.xform_type == RTE_CRYPTO_ASYM_XFORM_MODEX
529 || tc.modex.xform_type == RTE_CRYPTO_ASYM_XFORM_MODINV) {
530 status = test_cryptodev_asym_op(&testsuite_params, &tc, test_msg,
531 sessionless, 0, 0);
532 printf(" %u) TestCase %s %s\n", test_index++,
533 tc.modex.description, test_msg);
534 } else {
535 for (i = 0; i < RTE_CRYPTO_ASYM_OP_LIST_END; i++) {
536 if (tc.modex.xform_type == RTE_CRYPTO_ASYM_XFORM_RSA) {
537 if (tc.rsa_data.op_type_flags & (1 << i)) {
538 if (tc.rsa_data.key_exp) {
539 status = test_cryptodev_asym_op(
540 &testsuite_params, &tc,
541 test_msg, sessionless, i,
542 RTE_RSA_KEY_TYPE_EXP);
543 }
544 if (status)
545 break;
546 if (tc.rsa_data.key_qt && (i ==
547 RTE_CRYPTO_ASYM_OP_DECRYPT ||
548 i == RTE_CRYPTO_ASYM_OP_SIGN)) {
549 status = test_cryptodev_asym_op(
550 &testsuite_params,
551 &tc, test_msg, sessionless, i,
552 RTE_RSA_KEY_TYPE_QT);
553 }
554 if (status)
555 break;
556 }
557 }
558 }
559 printf(" %u) TestCase %s %s\n", test_index++,
560 tc.modex.description, test_msg);
561 }
562
563 return status;
564 }
565
566 static int
load_test_vectors(void)567 load_test_vectors(void)
568 {
569 uint32_t i = 0, v_size = 0;
570 /* Load MODEX vector*/
571 v_size = RTE_DIM(modex_test_case);
572 for (i = 0; i < v_size; i++) {
573 if (test_vector.size >= (TEST_VECTOR_SIZE)) {
574 RTE_LOG(DEBUG, USER1,
575 "TEST_VECTOR_SIZE too small\n");
576 return -1;
577 }
578 test_vector.address[test_vector.size] = &modex_test_case[i];
579 test_vector.size++;
580 }
581 /* Load MODINV vector*/
582 v_size = RTE_DIM(modinv_test_case);
583 for (i = 0; i < v_size; i++) {
584 if (test_vector.size >= (TEST_VECTOR_SIZE)) {
585 RTE_LOG(DEBUG, USER1,
586 "TEST_VECTOR_SIZE too small\n");
587 return -1;
588 }
589 test_vector.address[test_vector.size] = &modinv_test_case[i];
590 test_vector.size++;
591 }
592 /* Load RSA vector*/
593 v_size = RTE_DIM(rsa_test_case_list);
594 for (i = 0; i < v_size; i++) {
595 if (test_vector.size >= (TEST_VECTOR_SIZE)) {
596 RTE_LOG(DEBUG, USER1,
597 "TEST_VECTOR_SIZE too small\n");
598 return -1;
599 }
600 test_vector.address[test_vector.size] = &rsa_test_case_list[i];
601 test_vector.size++;
602 }
603 return 0;
604 }
605
606 static int
test_one_by_one(void)607 test_one_by_one(void)
608 {
609 int status = TEST_SUCCESS;
610 struct crypto_testsuite_params_asym *ts_params = &testsuite_params;
611 uint32_t i = 0;
612 uint8_t dev_id = ts_params->valid_devs[0];
613 struct rte_cryptodev_info dev_info;
614 int sessionless = 0;
615
616 rte_cryptodev_info_get(dev_id, &dev_info);
617 if ((dev_info.feature_flags &
618 RTE_CRYPTODEV_FF_ASYM_SESSIONLESS)) {
619 sessionless = 1;
620 }
621
622 /* Go through all test cases */
623 test_index = 0;
624 for (i = 0; i < test_vector.size; i++) {
625 if (test_one_case(test_vector.address[i], 0) != TEST_SUCCESS)
626 status = TEST_FAILED;
627 }
628 if (sessionless) {
629 for (i = 0; i < test_vector.size; i++) {
630 if (test_one_case(test_vector.address[i], 1)
631 != TEST_SUCCESS)
632 status = TEST_FAILED;
633 }
634 }
635
636 TEST_ASSERT_EQUAL(status, 0, "Test failed");
637 return status;
638 }
639
640 static int
test_rsa_sign_verify(void)641 test_rsa_sign_verify(void)
642 {
643 struct crypto_testsuite_params_asym *ts_params = &testsuite_params;
644 struct rte_mempool *sess_mpool = ts_params->session_mpool;
645 uint8_t dev_id = ts_params->valid_devs[0];
646 void *sess = NULL;
647 struct rte_cryptodev_info dev_info;
648 int ret, status = TEST_SUCCESS;
649
650 /* Test case supports op with exponent key only,
651 * Check in PMD feature flag for RSA exponent key type support.
652 */
653 rte_cryptodev_info_get(dev_id, &dev_info);
654 if (!(dev_info.feature_flags &
655 RTE_CRYPTODEV_FF_RSA_PRIV_OP_KEY_EXP)) {
656 RTE_LOG(INFO, USER1, "Device doesn't support sign op with "
657 "exponent key type. Test Skipped\n");
658 return TEST_SKIPPED;
659 }
660
661 ret = rte_cryptodev_asym_session_create(dev_id, &rsa_xform, sess_mpool, &sess);
662
663 if (ret < 0) {
664 RTE_LOG(ERR, USER1, "Session creation failed for "
665 "sign_verify\n");
666 status = (ret == -ENOTSUP) ? TEST_SKIPPED : TEST_FAILED;
667 goto error_exit;
668 }
669
670 status = queue_ops_rsa_sign_verify(sess);
671
672 error_exit:
673 rte_cryptodev_asym_session_free(dev_id, sess);
674
675 TEST_ASSERT_EQUAL(status, 0, "Test failed");
676
677 return status;
678 }
679
680 static int
test_rsa_enc_dec(void)681 test_rsa_enc_dec(void)
682 {
683 struct crypto_testsuite_params_asym *ts_params = &testsuite_params;
684 struct rte_mempool *sess_mpool = ts_params->session_mpool;
685 uint8_t dev_id = ts_params->valid_devs[0];
686 void *sess = NULL;
687 struct rte_cryptodev_info dev_info;
688 int ret, status = TEST_SUCCESS;
689
690 /* Test case supports op with exponent key only,
691 * Check in PMD feature flag for RSA exponent key type support.
692 */
693 rte_cryptodev_info_get(dev_id, &dev_info);
694 if (!(dev_info.feature_flags &
695 RTE_CRYPTODEV_FF_RSA_PRIV_OP_KEY_EXP)) {
696 RTE_LOG(INFO, USER1, "Device doesn't support decrypt op with "
697 "exponent key type. Test skipped\n");
698 return TEST_SKIPPED;
699 }
700
701 ret = rte_cryptodev_asym_session_create(dev_id, &rsa_xform, sess_mpool, &sess);
702
703 if (ret < 0) {
704 RTE_LOG(ERR, USER1, "Session creation failed for enc_dec\n");
705 status = (ret == -ENOTSUP) ? TEST_SKIPPED : TEST_FAILED;
706 goto error_exit;
707 }
708
709 status = queue_ops_rsa_enc_dec(sess);
710
711 error_exit:
712
713 rte_cryptodev_asym_session_free(dev_id, sess);
714
715 TEST_ASSERT_EQUAL(status, 0, "Test failed");
716
717 return status;
718 }
719
720 static int
test_rsa_sign_verify_crt(void)721 test_rsa_sign_verify_crt(void)
722 {
723 struct crypto_testsuite_params_asym *ts_params = &testsuite_params;
724 struct rte_mempool *sess_mpool = ts_params->session_mpool;
725 uint8_t dev_id = ts_params->valid_devs[0];
726 void *sess = NULL;
727 struct rte_cryptodev_info dev_info;
728 int ret, status = TEST_SUCCESS;
729
730 /* Test case supports op with quintuple format key only,
731 * Check im PMD feature flag for RSA quintuple key type support.
732 */
733 rte_cryptodev_info_get(dev_id, &dev_info);
734 if (!(dev_info.feature_flags & RTE_CRYPTODEV_FF_RSA_PRIV_OP_KEY_QT)) {
735 RTE_LOG(INFO, USER1, "Device doesn't support sign op with "
736 "quintuple key type. Test skipped\n");
737 return TEST_SKIPPED;
738 }
739
740 ret = rte_cryptodev_asym_session_create(dev_id, &rsa_xform_crt, sess_mpool, &sess);
741
742 if (ret < 0) {
743 RTE_LOG(ERR, USER1, "Session creation failed for "
744 "sign_verify_crt\n");
745 status = (ret == -ENOTSUP) ? TEST_SKIPPED : TEST_FAILED;
746 goto error_exit;
747 }
748
749 status = queue_ops_rsa_sign_verify(sess);
750
751 error_exit:
752
753 rte_cryptodev_asym_session_free(dev_id, sess);
754
755 TEST_ASSERT_EQUAL(status, 0, "Test failed");
756
757 return status;
758 }
759
760 static int
test_rsa_enc_dec_crt(void)761 test_rsa_enc_dec_crt(void)
762 {
763 struct crypto_testsuite_params_asym *ts_params = &testsuite_params;
764 struct rte_mempool *sess_mpool = ts_params->session_mpool;
765 uint8_t dev_id = ts_params->valid_devs[0];
766 void *sess = NULL;
767 struct rte_cryptodev_info dev_info;
768 int ret, status = TEST_SUCCESS;
769
770 /* Test case supports op with quintuple format key only,
771 * Check in PMD feature flag for RSA quintuple key type support.
772 */
773 rte_cryptodev_info_get(dev_id, &dev_info);
774 if (!(dev_info.feature_flags & RTE_CRYPTODEV_FF_RSA_PRIV_OP_KEY_QT)) {
775 RTE_LOG(INFO, USER1, "Device doesn't support decrypt op with "
776 "quintuple key type. Test skipped\n");
777 return TEST_SKIPPED;
778 }
779
780 ret = rte_cryptodev_asym_session_create(dev_id, &rsa_xform_crt, sess_mpool, &sess);
781
782 if (ret < 0) {
783 RTE_LOG(ERR, USER1, "Session creation failed for "
784 "enc_dec_crt\n");
785 status = (ret == -ENOTSUP) ? TEST_SKIPPED : TEST_FAILED;
786 goto error_exit;
787 }
788
789 status = queue_ops_rsa_enc_dec(sess);
790
791 error_exit:
792
793 rte_cryptodev_asym_session_free(dev_id, sess);
794
795 TEST_ASSERT_EQUAL(status, 0, "Test failed");
796
797 return status;
798 }
799
800 static int
testsuite_setup(void)801 testsuite_setup(void)
802 {
803 struct crypto_testsuite_params_asym *ts_params = &testsuite_params;
804 uint8_t valid_devs[RTE_CRYPTO_MAX_DEVS];
805 struct rte_cryptodev_info info;
806 int ret, dev_id = -1;
807 uint32_t i, nb_devs;
808 uint16_t qp_id;
809
810 memset(ts_params, 0, sizeof(*ts_params));
811
812 test_vector.size = 0;
813 load_test_vectors();
814
815 /* Device, op pool and session configuration for asymmetric crypto. 8< */
816 ts_params->op_mpool = rte_crypto_op_pool_create(
817 "CRYPTO_ASYM_OP_POOL",
818 RTE_CRYPTO_OP_TYPE_ASYMMETRIC,
819 TEST_NUM_BUFS, 0,
820 0,
821 rte_socket_id());
822 if (ts_params->op_mpool == NULL) {
823 RTE_LOG(ERR, USER1, "Can't create ASYM_CRYPTO_OP_POOL\n");
824 return TEST_FAILED;
825 }
826
827 /* Create an OPENSSL device if required */
828 if (gbl_driver_id == rte_cryptodev_driver_id_get(
829 RTE_STR(CRYPTODEV_NAME_OPENSSL_PMD))) {
830 nb_devs = rte_cryptodev_device_count_by_driver(
831 rte_cryptodev_driver_id_get(
832 RTE_STR(CRYPTODEV_NAME_OPENSSL_PMD)));
833 if (nb_devs < 1) {
834 ret = rte_vdev_init(
835 RTE_STR(CRYPTODEV_NAME_OPENSSL_PMD),
836 NULL);
837
838 TEST_ASSERT(ret == 0, "Failed to create "
839 "instance of pmd : %s",
840 RTE_STR(CRYPTODEV_NAME_OPENSSL_PMD));
841 }
842 }
843
844 /* Get list of valid crypto devs */
845 nb_devs = rte_cryptodev_devices_get(
846 rte_cryptodev_driver_name_get(gbl_driver_id),
847 valid_devs, RTE_CRYPTO_MAX_DEVS);
848 if (nb_devs < 1) {
849 RTE_LOG(ERR, USER1, "No crypto devices found?\n");
850 return TEST_FAILED;
851 }
852
853 /*
854 * Get first valid asymmetric device found in test suite param and
855 * break
856 */
857 for (i = 0; i < nb_devs ; i++) {
858 rte_cryptodev_info_get(valid_devs[i], &info);
859 if (info.feature_flags & RTE_CRYPTODEV_FF_ASYMMETRIC_CRYPTO) {
860 dev_id = ts_params->valid_devs[0] = valid_devs[i];
861 break;
862 }
863 }
864
865 if (dev_id == -1) {
866 RTE_LOG(ERR, USER1, "Device doesn't support asymmetric. "
867 "Test skipped.\n");
868 return TEST_FAILED;
869 }
870
871 /* Set valid device count */
872 ts_params->valid_dev_count = nb_devs;
873
874 /* configure device with num qp */
875 ts_params->conf.nb_queue_pairs = info.max_nb_queue_pairs;
876 ts_params->conf.socket_id = SOCKET_ID_ANY;
877 ts_params->conf.ff_disable = RTE_CRYPTODEV_FF_SECURITY |
878 RTE_CRYPTODEV_FF_SYMMETRIC_CRYPTO;
879 TEST_ASSERT_SUCCESS(rte_cryptodev_configure(dev_id,
880 &ts_params->conf),
881 "Failed to configure cryptodev %u with %u qps",
882 dev_id, ts_params->conf.nb_queue_pairs);
883
884 /* configure qp */
885 ts_params->qp_conf.nb_descriptors = DEFAULT_NUM_OPS_INFLIGHT;
886 ts_params->qp_conf.mp_session = ts_params->session_mpool;
887 for (qp_id = 0; qp_id < info.max_nb_queue_pairs; qp_id++) {
888 TEST_ASSERT_SUCCESS(rte_cryptodev_queue_pair_setup(
889 dev_id, qp_id, &ts_params->qp_conf,
890 rte_cryptodev_socket_id(dev_id)),
891 "Failed to setup queue pair %u on cryptodev %u ASYM",
892 qp_id, dev_id);
893 }
894
895 ts_params->session_mpool = rte_cryptodev_asym_session_pool_create(
896 "test_asym_sess_mp", TEST_NUM_SESSIONS, 0, 0,
897 SOCKET_ID_ANY);
898
899 TEST_ASSERT_NOT_NULL(ts_params->session_mpool,
900 "session mempool allocation failed");
901 /* >8 End of device, op pool and session configuration for asymmetric crypto section. */
902 return TEST_SUCCESS;
903 }
904
905 static void
testsuite_teardown(void)906 testsuite_teardown(void)
907 {
908 struct crypto_testsuite_params_asym *ts_params = &testsuite_params;
909
910 if (ts_params->op_mpool != NULL) {
911 RTE_LOG(DEBUG, USER1, "CRYPTO_OP_POOL count %u\n",
912 rte_mempool_avail_count(ts_params->op_mpool));
913 }
914
915 /* Free session mempools */
916 if (ts_params->session_mpool != NULL) {
917 rte_mempool_free(ts_params->session_mpool);
918 ts_params->session_mpool = NULL;
919 }
920 }
921
922 static int
ut_setup_asym(void)923 ut_setup_asym(void)
924 {
925 struct crypto_testsuite_params_asym *ts_params = &testsuite_params;
926
927 uint16_t qp_id;
928
929 /* Reconfigure device to default parameters */
930 ts_params->conf.socket_id = SOCKET_ID_ANY;
931
932 TEST_ASSERT_SUCCESS(rte_cryptodev_configure(ts_params->valid_devs[0],
933 &ts_params->conf),
934 "Failed to configure cryptodev %u",
935 ts_params->valid_devs[0]);
936
937 for (qp_id = 0; qp_id < ts_params->conf.nb_queue_pairs ; qp_id++) {
938 TEST_ASSERT_SUCCESS(rte_cryptodev_queue_pair_setup(
939 ts_params->valid_devs[0], qp_id,
940 &ts_params->qp_conf,
941 rte_cryptodev_socket_id(ts_params->valid_devs[0])),
942 "Failed to setup queue pair %u on cryptodev %u",
943 qp_id, ts_params->valid_devs[0]);
944 }
945
946 rte_cryptodev_stats_reset(ts_params->valid_devs[0]);
947
948 /* Start the device */
949 TEST_ASSERT_SUCCESS(rte_cryptodev_start(ts_params->valid_devs[0]),
950 "Failed to start cryptodev %u",
951 ts_params->valid_devs[0]);
952
953 return TEST_SUCCESS;
954 }
955
956 static void
ut_teardown_asym(void)957 ut_teardown_asym(void)
958 {
959 struct crypto_testsuite_params_asym *ts_params = &testsuite_params;
960 struct rte_cryptodev_stats stats;
961
962 rte_cryptodev_stats_get(ts_params->valid_devs[0], &stats);
963
964 /* Stop the device */
965 rte_cryptodev_stop(ts_params->valid_devs[0]);
966 }
967
print_asym_capa(const struct rte_cryptodev_asymmetric_xform_capability * capa)968 static inline void print_asym_capa(
969 const struct rte_cryptodev_asymmetric_xform_capability *capa)
970 {
971 int i = 0;
972
973 printf("\nxform type: %s\n===================\n",
974 rte_crypto_asym_xform_strings[capa->xform_type]);
975 printf("operation supported -");
976
977 for (i = 0; i < RTE_CRYPTO_ASYM_OP_LIST_END; i++) {
978 /* check supported operations */
979 if (rte_cryptodev_asym_xform_capability_check_optype(capa, i))
980 printf(" %s",
981 rte_crypto_asym_op_strings[i]);
982 }
983 switch (capa->xform_type) {
984 case RTE_CRYPTO_ASYM_XFORM_RSA:
985 case RTE_CRYPTO_ASYM_XFORM_MODINV:
986 case RTE_CRYPTO_ASYM_XFORM_MODEX:
987 case RTE_CRYPTO_ASYM_XFORM_DH:
988 case RTE_CRYPTO_ASYM_XFORM_DSA:
989 printf(" modlen: min %d max %d increment %d",
990 capa->modlen.min,
991 capa->modlen.max,
992 capa->modlen.increment);
993 break;
994 case RTE_CRYPTO_ASYM_XFORM_ECDSA:
995 case RTE_CRYPTO_ASYM_XFORM_ECPM:
996 default:
997 break;
998 }
999 printf("\n");
1000 }
1001
1002 static int
test_capability(void)1003 test_capability(void)
1004 {
1005 struct crypto_testsuite_params_asym *ts_params = &testsuite_params;
1006 uint8_t dev_id = ts_params->valid_devs[0];
1007 struct rte_cryptodev_info dev_info;
1008 const struct rte_cryptodev_capabilities *dev_capa;
1009 int i = 0;
1010 struct rte_cryptodev_asym_capability_idx idx;
1011 const struct rte_cryptodev_asymmetric_xform_capability *capa;
1012
1013 rte_cryptodev_info_get(dev_id, &dev_info);
1014 if (!(dev_info.feature_flags &
1015 RTE_CRYPTODEV_FF_ASYMMETRIC_CRYPTO)) {
1016 RTE_LOG(INFO, USER1,
1017 "Device doesn't support asymmetric. Test Skipped\n");
1018 return TEST_SUCCESS;
1019 }
1020
1021 /* print xform capability */
1022 for (i = 0;
1023 dev_info.capabilities[i].op != RTE_CRYPTO_OP_TYPE_UNDEFINED;
1024 i++) {
1025 dev_capa = &(dev_info.capabilities[i]);
1026 if (dev_info.capabilities[i].op ==
1027 RTE_CRYPTO_OP_TYPE_ASYMMETRIC) {
1028 idx.type = dev_capa->asym.xform_capa.xform_type;
1029
1030 capa = rte_cryptodev_asym_capability_get(dev_id,
1031 (const struct
1032 rte_cryptodev_asym_capability_idx *) &idx);
1033 print_asym_capa(capa);
1034 }
1035 }
1036 return TEST_SUCCESS;
1037 }
1038
1039 static int
test_dh_gen_shared_sec(struct rte_crypto_asym_xform * xfrm)1040 test_dh_gen_shared_sec(struct rte_crypto_asym_xform *xfrm)
1041 {
1042 struct crypto_testsuite_params_asym *ts_params = &testsuite_params;
1043 struct rte_mempool *op_mpool = ts_params->op_mpool;
1044 struct rte_mempool *sess_mpool = ts_params->session_mpool;
1045 uint8_t dev_id = ts_params->valid_devs[0];
1046 struct rte_crypto_asym_op *asym_op = NULL;
1047 struct rte_crypto_op *op = NULL, *result_op = NULL;
1048 void *sess = NULL;
1049 int ret, status = TEST_SUCCESS;
1050 uint8_t output[TEST_DH_MOD_LEN];
1051 struct rte_crypto_asym_xform xform = *xfrm;
1052 uint8_t peer[] = "01234567890123456789012345678901234567890123456789";
1053
1054 /* set up crypto op data structure */
1055 op = rte_crypto_op_alloc(op_mpool, RTE_CRYPTO_OP_TYPE_ASYMMETRIC);
1056 if (!op) {
1057 RTE_LOG(ERR, USER1,
1058 "line %u FAILED: %s",
1059 __LINE__, "Failed to allocate asymmetric crypto "
1060 "operation struct");
1061 status = TEST_FAILED;
1062 goto error_exit;
1063 }
1064 asym_op = op->asym;
1065
1066 /* Setup a xform and op to generate private key only */
1067 xform.dh.type = RTE_CRYPTO_ASYM_OP_SHARED_SECRET_COMPUTE;
1068 xform.next = NULL;
1069 asym_op->dh.priv_key.data = dh_test_params.priv_key.data;
1070 asym_op->dh.priv_key.length = dh_test_params.priv_key.length;
1071 asym_op->dh.pub_key.data = (uint8_t *)peer;
1072 asym_op->dh.pub_key.length = sizeof(peer);
1073 asym_op->dh.shared_secret.data = output;
1074 asym_op->dh.shared_secret.length = sizeof(output);
1075
1076 ret = rte_cryptodev_asym_session_create(dev_id, &xform, sess_mpool, &sess);
1077 if (ret < 0) {
1078 RTE_LOG(ERR, USER1,
1079 "line %u FAILED: %s", __LINE__,
1080 "Session creation failed");
1081 status = (ret == -ENOTSUP) ? TEST_SKIPPED : TEST_FAILED;
1082 goto error_exit;
1083 }
1084
1085 /* attach asymmetric crypto session to crypto operations */
1086 rte_crypto_op_attach_asym_session(op, sess);
1087
1088 RTE_LOG(DEBUG, USER1, "Process ASYM operation");
1089
1090 /* Process crypto operation */
1091 if (rte_cryptodev_enqueue_burst(dev_id, 0, &op, 1) != 1) {
1092 RTE_LOG(ERR, USER1,
1093 "line %u FAILED: %s",
1094 __LINE__, "Error sending packet for operation");
1095 status = TEST_FAILED;
1096 goto error_exit;
1097 }
1098
1099 while (rte_cryptodev_dequeue_burst(dev_id, 0, &result_op, 1) == 0)
1100 rte_pause();
1101
1102 if (result_op == NULL) {
1103 RTE_LOG(ERR, USER1,
1104 "line %u FAILED: %s",
1105 __LINE__, "Failed to process asym crypto op");
1106 status = TEST_FAILED;
1107 goto error_exit;
1108 }
1109
1110 debug_hexdump(stdout, "shared secret:",
1111 asym_op->dh.shared_secret.data,
1112 asym_op->dh.shared_secret.length);
1113
1114 error_exit:
1115 if (sess != NULL)
1116 rte_cryptodev_asym_session_free(dev_id, sess);
1117 if (op != NULL)
1118 rte_crypto_op_free(op);
1119 return status;
1120 }
1121
1122 static int
test_dh_gen_priv_key(struct rte_crypto_asym_xform * xfrm)1123 test_dh_gen_priv_key(struct rte_crypto_asym_xform *xfrm)
1124 {
1125 struct crypto_testsuite_params_asym *ts_params = &testsuite_params;
1126 struct rte_mempool *op_mpool = ts_params->op_mpool;
1127 struct rte_mempool *sess_mpool = ts_params->session_mpool;
1128 uint8_t dev_id = ts_params->valid_devs[0];
1129 struct rte_crypto_asym_op *asym_op = NULL;
1130 struct rte_crypto_op *op = NULL, *result_op = NULL;
1131 void *sess = NULL;
1132 int ret, status = TEST_SUCCESS;
1133 uint8_t output[TEST_DH_MOD_LEN];
1134 struct rte_crypto_asym_xform xform = *xfrm;
1135
1136 /* set up crypto op data structure */
1137 op = rte_crypto_op_alloc(op_mpool, RTE_CRYPTO_OP_TYPE_ASYMMETRIC);
1138 if (!op) {
1139 RTE_LOG(ERR, USER1,
1140 "line %u FAILED: %s",
1141 __LINE__, "Failed to allocate asymmetric crypto "
1142 "operation struct");
1143 status = TEST_FAILED;
1144 goto error_exit;
1145 }
1146 asym_op = op->asym;
1147
1148 /* Setup a xform and op to generate private key only */
1149 xform.dh.type = RTE_CRYPTO_ASYM_OP_PRIVATE_KEY_GENERATE;
1150 xform.next = NULL;
1151 asym_op->dh.priv_key.data = output;
1152 asym_op->dh.priv_key.length = sizeof(output);
1153
1154 ret = rte_cryptodev_asym_session_create(dev_id, &xform, sess_mpool, &sess);
1155 if (ret < 0) {
1156 RTE_LOG(ERR, USER1,
1157 "line %u FAILED: %s", __LINE__,
1158 "Session creation failed");
1159 status = (ret == -ENOTSUP) ? TEST_SKIPPED : TEST_FAILED;
1160 goto error_exit;
1161 }
1162
1163 /* attach asymmetric crypto session to crypto operations */
1164 rte_crypto_op_attach_asym_session(op, sess);
1165
1166 RTE_LOG(DEBUG, USER1, "Process ASYM operation");
1167
1168 /* Process crypto operation */
1169 if (rte_cryptodev_enqueue_burst(dev_id, 0, &op, 1) != 1) {
1170 RTE_LOG(ERR, USER1,
1171 "line %u FAILED: %s",
1172 __LINE__, "Error sending packet for operation");
1173 status = TEST_FAILED;
1174 goto error_exit;
1175 }
1176
1177 while (rte_cryptodev_dequeue_burst(dev_id, 0, &result_op, 1) == 0)
1178 rte_pause();
1179
1180 if (result_op == NULL) {
1181 RTE_LOG(ERR, USER1,
1182 "line %u FAILED: %s",
1183 __LINE__, "Failed to process asym crypto op");
1184 status = TEST_FAILED;
1185 goto error_exit;
1186 }
1187
1188 debug_hexdump(stdout, "private key:",
1189 asym_op->dh.priv_key.data,
1190 asym_op->dh.priv_key.length);
1191
1192
1193 error_exit:
1194 if (sess != NULL)
1195 rte_cryptodev_asym_session_free(dev_id, sess);
1196 if (op != NULL)
1197 rte_crypto_op_free(op);
1198
1199 return status;
1200 }
1201
1202
1203 static int
test_dh_gen_pub_key(struct rte_crypto_asym_xform * xfrm)1204 test_dh_gen_pub_key(struct rte_crypto_asym_xform *xfrm)
1205 {
1206 struct crypto_testsuite_params_asym *ts_params = &testsuite_params;
1207 struct rte_mempool *op_mpool = ts_params->op_mpool;
1208 struct rte_mempool *sess_mpool = ts_params->session_mpool;
1209 uint8_t dev_id = ts_params->valid_devs[0];
1210 struct rte_crypto_asym_op *asym_op = NULL;
1211 struct rte_crypto_op *op = NULL, *result_op = NULL;
1212 void *sess = NULL;
1213 int ret, status = TEST_SUCCESS;
1214 uint8_t output[TEST_DH_MOD_LEN];
1215 struct rte_crypto_asym_xform xform = *xfrm;
1216
1217 /* set up crypto op data structure */
1218 op = rte_crypto_op_alloc(op_mpool, RTE_CRYPTO_OP_TYPE_ASYMMETRIC);
1219 if (!op) {
1220 RTE_LOG(ERR, USER1,
1221 "line %u FAILED: %s",
1222 __LINE__, "Failed to allocate asymmetric crypto "
1223 "operation struct");
1224 status = TEST_FAILED;
1225 goto error_exit;
1226 }
1227 asym_op = op->asym;
1228 /* Setup a xform chain to generate public key
1229 * using test private key
1230 *
1231 */
1232 xform.dh.type = RTE_CRYPTO_ASYM_OP_PUBLIC_KEY_GENERATE;
1233 xform.next = NULL;
1234
1235 asym_op->dh.pub_key.data = output;
1236 asym_op->dh.pub_key.length = sizeof(output);
1237 /* load pre-defined private key */
1238 asym_op->dh.priv_key.data = rte_malloc(NULL,
1239 dh_test_params.priv_key.length,
1240 0);
1241 asym_op->dh.priv_key = dh_test_params.priv_key;
1242
1243 ret = rte_cryptodev_asym_session_create(dev_id, &xform, sess_mpool, &sess);
1244 if (ret < 0) {
1245 RTE_LOG(ERR, USER1,
1246 "line %u FAILED: %s", __LINE__,
1247 "Session creation failed");
1248 status = (ret == -ENOTSUP) ? TEST_SKIPPED : TEST_FAILED;
1249 goto error_exit;
1250 }
1251
1252 /* attach asymmetric crypto session to crypto operations */
1253 rte_crypto_op_attach_asym_session(op, sess);
1254
1255 RTE_LOG(DEBUG, USER1, "Process ASYM operation");
1256
1257 /* Process crypto operation */
1258 if (rte_cryptodev_enqueue_burst(dev_id, 0, &op, 1) != 1) {
1259 RTE_LOG(ERR, USER1,
1260 "line %u FAILED: %s",
1261 __LINE__, "Error sending packet for operation");
1262 status = TEST_FAILED;
1263 goto error_exit;
1264 }
1265
1266 while (rte_cryptodev_dequeue_burst(dev_id, 0, &result_op, 1) == 0)
1267 rte_pause();
1268
1269 if (result_op == NULL) {
1270 RTE_LOG(ERR, USER1,
1271 "line %u FAILED: %s",
1272 __LINE__, "Failed to process asym crypto op");
1273 status = TEST_FAILED;
1274 goto error_exit;
1275 }
1276
1277 debug_hexdump(stdout, "pub key:",
1278 asym_op->dh.pub_key.data, asym_op->dh.pub_key.length);
1279
1280 debug_hexdump(stdout, "priv key:",
1281 asym_op->dh.priv_key.data, asym_op->dh.priv_key.length);
1282
1283 error_exit:
1284 if (sess != NULL)
1285 rte_cryptodev_asym_session_free(dev_id, sess);
1286 if (op != NULL)
1287 rte_crypto_op_free(op);
1288
1289 return status;
1290 }
1291
1292 static int
test_dh_gen_kp(struct rte_crypto_asym_xform * xfrm)1293 test_dh_gen_kp(struct rte_crypto_asym_xform *xfrm)
1294 {
1295 struct crypto_testsuite_params_asym *ts_params = &testsuite_params;
1296 struct rte_mempool *op_mpool = ts_params->op_mpool;
1297 struct rte_mempool *sess_mpool = ts_params->session_mpool;
1298 uint8_t dev_id = ts_params->valid_devs[0];
1299 struct rte_crypto_asym_op *asym_op = NULL;
1300 struct rte_crypto_op *op = NULL, *result_op = NULL;
1301 void *sess = NULL;
1302 int ret, status = TEST_SUCCESS;
1303 uint8_t out_pub_key[TEST_DH_MOD_LEN];
1304 uint8_t out_prv_key[TEST_DH_MOD_LEN];
1305 struct rte_crypto_asym_xform pub_key_xform;
1306 struct rte_crypto_asym_xform xform = *xfrm;
1307
1308 /* set up crypto op data structure */
1309 op = rte_crypto_op_alloc(op_mpool, RTE_CRYPTO_OP_TYPE_ASYMMETRIC);
1310 if (!op) {
1311 RTE_LOG(ERR, USER1,
1312 "line %u FAILED: %s",
1313 __LINE__, "Failed to allocate asymmetric crypto "
1314 "operation struct");
1315 status = TEST_FAILED;
1316 goto error_exit;
1317 }
1318 asym_op = op->asym;
1319 /* Setup a xform chain to generate
1320 * private key first followed by
1321 * public key
1322 */xform.dh.type = RTE_CRYPTO_ASYM_OP_PRIVATE_KEY_GENERATE;
1323 pub_key_xform.xform_type = RTE_CRYPTO_ASYM_XFORM_DH;
1324 pub_key_xform.dh.type = RTE_CRYPTO_ASYM_OP_PUBLIC_KEY_GENERATE;
1325 xform.next = &pub_key_xform;
1326
1327 asym_op->dh.pub_key.data = out_pub_key;
1328 asym_op->dh.pub_key.length = sizeof(out_pub_key);
1329 asym_op->dh.priv_key.data = out_prv_key;
1330 asym_op->dh.priv_key.length = sizeof(out_prv_key);
1331
1332 ret = rte_cryptodev_asym_session_create(dev_id, &xform, sess_mpool, &sess);
1333 if (ret < 0) {
1334 RTE_LOG(ERR, USER1,
1335 "line %u FAILED: %s", __LINE__,
1336 "Session creation failed");
1337 status = (ret == -ENOTSUP) ? TEST_SKIPPED : TEST_FAILED;
1338 goto error_exit;
1339 }
1340
1341 /* attach asymmetric crypto session to crypto operations */
1342 rte_crypto_op_attach_asym_session(op, sess);
1343
1344 RTE_LOG(DEBUG, USER1, "Process ASYM operation");
1345
1346 /* Process crypto operation */
1347 if (rte_cryptodev_enqueue_burst(dev_id, 0, &op, 1) != 1) {
1348 RTE_LOG(ERR, USER1,
1349 "line %u FAILED: %s",
1350 __LINE__, "Error sending packet for operation");
1351 status = TEST_FAILED;
1352 goto error_exit;
1353 }
1354
1355 while (rte_cryptodev_dequeue_burst(dev_id, 0, &result_op, 1) == 0)
1356 rte_pause();
1357
1358 if (result_op == NULL) {
1359 RTE_LOG(ERR, USER1,
1360 "line %u FAILED: %s",
1361 __LINE__, "Failed to process asym crypto op");
1362 status = TEST_FAILED;
1363 goto error_exit;
1364 }
1365 debug_hexdump(stdout, "priv key:",
1366 out_prv_key, asym_op->dh.priv_key.length);
1367 debug_hexdump(stdout, "pub key:",
1368 out_pub_key, asym_op->dh.pub_key.length);
1369
1370 error_exit:
1371 if (sess != NULL)
1372 rte_cryptodev_asym_session_free(dev_id, sess);
1373 if (op != NULL)
1374 rte_crypto_op_free(op);
1375
1376 return status;
1377 }
1378
1379 static int
test_mod_inv(void)1380 test_mod_inv(void)
1381 {
1382 struct crypto_testsuite_params_asym *ts_params = &testsuite_params;
1383 struct rte_mempool *op_mpool = ts_params->op_mpool;
1384 struct rte_mempool *sess_mpool = ts_params->session_mpool;
1385 uint8_t dev_id = ts_params->valid_devs[0];
1386 struct rte_crypto_asym_op *asym_op = NULL;
1387 struct rte_crypto_op *op = NULL, *result_op = NULL;
1388 void *sess = NULL;
1389 int status = TEST_SUCCESS;
1390 struct rte_cryptodev_asym_capability_idx cap_idx;
1391 const struct rte_cryptodev_asymmetric_xform_capability *capability;
1392 uint8_t input[TEST_DATA_SIZE] = {0};
1393 int ret = 0;
1394 uint8_t result[sizeof(mod_p)] = { 0 };
1395
1396 if (rte_cryptodev_asym_get_xform_enum(
1397 &modinv_xform.xform_type, "modinv") < 0) {
1398 RTE_LOG(ERR, USER1,
1399 "Invalid ASYM algorithm specified\n");
1400 return -1;
1401 }
1402
1403 cap_idx.type = modinv_xform.xform_type;
1404 capability = rte_cryptodev_asym_capability_get(dev_id,
1405 &cap_idx);
1406
1407 if (capability == NULL) {
1408 RTE_LOG(INFO, USER1,
1409 "Device doesn't support MOD INV. Test Skipped\n");
1410 return TEST_SKIPPED;
1411 }
1412
1413 if (rte_cryptodev_asym_xform_capability_check_modlen(
1414 capability,
1415 modinv_xform.modinv.modulus.length)) {
1416 RTE_LOG(ERR, USER1,
1417 "Invalid MODULUS length specified\n");
1418 return TEST_SKIPPED;
1419 }
1420
1421 ret = rte_cryptodev_asym_session_create(dev_id, &modinv_xform, sess_mpool, &sess);
1422 if (ret < 0) {
1423 RTE_LOG(ERR, USER1, "line %u "
1424 "FAILED: %s", __LINE__,
1425 "Session creation failed");
1426 status = (ret == -ENOTSUP) ? TEST_SKIPPED : TEST_FAILED;
1427 goto error_exit;
1428 }
1429
1430 /* generate crypto op data structure */
1431 op = rte_crypto_op_alloc(op_mpool, RTE_CRYPTO_OP_TYPE_ASYMMETRIC);
1432 if (!op) {
1433 RTE_LOG(ERR, USER1,
1434 "line %u FAILED: %s",
1435 __LINE__, "Failed to allocate asymmetric crypto "
1436 "operation struct");
1437 status = TEST_FAILED;
1438 goto error_exit;
1439 }
1440
1441 asym_op = op->asym;
1442 memcpy(input, base, sizeof(base));
1443 asym_op->modinv.base.data = input;
1444 asym_op->modinv.base.length = sizeof(base);
1445 asym_op->modinv.result.data = result;
1446 asym_op->modinv.result.length = sizeof(result);
1447
1448 /* attach asymmetric crypto session to crypto operations */
1449 rte_crypto_op_attach_asym_session(op, sess);
1450
1451 RTE_LOG(DEBUG, USER1, "Process ASYM operation");
1452
1453 /* Process crypto operation */
1454 if (rte_cryptodev_enqueue_burst(dev_id, 0, &op, 1) != 1) {
1455 RTE_LOG(ERR, USER1,
1456 "line %u FAILED: %s",
1457 __LINE__, "Error sending packet for operation");
1458 status = TEST_FAILED;
1459 goto error_exit;
1460 }
1461
1462 while (rte_cryptodev_dequeue_burst(dev_id, 0, &result_op, 1) == 0)
1463 rte_pause();
1464
1465 if (result_op == NULL) {
1466 RTE_LOG(ERR, USER1,
1467 "line %u FAILED: %s",
1468 __LINE__, "Failed to process asym crypto op");
1469 status = TEST_FAILED;
1470 goto error_exit;
1471 }
1472
1473 ret = verify_modinv(mod_inv, result_op);
1474 if (ret) {
1475 RTE_LOG(ERR, USER1,
1476 "operation verification failed\n");
1477 status = TEST_FAILED;
1478 }
1479
1480 error_exit:
1481 if (sess)
1482 rte_cryptodev_asym_session_free(dev_id, sess);
1483
1484 if (op)
1485 rte_crypto_op_free(op);
1486
1487 TEST_ASSERT_EQUAL(status, 0, "Test failed");
1488
1489 return status;
1490 }
1491
1492 static int
test_mod_exp(void)1493 test_mod_exp(void)
1494 {
1495 struct crypto_testsuite_params_asym *ts_params = &testsuite_params;
1496 struct rte_mempool *op_mpool = ts_params->op_mpool;
1497 struct rte_mempool *sess_mpool = ts_params->session_mpool;
1498 uint8_t dev_id = ts_params->valid_devs[0];
1499 struct rte_crypto_asym_op *asym_op = NULL;
1500 struct rte_crypto_op *op = NULL, *result_op = NULL;
1501 void *sess = NULL;
1502 int status = TEST_SUCCESS;
1503 struct rte_cryptodev_asym_capability_idx cap_idx;
1504 const struct rte_cryptodev_asymmetric_xform_capability *capability;
1505 uint8_t input[TEST_DATA_SIZE] = {0};
1506 int ret = 0;
1507 uint8_t result[sizeof(mod_p)] = { 0 };
1508
1509 if (rte_cryptodev_asym_get_xform_enum(&modex_xform.xform_type,
1510 "modexp")
1511 < 0) {
1512 RTE_LOG(ERR, USER1,
1513 "Invalid ASYM algorithm specified\n");
1514 return -1;
1515 }
1516
1517 /* check for modlen capability */
1518 cap_idx.type = modex_xform.xform_type;
1519 capability = rte_cryptodev_asym_capability_get(dev_id, &cap_idx);
1520
1521 if (capability == NULL) {
1522 RTE_LOG(INFO, USER1,
1523 "Device doesn't support MOD EXP. Test Skipped\n");
1524 return TEST_SKIPPED;
1525 }
1526
1527 if (rte_cryptodev_asym_xform_capability_check_modlen(
1528 capability, modex_xform.modex.modulus.length)) {
1529 RTE_LOG(ERR, USER1,
1530 "Invalid MODULUS length specified\n");
1531 return TEST_SKIPPED;
1532 }
1533
1534 /* Create op, create session, and process packets. 8< */
1535 op = rte_crypto_op_alloc(op_mpool, RTE_CRYPTO_OP_TYPE_ASYMMETRIC);
1536 if (!op) {
1537 RTE_LOG(ERR, USER1,
1538 "line %u FAILED: %s",
1539 __LINE__, "Failed to allocate asymmetric crypto "
1540 "operation struct");
1541 status = TEST_FAILED;
1542 goto error_exit;
1543 }
1544
1545 ret = rte_cryptodev_asym_session_create(dev_id, &modex_xform, sess_mpool, &sess);
1546 if (ret < 0) {
1547 RTE_LOG(ERR, USER1,
1548 "line %u "
1549 "FAILED: %s", __LINE__,
1550 "Session creation failed");
1551 status = (ret == -ENOTSUP) ? TEST_SKIPPED : TEST_FAILED;
1552 goto error_exit;
1553 }
1554
1555 asym_op = op->asym;
1556 memcpy(input, base, sizeof(base));
1557 asym_op->modex.base.data = input;
1558 asym_op->modex.base.length = sizeof(base);
1559 asym_op->modex.result.data = result;
1560 asym_op->modex.result.length = sizeof(result);
1561 /* attach asymmetric crypto session to crypto operations */
1562 rte_crypto_op_attach_asym_session(op, sess);
1563
1564 RTE_LOG(DEBUG, USER1, "Process ASYM operation");
1565 /* Process crypto operation */
1566 if (rte_cryptodev_enqueue_burst(dev_id, 0, &op, 1) != 1) {
1567 RTE_LOG(ERR, USER1,
1568 "line %u FAILED: %s",
1569 __LINE__, "Error sending packet for operation");
1570 status = TEST_FAILED;
1571 goto error_exit;
1572 }
1573
1574 while (rte_cryptodev_dequeue_burst(dev_id, 0, &result_op, 1) == 0)
1575 rte_pause();
1576
1577 if (result_op == NULL) {
1578 RTE_LOG(ERR, USER1,
1579 "line %u FAILED: %s",
1580 __LINE__, "Failed to process asym crypto op");
1581 status = TEST_FAILED;
1582 goto error_exit;
1583 }
1584 /* >8 End of create op, create session, and process packets section. */
1585 ret = verify_modexp(mod_exp, result_op);
1586 if (ret) {
1587 RTE_LOG(ERR, USER1,
1588 "operation verification failed\n");
1589 status = TEST_FAILED;
1590 }
1591
1592 error_exit:
1593 if (sess != NULL)
1594 rte_cryptodev_asym_session_free(dev_id, sess);
1595
1596 if (op != NULL)
1597 rte_crypto_op_free(op);
1598
1599 TEST_ASSERT_EQUAL(status, 0, "Test failed");
1600
1601 return status;
1602 }
1603
1604 static int
test_dh_keygenration(void)1605 test_dh_keygenration(void)
1606 {
1607 int status;
1608
1609 debug_hexdump(stdout, "p:", dh_xform.dh.p.data, dh_xform.dh.p.length);
1610 debug_hexdump(stdout, "g:", dh_xform.dh.g.data, dh_xform.dh.g.length);
1611 debug_hexdump(stdout, "priv_key:", dh_test_params.priv_key.data,
1612 dh_test_params.priv_key.length);
1613
1614 RTE_LOG(INFO, USER1,
1615 "Test Public and Private key pair generation\n");
1616
1617 status = test_dh_gen_kp(&dh_xform);
1618 TEST_ASSERT_EQUAL(status, 0, "Test failed");
1619
1620 RTE_LOG(INFO, USER1,
1621 "Test Public Key Generation using pre-defined priv key\n");
1622
1623 status = test_dh_gen_pub_key(&dh_xform);
1624 TEST_ASSERT_EQUAL(status, 0, "Test failed");
1625
1626 RTE_LOG(INFO, USER1,
1627 "Test Private Key Generation only\n");
1628
1629 status = test_dh_gen_priv_key(&dh_xform);
1630 TEST_ASSERT_EQUAL(status, 0, "Test failed");
1631
1632 RTE_LOG(INFO, USER1,
1633 "Test shared secret compute\n");
1634
1635 status = test_dh_gen_shared_sec(&dh_xform);
1636 TEST_ASSERT_EQUAL(status, 0, "Test failed");
1637
1638 return status;
1639 }
1640
1641 static int
test_dsa_sign(void)1642 test_dsa_sign(void)
1643 {
1644 struct crypto_testsuite_params_asym *ts_params = &testsuite_params;
1645 struct rte_mempool *op_mpool = ts_params->op_mpool;
1646 struct rte_mempool *sess_mpool = ts_params->session_mpool;
1647 uint8_t dev_id = ts_params->valid_devs[0];
1648 struct rte_crypto_asym_op *asym_op = NULL;
1649 struct rte_crypto_op *op = NULL, *result_op = NULL;
1650 void *sess = NULL;
1651 int status = TEST_SUCCESS;
1652 uint8_t r[TEST_DH_MOD_LEN];
1653 uint8_t s[TEST_DH_MOD_LEN];
1654 uint8_t dgst[] = "35d81554afaad2cf18f3a1770d5fedc4ea5be344";
1655 int ret;
1656
1657 ret = rte_cryptodev_asym_session_create(dev_id, &dsa_xform, sess_mpool, &sess);
1658 if (ret < 0) {
1659 RTE_LOG(ERR, USER1,
1660 "line %u FAILED: %s", __LINE__,
1661 "Session creation failed");
1662 status = (ret == -ENOTSUP) ? TEST_SKIPPED : TEST_FAILED;
1663 goto error_exit;
1664 }
1665 /* set up crypto op data structure */
1666 op = rte_crypto_op_alloc(op_mpool, RTE_CRYPTO_OP_TYPE_ASYMMETRIC);
1667 if (!op) {
1668 RTE_LOG(ERR, USER1,
1669 "line %u FAILED: %s",
1670 __LINE__, "Failed to allocate asymmetric crypto "
1671 "operation struct");
1672 status = TEST_FAILED;
1673 goto error_exit;
1674 }
1675 asym_op = op->asym;
1676
1677 debug_hexdump(stdout, "p: ", dsa_xform.dsa.p.data,
1678 dsa_xform.dsa.p.length);
1679 debug_hexdump(stdout, "q: ", dsa_xform.dsa.q.data,
1680 dsa_xform.dsa.q.length);
1681 debug_hexdump(stdout, "g: ", dsa_xform.dsa.g.data,
1682 dsa_xform.dsa.g.length);
1683 debug_hexdump(stdout, "priv_key: ", dsa_xform.dsa.x.data,
1684 dsa_xform.dsa.x.length);
1685
1686 /* attach asymmetric crypto session to crypto operations */
1687 rte_crypto_op_attach_asym_session(op, sess);
1688 asym_op->dsa.op_type = RTE_CRYPTO_ASYM_OP_SIGN;
1689 asym_op->dsa.message.data = dgst;
1690 asym_op->dsa.message.length = sizeof(dgst);
1691 asym_op->dsa.r.length = sizeof(r);
1692 asym_op->dsa.r.data = r;
1693 asym_op->dsa.s.length = sizeof(s);
1694 asym_op->dsa.s.data = s;
1695
1696 RTE_LOG(DEBUG, USER1, "Process ASYM operation");
1697
1698 /* Process crypto operation */
1699 if (rte_cryptodev_enqueue_burst(dev_id, 0, &op, 1) != 1) {
1700 RTE_LOG(ERR, USER1,
1701 "line %u FAILED: %s",
1702 __LINE__, "Error sending packet for operation");
1703 status = TEST_FAILED;
1704 goto error_exit;
1705 }
1706
1707 while (rte_cryptodev_dequeue_burst(dev_id, 0, &result_op, 1) == 0)
1708 rte_pause();
1709
1710 if (result_op == NULL) {
1711 RTE_LOG(ERR, USER1,
1712 "line %u FAILED: %s",
1713 __LINE__, "Failed to process asym crypto op");
1714 status = TEST_FAILED;
1715 goto error_exit;
1716 }
1717
1718 asym_op = result_op->asym;
1719
1720 debug_hexdump(stdout, "r:",
1721 asym_op->dsa.r.data, asym_op->dsa.r.length);
1722 debug_hexdump(stdout, "s:",
1723 asym_op->dsa.s.data, asym_op->dsa.s.length);
1724
1725 /* Test PMD DSA sign verification using signer public key */
1726 asym_op->dsa.op_type = RTE_CRYPTO_ASYM_OP_VERIFY;
1727
1728 /* copy signer public key */
1729 asym_op->dsa.y.data = dsa_test_params.y.data;
1730 asym_op->dsa.y.length = dsa_test_params.y.length;
1731
1732 /* Process crypto operation */
1733 if (rte_cryptodev_enqueue_burst(dev_id, 0, &op, 1) != 1) {
1734 RTE_LOG(ERR, USER1,
1735 "line %u FAILED: %s",
1736 __LINE__, "Error sending packet for operation");
1737 status = TEST_FAILED;
1738 goto error_exit;
1739 }
1740
1741 while (rte_cryptodev_dequeue_burst(dev_id, 0, &result_op, 1) == 0)
1742 rte_pause();
1743
1744 if (result_op == NULL) {
1745 RTE_LOG(ERR, USER1,
1746 "line %u FAILED: %s",
1747 __LINE__, "Failed to process asym crypto op");
1748 status = TEST_FAILED;
1749 goto error_exit;
1750 }
1751
1752 if (result_op->status != RTE_CRYPTO_OP_STATUS_SUCCESS) {
1753 RTE_LOG(ERR, USER1,
1754 "line %u FAILED: %s",
1755 __LINE__, "Failed to process asym crypto op");
1756 status = TEST_FAILED;
1757 }
1758 error_exit:
1759 if (sess != NULL)
1760 rte_cryptodev_asym_session_free(dev_id, sess);
1761 if (op != NULL)
1762 rte_crypto_op_free(op);
1763 return status;
1764 }
1765
1766 static int
test_dsa(void)1767 test_dsa(void)
1768 {
1769 int status;
1770 status = test_dsa_sign();
1771 TEST_ASSERT_EQUAL(status, 0, "Test failed");
1772 return status;
1773 }
1774
1775 static int
test_ecdsa_sign_verify(enum curve curve_id)1776 test_ecdsa_sign_verify(enum curve curve_id)
1777 {
1778 struct crypto_testsuite_params_asym *ts_params = &testsuite_params;
1779 struct rte_mempool *sess_mpool = ts_params->session_mpool;
1780 struct rte_mempool *op_mpool = ts_params->op_mpool;
1781 struct crypto_testsuite_ecdsa_params input_params;
1782 void *sess = NULL;
1783 uint8_t dev_id = ts_params->valid_devs[0];
1784 struct rte_crypto_op *result_op = NULL;
1785 uint8_t output_buf_r[TEST_DATA_SIZE];
1786 uint8_t output_buf_s[TEST_DATA_SIZE];
1787 struct rte_crypto_asym_xform xform;
1788 struct rte_crypto_asym_op *asym_op;
1789 struct rte_cryptodev_info dev_info;
1790 struct rte_crypto_op *op = NULL;
1791 int ret, status = TEST_SUCCESS;
1792
1793 switch (curve_id) {
1794 case SECP192R1:
1795 input_params = ecdsa_param_secp192r1;
1796 break;
1797 case SECP224R1:
1798 input_params = ecdsa_param_secp224r1;
1799 break;
1800 case SECP256R1:
1801 input_params = ecdsa_param_secp256r1;
1802 break;
1803 case SECP384R1:
1804 input_params = ecdsa_param_secp384r1;
1805 break;
1806 case SECP521R1:
1807 input_params = ecdsa_param_secp521r1;
1808 break;
1809 default:
1810 RTE_LOG(ERR, USER1,
1811 "line %u FAILED: %s", __LINE__,
1812 "Unsupported curve id\n");
1813 status = TEST_FAILED;
1814 goto exit;
1815 }
1816
1817 rte_cryptodev_info_get(dev_id, &dev_info);
1818
1819 /* Setup crypto op data structure */
1820 op = rte_crypto_op_alloc(op_mpool, RTE_CRYPTO_OP_TYPE_ASYMMETRIC);
1821 if (op == NULL) {
1822 RTE_LOG(ERR, USER1,
1823 "line %u FAILED: %s", __LINE__,
1824 "Failed to allocate asymmetric crypto "
1825 "operation struct\n");
1826 status = TEST_FAILED;
1827 goto exit;
1828 }
1829 asym_op = op->asym;
1830
1831 /* Setup asym xform */
1832 xform.next = NULL;
1833 xform.xform_type = RTE_CRYPTO_ASYM_XFORM_ECDSA;
1834 xform.ec.curve_id = input_params.curve;
1835
1836 ret = rte_cryptodev_asym_session_create(dev_id, &xform, sess_mpool, &sess);
1837 if (ret < 0) {
1838 RTE_LOG(ERR, USER1,
1839 "line %u FAILED: %s", __LINE__,
1840 "Session creation failed\n");
1841 status = (ret == -ENOTSUP) ? TEST_SKIPPED : TEST_FAILED;
1842 goto exit;
1843 }
1844
1845 /* Attach asymmetric crypto session to crypto operations */
1846 rte_crypto_op_attach_asym_session(op, sess);
1847
1848 /* Compute sign */
1849
1850 /* Populate op with operational details */
1851 op->asym->ecdsa.op_type = RTE_CRYPTO_ASYM_OP_SIGN;
1852 op->asym->ecdsa.message.data = input_params.digest.data;
1853 op->asym->ecdsa.message.length = input_params.digest.length;
1854 op->asym->ecdsa.k.data = input_params.scalar.data;
1855 op->asym->ecdsa.k.length = input_params.scalar.length;
1856 op->asym->ecdsa.pkey.data = input_params.pkey.data;
1857 op->asym->ecdsa.pkey.length = input_params.pkey.length;
1858
1859 /* Init out buf */
1860 op->asym->ecdsa.r.data = output_buf_r;
1861 op->asym->ecdsa.s.data = output_buf_s;
1862
1863 RTE_LOG(DEBUG, USER1, "Process ASYM operation\n");
1864
1865 /* Process crypto operation */
1866 if (rte_cryptodev_enqueue_burst(dev_id, 0, &op, 1) != 1) {
1867 RTE_LOG(ERR, USER1,
1868 "line %u FAILED: %s", __LINE__,
1869 "Error sending packet for operation\n");
1870 status = TEST_FAILED;
1871 goto exit;
1872 }
1873
1874 while (rte_cryptodev_dequeue_burst(dev_id, 0, &result_op, 1) == 0)
1875 rte_pause();
1876
1877 if (result_op == NULL) {
1878 RTE_LOG(ERR, USER1,
1879 "line %u FAILED: %s", __LINE__,
1880 "Failed to process asym crypto op\n");
1881 status = TEST_FAILED;
1882 goto exit;
1883 }
1884
1885 if (result_op->status != RTE_CRYPTO_OP_STATUS_SUCCESS) {
1886 RTE_LOG(ERR, USER1,
1887 "line %u FAILED: %s", __LINE__,
1888 "Failed to process asym crypto op\n");
1889 status = TEST_FAILED;
1890 goto exit;
1891 }
1892
1893 asym_op = result_op->asym;
1894
1895 debug_hexdump(stdout, "r:",
1896 asym_op->ecdsa.r.data, asym_op->ecdsa.r.length);
1897 debug_hexdump(stdout, "s:",
1898 asym_op->ecdsa.s.data, asym_op->ecdsa.s.length);
1899
1900 ret = verify_ecdsa_sign(input_params.sign_r.data,
1901 input_params.sign_s.data, result_op);
1902 if (ret) {
1903 status = TEST_FAILED;
1904 RTE_LOG(ERR, USER1,
1905 "line %u FAILED: %s", __LINE__,
1906 "ECDSA sign failed.\n");
1907 goto exit;
1908 }
1909
1910 /* Verify sign */
1911
1912 /* Populate op with operational details */
1913 op->asym->ecdsa.op_type = RTE_CRYPTO_ASYM_OP_VERIFY;
1914 op->asym->ecdsa.q.x.data = input_params.pubkey_qx.data;
1915 op->asym->ecdsa.q.x.length = input_params.pubkey_qx.length;
1916 op->asym->ecdsa.q.y.data = input_params.pubkey_qy.data;
1917 op->asym->ecdsa.q.y.length = input_params.pubkey_qx.length;
1918 op->asym->ecdsa.r.data = asym_op->ecdsa.r.data;
1919 op->asym->ecdsa.r.length = asym_op->ecdsa.r.length;
1920 op->asym->ecdsa.s.data = asym_op->ecdsa.s.data;
1921 op->asym->ecdsa.s.length = asym_op->ecdsa.s.length;
1922
1923 /* Enqueue sign result for verify */
1924 if (rte_cryptodev_enqueue_burst(dev_id, 0, &op, 1) != 1) {
1925 status = TEST_FAILED;
1926 RTE_LOG(ERR, USER1,
1927 "line %u FAILED: %s", __LINE__,
1928 "Error sending packet for operation\n");
1929 goto exit;
1930 }
1931
1932 while (rte_cryptodev_dequeue_burst(dev_id, 0, &result_op, 1) == 0)
1933 rte_pause();
1934
1935 if (result_op == NULL) {
1936 status = TEST_FAILED;
1937 goto exit;
1938 }
1939 if (result_op->status != RTE_CRYPTO_OP_STATUS_SUCCESS) {
1940 status = TEST_FAILED;
1941 RTE_LOG(ERR, USER1,
1942 "line %u FAILED: %s", __LINE__,
1943 "ECDSA verify failed.\n");
1944 goto exit;
1945 }
1946
1947 exit:
1948 if (sess != NULL)
1949 rte_cryptodev_asym_session_free(dev_id, sess);
1950 if (op != NULL)
1951 rte_crypto_op_free(op);
1952 return status;
1953 };
1954
1955 static int
test_ecdsa_sign_verify_all_curve(void)1956 test_ecdsa_sign_verify_all_curve(void)
1957 {
1958 int status, overall_status = TEST_SUCCESS;
1959 enum curve curve_id;
1960 int test_index = 0;
1961 const char *msg;
1962
1963 for (curve_id = SECP192R1; curve_id < END_OF_CURVE_LIST; curve_id++) {
1964 status = test_ecdsa_sign_verify(curve_id);
1965 if (status == TEST_SUCCESS) {
1966 msg = "succeeded";
1967 } else {
1968 msg = "failed";
1969 overall_status = status;
1970 }
1971 printf(" %u) TestCase Sign/Veriy Curve %s %s\n",
1972 test_index ++, curve[curve_id], msg);
1973 }
1974 return overall_status;
1975 }
1976
1977 static int
test_ecpm(enum curve curve_id)1978 test_ecpm(enum curve curve_id)
1979 {
1980 struct crypto_testsuite_params_asym *ts_params = &testsuite_params;
1981 struct rte_mempool *sess_mpool = ts_params->session_mpool;
1982 struct rte_mempool *op_mpool = ts_params->op_mpool;
1983 struct crypto_testsuite_ecpm_params input_params;
1984 void *sess = NULL;
1985 uint8_t dev_id = ts_params->valid_devs[0];
1986 struct rte_crypto_op *result_op = NULL;
1987 uint8_t output_buf_x[TEST_DATA_SIZE];
1988 uint8_t output_buf_y[TEST_DATA_SIZE];
1989 struct rte_crypto_asym_xform xform;
1990 struct rte_crypto_asym_op *asym_op;
1991 struct rte_cryptodev_info dev_info;
1992 struct rte_crypto_op *op = NULL;
1993 int ret, status = TEST_SUCCESS;
1994
1995 switch (curve_id) {
1996 case SECP192R1:
1997 input_params = ecpm_param_secp192r1;
1998 break;
1999 case SECP224R1:
2000 input_params = ecpm_param_secp224r1;
2001 break;
2002 case SECP256R1:
2003 input_params = ecpm_param_secp256r1;
2004 break;
2005 case SECP384R1:
2006 input_params = ecpm_param_secp384r1;
2007 break;
2008 case SECP521R1:
2009 input_params = ecpm_param_secp521r1;
2010 break;
2011 default:
2012 RTE_LOG(ERR, USER1,
2013 "line %u FAILED: %s", __LINE__,
2014 "Unsupported curve id\n");
2015 status = TEST_FAILED;
2016 goto exit;
2017 }
2018
2019 rte_cryptodev_info_get(dev_id, &dev_info);
2020
2021 /* Setup crypto op data structure */
2022 op = rte_crypto_op_alloc(op_mpool, RTE_CRYPTO_OP_TYPE_ASYMMETRIC);
2023 if (op == NULL) {
2024 RTE_LOG(ERR, USER1,
2025 "line %u FAILED: %s", __LINE__,
2026 "Failed to allocate asymmetric crypto "
2027 "operation struct\n");
2028 status = TEST_FAILED;
2029 goto exit;
2030 }
2031 asym_op = op->asym;
2032
2033 /* Setup asym xform */
2034 xform.next = NULL;
2035 xform.xform_type = RTE_CRYPTO_ASYM_XFORM_ECPM;
2036 xform.ec.curve_id = input_params.curve;
2037
2038 ret = rte_cryptodev_asym_session_create(dev_id, &xform, sess_mpool, &sess);
2039 if (ret < 0) {
2040 RTE_LOG(ERR, USER1,
2041 "line %u FAILED: %s", __LINE__,
2042 "Session creation failed\n");
2043 status = (ret == -ENOTSUP) ? TEST_SKIPPED : TEST_FAILED;
2044 goto exit;
2045 }
2046
2047 /* Attach asymmetric crypto session to crypto operations */
2048 rte_crypto_op_attach_asym_session(op, sess);
2049
2050 /* Populate op with operational details */
2051 op->asym->ecpm.p.x.data = input_params.gen_x.data;
2052 op->asym->ecpm.p.x.length = input_params.gen_x.length;
2053 op->asym->ecpm.p.y.data = input_params.gen_y.data;
2054 op->asym->ecpm.p.y.length = input_params.gen_y.length;
2055 op->asym->ecpm.scalar.data = input_params.privkey.data;
2056 op->asym->ecpm.scalar.length = input_params.privkey.length;
2057
2058 /* Init out buf */
2059 op->asym->ecpm.r.x.data = output_buf_x;
2060 op->asym->ecpm.r.y.data = output_buf_y;
2061
2062 RTE_LOG(DEBUG, USER1, "Process ASYM operation\n");
2063
2064 /* Process crypto operation */
2065 if (rte_cryptodev_enqueue_burst(dev_id, 0, &op, 1) != 1) {
2066 RTE_LOG(ERR, USER1,
2067 "line %u FAILED: %s", __LINE__,
2068 "Error sending packet for operation\n");
2069 status = TEST_FAILED;
2070 goto exit;
2071 }
2072
2073 while (rte_cryptodev_dequeue_burst(dev_id, 0, &result_op, 1) == 0)
2074 rte_pause();
2075
2076 if (result_op == NULL) {
2077 RTE_LOG(ERR, USER1,
2078 "line %u FAILED: %s", __LINE__,
2079 "Failed to process asym crypto op\n");
2080 status = TEST_FAILED;
2081 goto exit;
2082 }
2083
2084 if (result_op->status != RTE_CRYPTO_OP_STATUS_SUCCESS) {
2085 RTE_LOG(ERR, USER1,
2086 "line %u FAILED: %s", __LINE__,
2087 "Failed to process asym crypto op\n");
2088 status = TEST_FAILED;
2089 goto exit;
2090 }
2091
2092 asym_op = result_op->asym;
2093
2094 debug_hexdump(stdout, "r x:",
2095 asym_op->ecpm.r.x.data, asym_op->ecpm.r.x.length);
2096 debug_hexdump(stdout, "r y:",
2097 asym_op->ecpm.r.y.data, asym_op->ecpm.r.y.length);
2098
2099 ret = verify_ecpm(input_params.pubkey_x.data,
2100 input_params.pubkey_y.data, result_op);
2101 if (ret) {
2102 status = TEST_FAILED;
2103 RTE_LOG(ERR, USER1,
2104 "line %u FAILED: %s", __LINE__,
2105 "EC Point Multiplication failed.\n");
2106 goto exit;
2107 }
2108
2109 exit:
2110 if (sess != NULL)
2111 rte_cryptodev_asym_session_free(dev_id, sess);
2112 if (op != NULL)
2113 rte_crypto_op_free(op);
2114 return status;
2115 }
2116
2117 static int
test_ecpm_all_curve(void)2118 test_ecpm_all_curve(void)
2119 {
2120 int status, overall_status = TEST_SUCCESS;
2121 enum curve curve_id;
2122 int test_index = 0;
2123 const char *msg;
2124
2125 for (curve_id = SECP192R1; curve_id < END_OF_CURVE_LIST; curve_id++) {
2126 status = test_ecpm(curve_id);
2127 if (status == TEST_SUCCESS) {
2128 msg = "succeeded";
2129 } else {
2130 msg = "failed";
2131 overall_status = status;
2132 }
2133 printf(" %u) TestCase EC Point Mul Curve %s %s\n",
2134 test_index ++, curve[curve_id], msg);
2135 }
2136 return overall_status;
2137 }
2138
2139 static struct unit_test_suite cryptodev_openssl_asym_testsuite = {
2140 .suite_name = "Crypto Device OPENSSL ASYM Unit Test Suite",
2141 .setup = testsuite_setup,
2142 .teardown = testsuite_teardown,
2143 .unit_test_cases = {
2144 TEST_CASE_ST(ut_setup_asym, ut_teardown_asym, test_capability),
2145 TEST_CASE_ST(ut_setup_asym, ut_teardown_asym, test_dsa),
2146 TEST_CASE_ST(ut_setup_asym, ut_teardown_asym,
2147 test_dh_keygenration),
2148 TEST_CASE_ST(ut_setup_asym, ut_teardown_asym, test_rsa_enc_dec),
2149 TEST_CASE_ST(ut_setup_asym, ut_teardown_asym,
2150 test_rsa_sign_verify),
2151 TEST_CASE_ST(ut_setup_asym, ut_teardown_asym,
2152 test_rsa_enc_dec_crt),
2153 TEST_CASE_ST(ut_setup_asym, ut_teardown_asym,
2154 test_rsa_sign_verify_crt),
2155 TEST_CASE_ST(ut_setup_asym, ut_teardown_asym, test_mod_inv),
2156 TEST_CASE_ST(ut_setup_asym, ut_teardown_asym, test_mod_exp),
2157 TEST_CASE_ST(ut_setup_asym, ut_teardown_asym, test_one_by_one),
2158 TEST_CASES_END() /**< NULL terminate unit test array */
2159 }
2160 };
2161
2162 static struct unit_test_suite cryptodev_qat_asym_testsuite = {
2163 .suite_name = "Crypto Device QAT ASYM Unit Test Suite",
2164 .setup = testsuite_setup,
2165 .teardown = testsuite_teardown,
2166 .unit_test_cases = {
2167 TEST_CASE_ST(ut_setup_asym, ut_teardown_asym, test_one_by_one),
2168 TEST_CASES_END() /**< NULL terminate unit test array */
2169 }
2170 };
2171
2172 static struct unit_test_suite cryptodev_octeontx_asym_testsuite = {
2173 .suite_name = "Crypto Device OCTEONTX ASYM Unit Test Suite",
2174 .setup = testsuite_setup,
2175 .teardown = testsuite_teardown,
2176 .unit_test_cases = {
2177 TEST_CASE_ST(ut_setup_asym, ut_teardown_asym, test_capability),
2178 TEST_CASE_ST(ut_setup_asym, ut_teardown_asym,
2179 test_rsa_enc_dec_crt),
2180 TEST_CASE_ST(ut_setup_asym, ut_teardown_asym,
2181 test_rsa_sign_verify_crt),
2182 TEST_CASE_ST(ut_setup_asym, ut_teardown_asym, test_mod_exp),
2183 TEST_CASE_ST(ut_setup_asym, ut_teardown_asym,
2184 test_ecdsa_sign_verify_all_curve),
2185 TEST_CASE_ST(ut_setup_asym, ut_teardown_asym,
2186 test_ecpm_all_curve),
2187 TEST_CASES_END() /**< NULL terminate unit test array */
2188 }
2189 };
2190
2191 static int
test_cryptodev_openssl_asym(void)2192 test_cryptodev_openssl_asym(void)
2193 {
2194 gbl_driver_id = rte_cryptodev_driver_id_get(
2195 RTE_STR(CRYPTODEV_NAME_OPENSSL_PMD));
2196
2197 if (gbl_driver_id == -1) {
2198 RTE_LOG(ERR, USER1, "OPENSSL PMD must be loaded.\n");
2199 return TEST_FAILED;
2200 }
2201
2202 return unit_test_suite_runner(&cryptodev_openssl_asym_testsuite);
2203 }
2204
2205 static int
test_cryptodev_qat_asym(void)2206 test_cryptodev_qat_asym(void)
2207 {
2208 gbl_driver_id = rte_cryptodev_driver_id_get(
2209 RTE_STR(CRYPTODEV_NAME_QAT_ASYM_PMD));
2210
2211 if (gbl_driver_id == -1) {
2212 RTE_LOG(ERR, USER1, "QAT PMD must be loaded.\n");
2213 return TEST_FAILED;
2214 }
2215
2216 return unit_test_suite_runner(&cryptodev_qat_asym_testsuite);
2217 }
2218
2219 static int
test_cryptodev_octeontx_asym(void)2220 test_cryptodev_octeontx_asym(void)
2221 {
2222 gbl_driver_id = rte_cryptodev_driver_id_get(
2223 RTE_STR(CRYPTODEV_NAME_OCTEONTX_SYM_PMD));
2224 if (gbl_driver_id == -1) {
2225 RTE_LOG(ERR, USER1, "OCTEONTX PMD must be loaded.\n");
2226 return TEST_FAILED;
2227 }
2228 return unit_test_suite_runner(&cryptodev_octeontx_asym_testsuite);
2229 }
2230
2231 static int
test_cryptodev_cn9k_asym(void)2232 test_cryptodev_cn9k_asym(void)
2233 {
2234 gbl_driver_id = rte_cryptodev_driver_id_get(
2235 RTE_STR(CRYPTODEV_NAME_CN9K_PMD));
2236 if (gbl_driver_id == -1) {
2237 RTE_LOG(ERR, USER1, "CN9K PMD must be loaded.\n");
2238 return TEST_FAILED;
2239 }
2240
2241 /* Use test suite registered for crypto_octeontx PMD */
2242 return unit_test_suite_runner(&cryptodev_octeontx_asym_testsuite);
2243 }
2244
2245 static int
test_cryptodev_cn10k_asym(void)2246 test_cryptodev_cn10k_asym(void)
2247 {
2248 gbl_driver_id = rte_cryptodev_driver_id_get(
2249 RTE_STR(CRYPTODEV_NAME_CN10K_PMD));
2250 if (gbl_driver_id == -1) {
2251 RTE_LOG(ERR, USER1, "CN10K PMD must be loaded.\n");
2252 return TEST_FAILED;
2253 }
2254
2255 /* Use test suite registered for crypto_octeontx PMD */
2256 return unit_test_suite_runner(&cryptodev_octeontx_asym_testsuite);
2257 }
2258
2259 REGISTER_TEST_COMMAND(cryptodev_openssl_asym_autotest,
2260 test_cryptodev_openssl_asym);
2261
2262 REGISTER_TEST_COMMAND(cryptodev_qat_asym_autotest, test_cryptodev_qat_asym);
2263
2264 REGISTER_TEST_COMMAND(cryptodev_octeontx_asym_autotest,
2265 test_cryptodev_octeontx_asym);
2266 REGISTER_TEST_COMMAND(cryptodev_cn9k_asym_autotest, test_cryptodev_cn9k_asym);
2267 REGISTER_TEST_COMMAND(cryptodev_cn10k_asym_autotest, test_cryptodev_cn10k_asym);
2268
2269 #endif /* !RTE_EXEC_ENV_WINDOWS */
2270