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