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