1 /*
2 * This file and its contents are supplied under the terms of the
3 * Common Development and Distribution License ("CDDL"), version 1.0.
4 * You may only use this file in accordance with the terms of version
5 * 1.0 of the CDDL.
6 *
7 * A full copy of the text of the CDDL should have accompanied this
8 * source. A copy of the CDDL is also available via the Internet at
9 * http://www.illumos.org/license/CDDL.
10 */
11
12 /*
13 * Copyright 2015 Nexenta Systems, Inc. All rights reserved.
14 * Copyright 2018, Joyent, Inc.
15 */
16
17 #ifndef _CRYPTOTEST_H
18 #define _CRYPTOTEST_H
19
20 #ifdef __cplusplus
21 extern "C" {
22 #endif
23
24 #include <sys/crypto/ioctl.h>
25
26 #define CTEST_INIT_FAILED (-1)
27 #define CTEST_NAME_RESOLVE_FAILED (-2)
28 #define CTEST_MECH_NO_PROVIDER (-3)
29
30 typedef struct cryptotest {
31 uint8_t *in;
32 uint8_t *out;
33 uint8_t *key;
34 void *param;
35
36 size_t inlen;
37 size_t outlen;
38 size_t keylen;
39 size_t plen;
40
41 char *mechname;
42 size_t updatelen;
43 } cryptotest_t;
44
45 typedef int (*testfunc_t)(cryptotest_t *);
46
47 typedef struct test_fg {
48 testfunc_t single;
49 testfunc_t update;
50 } test_fg_t;
51
52 #define CRYPTO_INVALID_SESSION ((size_t)-1)
53 typedef struct crypto_op crypto_op_t;
54
55 int run_test(cryptotest_t *args, uint8_t *cmp, size_t cmplen, test_fg_t *funcs);
56
57 /* utils */
58 crypto_op_t *cryptotest_init(cryptotest_t *args, crypto_func_group_t fg);
59 int cryptotest_close(crypto_op_t *op);
60 int get_mech_info(crypto_op_t *op);
61 int get_hsession_by_mech(crypto_op_t *op);
62
63 /* CRYPTO_MAC */
64 int mac_init(crypto_op_t *op);
65 int mac_single(crypto_op_t *op);
66 int mac_update(crypto_op_t *op, int offset);
67 int mac_final(crypto_op_t *op);
68
69 /* CRYPTO_ENCRYPT */
70 int encrypt_init(crypto_op_t *op);
71 int encrypt_single(crypto_op_t *op);
72 int encrypt_update(crypto_op_t *op, int offset, size_t *encrlen);
73 int encrypt_final(crypto_op_t *op, size_t encrlen);
74
75 /* CRYPTO_DECRYPT */
76 int decrypt_init(crypto_op_t *op);
77 int decrypt_single(crypto_op_t *op);
78 int decrypt_update(crypto_op_t *op, int offset, size_t *encrlen);
79 int decrypt_final(crypto_op_t *op, size_t encrlen);
80
81 /* CRYPTO_DIGEST */
82 int digest_init(crypto_op_t *op);
83 int digest_single(crypto_op_t *op);
84 int digest_update(crypto_op_t *op, int);
85 int digest_final(crypto_op_t *op);
86
87 /* wrappers */
88 int test_mac_single(cryptotest_t *args);
89 int test_mac(cryptotest_t *args);
90
91 int test_encrypt_single(cryptotest_t *args);
92 int test_encrypt(cryptotest_t *args);
93
94 int test_decrypt_single(cryptotest_t *args);
95 int test_decrypt(cryptotest_t *args);
96
97 int test_digest_single(cryptotest_t *args);
98 int test_digest(cryptotest_t *args);
99
100 extern test_fg_t cryptotest_decr_fg;
101 extern test_fg_t cryptotest_encr_fg;
102 extern test_fg_t cryptotest_mac_fg;
103 extern test_fg_t cryptotest_digest_fg;
104
105 #define MAC_FG (&cryptotest_mac_fg)
106 #define ENCR_FG (&cryptotest_encr_fg)
107 #define DECR_FG (&cryptotest_decr_fg)
108 #define DIGEST_FG (&cryptotest_digest_fg)
109
110 #ifdef __cplusplus
111 }
112 #endif
113
114 #endif /* _CRYPTOTEST_H */