1/* $NetBSD: evp-pkcs11.h,v 1.3 2023/06/19 21:41:43 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_md4() hc_EVP_pkcs11_md4() 41#define EVP_pkcs11_md5() hc_EVP_pkcs11_md5() 42#define EVP_pkcs11_sha1() hc_EVP_pkcs11_sha1() 43#define EVP_pkcs11_sha256() hc_EVP_pkcs11_sha256() 44#define EVP_pkcs11_sha384() hc_EVP_pkcs11_sha384() 45#define EVP_pkcs11_sha512() hc_EVP_pkcs11_sha512() 46#define EVP_pkcs11_des_cbc() hc_EVP_pkcs11_des_cbc() 47#define EVP_pkcs11_des_ede3_cbc() hc_EVP_pkcs11_des_ede3_cbc() 48#define EVP_pkcs11_aes_128_cbc() hc_EVP_pkcs11_aes_128_cbc() 49#define EVP_pkcs11_aes_192_cbc() hc_EVP_pkcs11_aes_192_cbc() 50#define EVP_pkcs11_aes_256_cbc() hc_EVP_pkcs11_aes_256_cbc() 51#define EVP_pkcs11_aes_128_cfb8() hc_EVP_pkcs11_aes_128_cfb8() 52#define EVP_pkcs11_aes_192_cfb8() hc_EVP_pkcs11_aes_192_cfb8() 53#define EVP_pkcs11_aes_256_cfb8() hc_EVP_pkcs11_aes_256_cfb8() 54#define EVP_pkcs11_rc4() hc_EVP_pkcs11_rc4() 55#define EVP_pkcs11_rc4_40() hc_EVP_pkcs11_rc4_40() 56#define EVP_pkcs11_rc2_40_cbc() hc_EVP_pkcs11_rc2_40_cbc() 57#define EVP_pkcs11_rc2_64_cbc() hc_EVP_pkcs11_rc2_64_cbc() 58#define EVP_pkcs11_rc2_cbc() hc_EVP_pkcs11_rc2_cbc() 59#define EVP_pkcs11_camellia_128_cbc() hc_EVP_pkcs11_camellia_128_cbc() 60#define EVP_pkcs11_camellia_192_cbc() hc_EVP_pkcs11_camellia_192_cbc() 61#define EVP_pkcs11_camellia_256_cbc() hc_EVP_pkcs11_camellia_256_cbc() 62 63#define EVP_pkcs11_hcrypto_md4() hc_EVP_pkcs11_hcrypto_md4() 64#define EVP_pkcs11_hcrypto_md5() hc_EVP_pkcs11_hcrypto_md5() 65#define EVP_pkcs11_hcrypto_sha1() hc_EVP_pkcs11_hcrypto_sha1() 66#define EVP_pkcs11_hcrypto_sha256() hc_EVP_pkcs11_hcrypto_sha256() 67#define EVP_pkcs11_hcrypto_sha384() hc_EVP_pkcs11_hcrypto_sha384() 68#define EVP_pkcs11_hcrypto_sha512() hc_EVP_pkcs11_hcrypto_sha512() 69#define EVP_pkcs11_hcrypto_des_cbc() hc_EVP_pkcs11_hcrypto_des_cbc() 70#define EVP_pkcs11_hcrypto_des_ede3_cbc() hc_EVP_pkcs11_hcrypto_des_ede3_cbc() 71#define EVP_pkcs11_hcrypto_aes_128_cbc() hc_EVP_pkcs11_hcrypto_aes_128_cbc() 72#define EVP_pkcs11_hcrypto_aes_192_cbc() hc_EVP_pkcs11_hcrypto_aes_192_cbc() 73#define EVP_pkcs11_hcrypto_aes_256_cbc() hc_EVP_pkcs11_hcrypto_aes_256_cbc() 74#define EVP_pkcs11_hcrypto_aes_128_cfb8() hc_EVP_pkcs11_hcrypto_aes_128_cfb8() 75#define EVP_pkcs11_hcrypto_aes_192_cfb8() hc_EVP_pkcs11_hcrypto_aes_192_cfb8() 76#define EVP_pkcs11_hcrypto_aes_256_cfb8() hc_EVP_pkcs11_hcrypto_aes_256_cfb8() 77#define EVP_pkcs11_hcrypto_rc4() hc_EVP_pkcs11_hcrypto_rc4() 78#define EVP_pkcs11_hcrypto_rc4_40() hc_EVP_pkcs11_hcrypto_rc4_40() 79#define EVP_pkcs11_hcrypto_rc2_40_cbc() hc_EVP_pkcs11_hcrypto_rc2_40_cbc() 80#define EVP_pkcs11_hcrypto_rc2_64_cbc() hc_EVP_pkcs11_hcrypto_rc2_64_cbc() 81#define EVP_pkcs11_hcrypto_rc2_cbc() hc_EVP_pkcs11_hcrypto_rc2_cbc() 82#define EVP_pkcs11_hcrypto_camellia_128_cbc() hc_EVP_pkcs11_hcrypto_camellia_128_cbc() 83#define EVP_pkcs11_hcrypto_camellia_192_cbc() hc_EVP_pkcs11_hcrypto_camellia_192_cbc() 84#define EVP_pkcs11_hcrypto_camellia_256_cbc() hc_EVP_pkcs11_hcrypto_camellia_256_cbc() 85 86HC_CPP_BEGIN 87 88/* 89 * Strict PKCS#11 implementations (these will return NULL if the underlying 90 * PKCS#11 implementation does not implement the cipher or hash). 91 */ 92const EVP_MD * hc_EVP_pkcs11_md4(void); 93const EVP_MD * hc_EVP_pkcs11_md5(void); 94const EVP_MD * hc_EVP_pkcs11_sha1(void); 95const EVP_MD * hc_EVP_pkcs11_sha256(void); 96const EVP_MD * hc_EVP_pkcs11_sha384(void); 97const EVP_MD * hc_EVP_pkcs11_sha512(void); 98 99const EVP_CIPHER * hc_EVP_pkcs11_rc2_cbc(void); 100const EVP_CIPHER * hc_EVP_pkcs11_rc2_40_cbc(void); 101const EVP_CIPHER * hc_EVP_pkcs11_rc2_64_cbc(void); 102 103const EVP_CIPHER * hc_EVP_pkcs11_rc4(void); 104const EVP_CIPHER * hc_EVP_pkcs11_rc4_40(void); 105 106const EVP_CIPHER * hc_EVP_pkcs11_des_cbc(void); 107const EVP_CIPHER * hc_EVP_pkcs11_des_ede3_cbc(void); 108 109const EVP_CIPHER * hc_EVP_pkcs11_aes_128_cbc(void); 110const EVP_CIPHER * hc_EVP_pkcs11_aes_192_cbc(void); 111const EVP_CIPHER * hc_EVP_pkcs11_aes_256_cbc(void); 112 113const EVP_CIPHER * hc_EVP_pkcs11_aes_128_cfb8(void); 114const EVP_CIPHER * hc_EVP_pkcs11_aes_192_cfb8(void); 115const EVP_CIPHER * hc_EVP_pkcs11_aes_256_cfb8(void); 116 117const EVP_CIPHER * hc_EVP_pkcs11_camellia_128_cbc(void); 118const EVP_CIPHER * hc_EVP_pkcs11_camellia_192_cbc(void); 119const EVP_CIPHER * hc_EVP_pkcs11_camellia_256_cbc(void); 120 121/* 122 * PKCS#11 implementations with fallback to hcrypto. 123 */ 124const EVP_MD * hc_EVP_pkcs11_hcrypto_md4(void); 125const EVP_MD * hc_EVP_pkcs11_hcrypto_md5(void); 126const EVP_MD * hc_EVP_pkcs11_hcrypto_sha1(void); 127const EVP_MD * hc_EVP_pkcs11_hcrypto_sha256(void); 128const EVP_MD * hc_EVP_pkcs11_hcrypto_sha384(void); 129const EVP_MD * hc_EVP_pkcs11_hcrypto_sha512(void); 130 131const EVP_CIPHER * hc_EVP_pkcs11_hcrypto_rc2_cbc(void); 132const EVP_CIPHER * hc_EVP_pkcs11_hcrypto_rc2_40_cbc(void); 133const EVP_CIPHER * hc_EVP_pkcs11_hcrypto_rc2_64_cbc(void); 134 135const EVP_CIPHER * hc_EVP_pkcs11_hcrypto_rc4(void); 136const EVP_CIPHER * hc_EVP_pkcs11_hcrypto_rc4_40(void); 137 138const EVP_CIPHER * hc_EVP_pkcs11_hcrypto_des_cbc(void); 139const EVP_CIPHER * hc_EVP_pkcs11_hcrypto_des_ede3_cbc(void); 140 141const EVP_CIPHER * hc_EVP_pkcs11_hcrypto_aes_128_cbc(void); 142const EVP_CIPHER * hc_EVP_pkcs11_hcrypto_aes_192_cbc(void); 143const EVP_CIPHER * hc_EVP_pkcs11_hcrypto_aes_256_cbc(void); 144 145const EVP_CIPHER * hc_EVP_pkcs11_hcrypto_aes_128_cfb8(void); 146const EVP_CIPHER * hc_EVP_pkcs11_hcrypto_aes_192_cfb8(void); 147const EVP_CIPHER * hc_EVP_pkcs11_hcrypto_aes_256_cfb8(void); 148 149const EVP_CIPHER * hc_EVP_pkcs11_hcrypto_camellia_128_cbc(void); 150const EVP_CIPHER * hc_EVP_pkcs11_hcrypto_camellia_192_cbc(void); 151const EVP_CIPHER * hc_EVP_pkcs11_hcrypto_camellia_256_cbc(void); 152 153HC_CPP_END 154 155#endif /* HEIM_EVP_PKCS11_H */ 156