summaryrefslogtreecommitdiffstats
path: root/src/spdk/dpdk/app/test/test_cryptodev_asym_util.h
blob: 83dc265dd75bb15866dc6b86dfc55b63de767bcf (plain)
1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
23
24
25
26
27
28
29
30
31
32
33
34
35
36
37
38
39
40
41
42
43
44
45
46
47
48
49
50
51
52
53
54
55
56
57
58
59
60
/* SPDX-License-Identifier: BSD-3-Clause
 * Copyright(c) 2018 Cavium Networks
 */

#ifndef TEST_CRYPTODEV_ASYM_TEST_UTIL_H__
#define TEST_CRYPTODEV_ASYM_TEST_UTIL_H__

/* Below Apis compare resulted buffer to original test vector */

static inline int rsa_verify(struct rsa_test_data *rsa_param,
		struct rte_crypto_op *result_op)
{
	if (memcmp(rsa_param->data,
				result_op->asym->rsa.message.data,
				result_op->asym->rsa.message.length))
		return -1;
	return 0;
}

static inline int verify_modinv(uint8_t *mod_inv,
		struct rte_crypto_op *result_op)
{
	if (memcmp(mod_inv, result_op->asym->modinv.result.data,
				result_op->asym->modinv.result.length))
		return -1;
	return 0;
}

static inline int verify_modexp(uint8_t *mod_exp,
		struct rte_crypto_op *result_op)
{
	if (memcmp(mod_exp, result_op->asym->modex.result.data,
				result_op->asym->modex.result.length))
		return -1;
	return 0;
}

static inline int verify_ecdsa_sign(uint8_t *sign_r,
		uint8_t *sign_s, struct rte_crypto_op *result_op)
{
	if (memcmp(sign_r, result_op->asym->ecdsa.r.data,
		   result_op->asym->ecdsa.r.length) ||
		   memcmp(sign_s, result_op->asym->ecdsa.s.data,
		   result_op->asym->ecdsa.s.length))
		return -1;
	return 0;
}

static inline int verify_ecpm(uint8_t *result_x, uint8_t *result_y,
			      struct rte_crypto_op *result_op)
{
	if (memcmp(result_x, result_op->asym->ecpm.r.x.data,
		   result_op->asym->ecpm.r.x.length) ||
		   memcmp(result_y, result_op->asym->ecpm.r.y.data,
		   result_op->asym->ecpm.r.y.length))
		return -1;

	return 0;
}
#endif /* TEST_CRYPTODEV_ASYM_TEST_UTIL_H__ */