xref: /netbsd-src/crypto/external/bsd/heimdal/dist/lib/hcrypto/evp-pkcs11.h (revision d90047b5d07facf36e6c01dcc0bded8997ce9cc2)
1 /*	$NetBSD: evp-pkcs11.h,v 1.2 2017/01/28 21:31:47 christos Exp $	*/
2 
3 /*
4  * Copyright (c) 2015, Secure Endpoints Inc.
5  * All rights reserved.
6  *
7  * Redistribution and use in source and binary forms, with or without
8  * modification, are permitted provided that the following conditions
9  * are met:
10  *
11  * - Redistributions of source code must retain the above copyright
12  *   notice, this list of conditions and the following disclaimer.
13  *
14  * - Redistributions in binary form must reproduce the above copyright
15  *   notice, this list of conditions and the following disclaimer in
16  *   the documentation and/or other materials provided with the
17  *   distribution.
18  *
19  * THIS SOFTWARE IS PROVIDED BY THE COPYRIGHT HOLDERS AND CONTRIBUTORS
20  * "AS IS" AND ANY EXPRESS OR IMPLIED WARRANTIES, INCLUDING, BUT NOT
21  * LIMITED TO, THE IMPLIED WARRANTIES OF MERCHANTABILITY AND FITNESS
22  * FOR A PARTICULAR PURPOSE ARE DISCLAIMED. IN NO EVENT SHALL THE
23  * COPYRIGHT HOLDER OR CONTRIBUTORS BE LIABLE FOR ANY DIRECT,
24  * INDIRECT, INCIDENTAL, SPECIAL, EXEMPLARY, OR CONSEQUENTIAL DAMAGES
25  * (INCLUDING, BUT NOT LIMITED TO, PROCUREMENT OF SUBSTITUTE GOODS OR
26  * SERVICES; LOSS OF USE, DATA, OR PROFITS; OR BUSINESS INTERRUPTION)
27  * HOWEVER CAUSED AND ON ANY THEORY OF LIABILITY, WHETHER IN CONTRACT,
28  * STRICT LIABILITY, OR TORT (INCLUDING NEGLIGENCE OR OTHERWISE)
29  * ARISING IN ANY WAY OUT OF THE USE OF THIS SOFTWARE, EVEN IF ADVISED
30  * OF THE POSSIBILITY OF SUCH DAMAGE.
31  */
32 
33 /* Id */
34 
35 #ifndef HEIM_EVP_PKCS11_H
36 #define HEIM_EVP_PKCS11_H 1
37 
38 /* symbol renaming */
39 
40 #define EVP_pkcs11_md2() hc_EVP_pkcs11_md2()
41 #define EVP_pkcs11_md4() hc_EVP_pkcs11_md4()
42 #define EVP_pkcs11_md5() hc_EVP_pkcs11_md5()
43 #define EVP_pkcs11_sha1() hc_EVP_pkcs11_sha1()
44 #define EVP_pkcs11_sha256() hc_EVP_pkcs11_sha256()
45 #define EVP_pkcs11_sha384() hc_EVP_pkcs11_sha384()
46 #define EVP_pkcs11_sha512() hc_EVP_pkcs11_sha512()
47 #define EVP_pkcs11_des_cbc() hc_EVP_pkcs11_des_cbc()
48 #define EVP_pkcs11_des_ede3_cbc() hc_EVP_pkcs11_des_ede3_cbc()
49 #define EVP_pkcs11_aes_128_cbc() hc_EVP_pkcs11_aes_128_cbc()
50 #define EVP_pkcs11_aes_192_cbc() hc_EVP_pkcs11_aes_192_cbc()
51 #define EVP_pkcs11_aes_256_cbc() hc_EVP_pkcs11_aes_256_cbc()
52 #define EVP_pkcs11_aes_128_cfb8() hc_EVP_pkcs11_aes_128_cfb8()
53 #define EVP_pkcs11_aes_192_cfb8() hc_EVP_pkcs11_aes_192_cfb8()
54 #define EVP_pkcs11_aes_256_cfb8() hc_EVP_pkcs11_aes_256_cfb8()
55 #define EVP_pkcs11_rc4() hc_EVP_pkcs11_rc4()
56 #define EVP_pkcs11_rc4_40() hc_EVP_pkcs11_rc4_40()
57 #define EVP_pkcs11_rc2_40_cbc() hc_EVP_pkcs11_rc2_40_cbc()
58 #define EVP_pkcs11_rc2_64_cbc() hc_EVP_pkcs11_rc2_64_cbc()
59 #define EVP_pkcs11_rc2_cbc() hc_EVP_pkcs11_rc2_cbc()
60 #define EVP_pkcs11_camellia_128_cbc() hc_EVP_pkcs11_camellia_128_cbc()
61 #define EVP_pkcs11_camellia_192_cbc() hc_EVP_pkcs11_camellia_192_cbc()
62 #define EVP_pkcs11_camellia_256_cbc() hc_EVP_pkcs11_camellia_256_cbc()
63 
64 #define EVP_pkcs11_hcrypto_md2() hc_EVP_pkcs11_hcrypto_md2()
65 #define EVP_pkcs11_hcrypto_md4() hc_EVP_pkcs11_hcrypto_md4()
66 #define EVP_pkcs11_hcrypto_md5() hc_EVP_pkcs11_hcrypto_md5()
67 #define EVP_pkcs11_hcrypto_sha1() hc_EVP_pkcs11_hcrypto_sha1()
68 #define EVP_pkcs11_hcrypto_sha256() hc_EVP_pkcs11_hcrypto_sha256()
69 #define EVP_pkcs11_hcrypto_sha384() hc_EVP_pkcs11_hcrypto_sha384()
70 #define EVP_pkcs11_hcrypto_sha512() hc_EVP_pkcs11_hcrypto_sha512()
71 #define EVP_pkcs11_hcrypto_des_cbc() hc_EVP_pkcs11_hcrypto_des_cbc()
72 #define EVP_pkcs11_hcrypto_des_ede3_cbc() hc_EVP_pkcs11_hcrypto_des_ede3_cbc()
73 #define EVP_pkcs11_hcrypto_aes_128_cbc() hc_EVP_pkcs11_hcrypto_aes_128_cbc()
74 #define EVP_pkcs11_hcrypto_aes_192_cbc() hc_EVP_pkcs11_hcrypto_aes_192_cbc()
75 #define EVP_pkcs11_hcrypto_aes_256_cbc() hc_EVP_pkcs11_hcrypto_aes_256_cbc()
76 #define EVP_pkcs11_hcrypto_aes_128_cfb8() hc_EVP_pkcs11_hcrypto_aes_128_cfb8()
77 #define EVP_pkcs11_hcrypto_aes_192_cfb8() hc_EVP_pkcs11_hcrypto_aes_192_cfb8()
78 #define EVP_pkcs11_hcrypto_aes_256_cfb8() hc_EVP_pkcs11_hcrypto_aes_256_cfb8()
79 #define EVP_pkcs11_hcrypto_rc4() hc_EVP_pkcs11_hcrypto_rc4()
80 #define EVP_pkcs11_hcrypto_rc4_40() hc_EVP_pkcs11_hcrypto_rc4_40()
81 #define EVP_pkcs11_hcrypto_rc2_40_cbc() hc_EVP_pkcs11_hcrypto_rc2_40_cbc()
82 #define EVP_pkcs11_hcrypto_rc2_64_cbc() hc_EVP_pkcs11_hcrypto_rc2_64_cbc()
83 #define EVP_pkcs11_hcrypto_rc2_cbc() hc_EVP_pkcs11_hcrypto_rc2_cbc()
84 #define EVP_pkcs11_hcrypto_camellia_128_cbc() hc_EVP_pkcs11_hcrypto_camellia_128_cbc()
85 #define EVP_pkcs11_hcrypto_camellia_192_cbc() hc_EVP_pkcs11_hcrypto_camellia_192_cbc()
86 #define EVP_pkcs11_hcrypto_camellia_256_cbc() hc_EVP_pkcs11_hcrypto_camellia_256_cbc()
87 
88 HC_CPP_BEGIN
89 
90 /*
91  * Strict PKCS#11 implementations (these will return NULL if the underlying
92  * PKCS#11 implementation does not implement the cipher or hash).
93  */
94 const EVP_MD * hc_EVP_pkcs11_md2(void);
95 const EVP_MD * hc_EVP_pkcs11_md4(void);
96 const EVP_MD * hc_EVP_pkcs11_md5(void);
97 const EVP_MD * hc_EVP_pkcs11_sha1(void);
98 const EVP_MD * hc_EVP_pkcs11_sha256(void);
99 const EVP_MD * hc_EVP_pkcs11_sha384(void);
100 const EVP_MD * hc_EVP_pkcs11_sha512(void);
101 
102 const EVP_CIPHER * hc_EVP_pkcs11_rc2_cbc(void);
103 const EVP_CIPHER * hc_EVP_pkcs11_rc2_40_cbc(void);
104 const EVP_CIPHER * hc_EVP_pkcs11_rc2_64_cbc(void);
105 
106 const EVP_CIPHER * hc_EVP_pkcs11_rc4(void);
107 const EVP_CIPHER * hc_EVP_pkcs11_rc4_40(void);
108 
109 const EVP_CIPHER * hc_EVP_pkcs11_des_cbc(void);
110 const EVP_CIPHER * hc_EVP_pkcs11_des_ede3_cbc(void);
111 
112 const EVP_CIPHER * hc_EVP_pkcs11_aes_128_cbc(void);
113 const EVP_CIPHER * hc_EVP_pkcs11_aes_192_cbc(void);
114 const EVP_CIPHER * hc_EVP_pkcs11_aes_256_cbc(void);
115 
116 const EVP_CIPHER * hc_EVP_pkcs11_aes_128_cfb8(void);
117 const EVP_CIPHER * hc_EVP_pkcs11_aes_192_cfb8(void);
118 const EVP_CIPHER * hc_EVP_pkcs11_aes_256_cfb8(void);
119 
120 const EVP_CIPHER * hc_EVP_pkcs11_camellia_128_cbc(void);
121 const EVP_CIPHER * hc_EVP_pkcs11_camellia_192_cbc(void);
122 const EVP_CIPHER * hc_EVP_pkcs11_camellia_256_cbc(void);
123 
124 /*
125  * PKCS#11 implementations with fallback to hcrypto.
126  */
127 const EVP_MD * hc_EVP_pkcs11_hcrypto_md2(void);
128 const EVP_MD * hc_EVP_pkcs11_hcrypto_md4(void);
129 const EVP_MD * hc_EVP_pkcs11_hcrypto_md5(void);
130 const EVP_MD * hc_EVP_pkcs11_hcrypto_sha1(void);
131 const EVP_MD * hc_EVP_pkcs11_hcrypto_sha256(void);
132 const EVP_MD * hc_EVP_pkcs11_hcrypto_sha384(void);
133 const EVP_MD * hc_EVP_pkcs11_hcrypto_sha512(void);
134 
135 const EVP_CIPHER * hc_EVP_pkcs11_hcrypto_rc2_cbc(void);
136 const EVP_CIPHER * hc_EVP_pkcs11_hcrypto_rc2_40_cbc(void);
137 const EVP_CIPHER * hc_EVP_pkcs11_hcrypto_rc2_64_cbc(void);
138 
139 const EVP_CIPHER * hc_EVP_pkcs11_hcrypto_rc4(void);
140 const EVP_CIPHER * hc_EVP_pkcs11_hcrypto_rc4_40(void);
141 
142 const EVP_CIPHER * hc_EVP_pkcs11_hcrypto_des_cbc(void);
143 const EVP_CIPHER * hc_EVP_pkcs11_hcrypto_des_ede3_cbc(void);
144 
145 const EVP_CIPHER * hc_EVP_pkcs11_hcrypto_aes_128_cbc(void);
146 const EVP_CIPHER * hc_EVP_pkcs11_hcrypto_aes_192_cbc(void);
147 const EVP_CIPHER * hc_EVP_pkcs11_hcrypto_aes_256_cbc(void);
148 
149 const EVP_CIPHER * hc_EVP_pkcs11_hcrypto_aes_128_cfb8(void);
150 const EVP_CIPHER * hc_EVP_pkcs11_hcrypto_aes_192_cfb8(void);
151 const EVP_CIPHER * hc_EVP_pkcs11_hcrypto_aes_256_cfb8(void);
152 
153 const EVP_CIPHER * hc_EVP_pkcs11_hcrypto_camellia_128_cbc(void);
154 const EVP_CIPHER * hc_EVP_pkcs11_hcrypto_camellia_192_cbc(void);
155 const EVP_CIPHER * hc_EVP_pkcs11_hcrypto_camellia_256_cbc(void);
156 
157 HC_CPP_END
158 
159 #endif /* HEIM_EVP_PKCS11_H */
160