1/* ==================================================================== 2 * Copyright (c) 1999 The OpenSSL Project. All rights reserved. 3 * 4 * Redistribution and use in source and binary forms, with or without 5 * modification, are permitted provided that the following conditions 6 * are met: 7 * 8 * 1. Redistributions of source code must retain the above copyright 9 * notice, this list of conditions and the following disclaimer. 10 * 11 * 2. Redistributions in binary form must reproduce the above copyright 12 * notice, this list of conditions and the following disclaimer in 13 * the documentation and/or other materials provided with the 14 * distribution. 15 * 16 * 3. All advertising materials mentioning features or use of this 17 * software must display the following acknowledgment: 18 * "This product includes software developed by the OpenSSL Project 19 * for use in the OpenSSL Toolkit. (http://www.openssl.org/)" 20 * 21 * 4. The names "OpenSSL Toolkit" and "OpenSSL Project" must not be used to 22 * endorse or promote products derived from this software without 23 * prior written permission. For written permission, please contact 24 * openssl-core@openssl.org. 25 * 26 * 5. Products derived from this software may not be called "OpenSSL" 27 * nor may "OpenSSL" appear in their names without prior written 28 * permission of the OpenSSL Project. 29 * 30 * 6. Redistributions of any form whatsoever must retain the following 31 * acknowledgment: 32 * "This product includes software developed by the OpenSSL Project 33 * for use in the OpenSSL Toolkit (http://www.openssl.org/)" 34 * 35 * THIS SOFTWARE IS PROVIDED BY THE OpenSSL PROJECT ``AS IS'' AND ANY 36 * EXPRESSED OR IMPLIED WARRANTIES, INCLUDING, BUT NOT LIMITED TO, THE 37 * IMPLIED WARRANTIES OF MERCHANTABILITY AND FITNESS FOR A PARTICULAR 38 * PURPOSE ARE DISCLAIMED. IN NO EVENT SHALL THE OpenSSL PROJECT OR 39 * ITS CONTRIBUTORS BE LIABLE FOR ANY DIRECT, INDIRECT, INCIDENTAL, 40 * SPECIAL, EXEMPLARY, OR CONSEQUENTIAL DAMAGES (INCLUDING, BUT 41 * NOT LIMITED TO, PROCUREMENT OF SUBSTITUTE GOODS OR SERVICES; 42 * LOSS OF USE, DATA, OR PROFITS; OR BUSINESS INTERRUPTION) 43 * HOWEVER CAUSED AND ON ANY THEORY OF LIABILITY, WHETHER IN CONTRACT, 44 * STRICT LIABILITY, OR TORT (INCLUDING NEGLIGENCE OR OTHERWISE) 45 * ARISING IN ANY WAY OUT OF THE USE OF THIS SOFTWARE, EVEN IF ADVISED 46 * OF THE POSSIBILITY OF SUCH DAMAGE. 47 * ==================================================================== 48 * 49 * This product includes cryptographic software written by Eric Young 50 * (eay@cryptsoft.com). This product includes software written by Tim 51 * Hudson (tjh@cryptsoft.com). 52 * 53 */ 54 55#ifndef HEADER_SYMHACKS_H 56#define HEADER_SYMHACKS_H 57 58#include <openssl/e_os2.h> 59 60/* Hacks to solve the problem with linkers incapable of handling very long 61 symbol names. In the case of VMS, the limit is 31 characters on VMS for 62 VAX. */ 63#ifdef OPENSSL_SYS_VMS 64 65/* Hack a long name in crypto/ex_data.c */ 66#undef CRYPTO_get_ex_data_implementation 67#define CRYPTO_get_ex_data_implementation CRYPTO_get_ex_data_impl 68#undef CRYPTO_set_ex_data_implementation 69#define CRYPTO_set_ex_data_implementation CRYPTO_set_ex_data_impl 70 71/* Hack a long name in crypto/asn1/a_mbstr.c */ 72#undef ASN1_STRING_set_default_mask_asc 73#define ASN1_STRING_set_default_mask_asc ASN1_STRING_set_def_mask_asc 74 75#if 0 /* No longer needed, since safestack macro magic does the job */ 76/* Hack the names created with DECLARE_ASN1_SET_OF(PKCS7_SIGNER_INFO) */ 77#undef i2d_ASN1_SET_OF_PKCS7_SIGNER_INFO 78#define i2d_ASN1_SET_OF_PKCS7_SIGNER_INFO i2d_ASN1_SET_OF_PKCS7_SIGINF 79#undef d2i_ASN1_SET_OF_PKCS7_SIGNER_INFO 80#define d2i_ASN1_SET_OF_PKCS7_SIGNER_INFO d2i_ASN1_SET_OF_PKCS7_SIGINF 81#endif 82 83#if 0 /* No longer needed, since safestack macro magic does the job */ 84/* Hack the names created with DECLARE_ASN1_SET_OF(PKCS7_RECIP_INFO) */ 85#undef i2d_ASN1_SET_OF_PKCS7_RECIP_INFO 86#define i2d_ASN1_SET_OF_PKCS7_RECIP_INFO i2d_ASN1_SET_OF_PKCS7_RECINF 87#undef d2i_ASN1_SET_OF_PKCS7_RECIP_INFO 88#define d2i_ASN1_SET_OF_PKCS7_RECIP_INFO d2i_ASN1_SET_OF_PKCS7_RECINF 89#endif 90 91#if 0 /* No longer needed, since safestack macro magic does the job */ 92/* Hack the names created with DECLARE_ASN1_SET_OF(ACCESS_DESCRIPTION) */ 93#undef i2d_ASN1_SET_OF_ACCESS_DESCRIPTION 94#define i2d_ASN1_SET_OF_ACCESS_DESCRIPTION i2d_ASN1_SET_OF_ACC_DESC 95#undef d2i_ASN1_SET_OF_ACCESS_DESCRIPTION 96#define d2i_ASN1_SET_OF_ACCESS_DESCRIPTION d2i_ASN1_SET_OF_ACC_DESC 97#endif 98 99/* Hack the names created with DECLARE_PEM_rw(NETSCAPE_CERT_SEQUENCE) */ 100#undef PEM_read_NETSCAPE_CERT_SEQUENCE 101#define PEM_read_NETSCAPE_CERT_SEQUENCE PEM_read_NS_CERT_SEQ 102#undef PEM_write_NETSCAPE_CERT_SEQUENCE 103#define PEM_write_NETSCAPE_CERT_SEQUENCE PEM_write_NS_CERT_SEQ 104#undef PEM_read_bio_NETSCAPE_CERT_SEQUENCE 105#define PEM_read_bio_NETSCAPE_CERT_SEQUENCE PEM_read_bio_NS_CERT_SEQ 106#undef PEM_write_bio_NETSCAPE_CERT_SEQUENCE 107#define PEM_write_bio_NETSCAPE_CERT_SEQUENCE PEM_write_bio_NS_CERT_SEQ 108#undef PEM_write_cb_bio_NETSCAPE_CERT_SEQUENCE 109#define PEM_write_cb_bio_NETSCAPE_CERT_SEQUENCE PEM_write_cb_bio_NS_CERT_SEQ 110 111/* Hack the names created with DECLARE_PEM_rw(PKCS8_PRIV_KEY_INFO) */ 112#undef PEM_read_PKCS8_PRIV_KEY_INFO 113#define PEM_read_PKCS8_PRIV_KEY_INFO PEM_read_P8_PRIV_KEY_INFO 114#undef PEM_write_PKCS8_PRIV_KEY_INFO 115#define PEM_write_PKCS8_PRIV_KEY_INFO PEM_write_P8_PRIV_KEY_INFO 116#undef PEM_read_bio_PKCS8_PRIV_KEY_INFO 117#define PEM_read_bio_PKCS8_PRIV_KEY_INFO PEM_read_bio_P8_PRIV_KEY_INFO 118#undef PEM_write_bio_PKCS8_PRIV_KEY_INFO 119#define PEM_write_bio_PKCS8_PRIV_KEY_INFO PEM_write_bio_P8_PRIV_KEY_INFO 120#undef PEM_write_cb_bio_PKCS8_PRIV_KEY_INFO 121#define PEM_write_cb_bio_PKCS8_PRIV_KEY_INFO PEM_wrt_cb_bio_P8_PRIV_KEY_INFO 122 123/* Hack other PEM names */ 124#undef PEM_write_bio_PKCS8PrivateKey_nid 125#define PEM_write_bio_PKCS8PrivateKey_nid PEM_write_bio_PKCS8PrivKey_nid 126 127/* Hack some long X509 names */ 128#undef X509_REVOKED_get_ext_by_critical 129#define X509_REVOKED_get_ext_by_critical X509_REVOKED_get_ext_by_critic 130 131/* Hack some long CRYPTO names */ 132#undef CRYPTO_set_dynlock_destroy_callback 133#define CRYPTO_set_dynlock_destroy_callback CRYPTO_set_dynlock_destroy_cb 134#undef CRYPTO_set_dynlock_create_callback 135#define CRYPTO_set_dynlock_create_callback CRYPTO_set_dynlock_create_cb 136#undef CRYPTO_set_dynlock_lock_callback 137#define CRYPTO_set_dynlock_lock_callback CRYPTO_set_dynlock_lock_cb 138#undef CRYPTO_get_dynlock_lock_callback 139#define CRYPTO_get_dynlock_lock_callback CRYPTO_get_dynlock_lock_cb 140#undef CRYPTO_get_dynlock_destroy_callback 141#define CRYPTO_get_dynlock_destroy_callback CRYPTO_get_dynlock_destroy_cb 142#undef CRYPTO_get_dynlock_create_callback 143#define CRYPTO_get_dynlock_create_callback CRYPTO_get_dynlock_create_cb 144#undef CRYPTO_set_locked_mem_ex_functions 145#define CRYPTO_set_locked_mem_ex_functions CRYPTO_set_locked_mem_ex_funcs 146#undef CRYPTO_get_locked_mem_ex_functions 147#define CRYPTO_get_locked_mem_ex_functions CRYPTO_get_locked_mem_ex_funcs 148 149/* Hack some long SSL names */ 150#undef SSL_CTX_set_default_verify_paths 151#define SSL_CTX_set_default_verify_paths SSL_CTX_set_def_verify_paths 152#undef SSL_get_ex_data_X509_STORE_CTX_idx 153#define SSL_get_ex_data_X509_STORE_CTX_idx SSL_get_ex_d_X509_STORE_CTX_idx 154#undef SSL_add_file_cert_subjects_to_stack 155#define SSL_add_file_cert_subjects_to_stack SSL_add_file_cert_subjs_to_stk 156#if 0 /* This function is not defined i VMS. */ 157#undef SSL_add_dir_cert_subjects_to_stack 158#define SSL_add_dir_cert_subjects_to_stack SSL_add_dir_cert_subjs_to_stk 159#endif 160#undef SSL_CTX_use_certificate_chain_file 161#define SSL_CTX_use_certificate_chain_file SSL_CTX_use_cert_chain_file 162#undef SSL_CTX_set_cert_verify_callback 163#define SSL_CTX_set_cert_verify_callback SSL_CTX_set_cert_verify_cb 164#undef SSL_CTX_set_default_passwd_cb_userdata 165#define SSL_CTX_set_default_passwd_cb_userdata SSL_CTX_set_def_passwd_cb_ud 166 167/* Hack some long ENGINE names */ 168#undef ENGINE_get_default_BN_mod_exp_crt 169#define ENGINE_get_default_BN_mod_exp_crt ENGINE_get_def_BN_mod_exp_crt 170#undef ENGINE_set_default_BN_mod_exp_crt 171#define ENGINE_set_default_BN_mod_exp_crt ENGINE_set_def_BN_mod_exp_crt 172#undef ENGINE_set_load_privkey_function 173#define ENGINE_set_load_privkey_function ENGINE_set_load_privkey_fn 174#undef ENGINE_get_load_privkey_function 175#define ENGINE_get_load_privkey_function ENGINE_get_load_privkey_fn 176 177/* Hack some long OCSP names */ 178#undef OCSP_REQUEST_get_ext_by_critical 179#define OCSP_REQUEST_get_ext_by_critical OCSP_REQUEST_get_ext_by_crit 180#undef OCSP_BASICRESP_get_ext_by_critical 181#define OCSP_BASICRESP_get_ext_by_critical OCSP_BASICRESP_get_ext_by_crit 182#undef OCSP_SINGLERESP_get_ext_by_critical 183#define OCSP_SINGLERESP_get_ext_by_critical OCSP_SINGLERESP_get_ext_by_crit 184 185/* Hack some long DES names */ 186#undef _ossl_old_des_ede3_cfb64_encrypt 187#define _ossl_old_des_ede3_cfb64_encrypt _ossl_odes_ede3_cfb64_encrypt 188#undef _ossl_old_des_ede3_ofb64_encrypt 189#define _ossl_old_des_ede3_ofb64_encrypt _ossl_odes_ede3_ofb64_encrypt 190 191/* Hack some long EVP names */ 192#undef OPENSSL_add_all_algorithms_noconf 193#define OPENSSL_add_all_algorithms_noconf OPENSSL_add_all_algo_noconf 194#undef OPENSSL_add_all_algorithms_conf 195#define OPENSSL_add_all_algorithms_conf OPENSSL_add_all_algo_conf 196 197/* Hack some long EC names */ 198#undef EC_POINT_set_Jprojective_coordinates_GFp 199#define EC_POINT_set_Jprojective_coordinates_GFp \ 200 EC_POINT_set_Jproj_coords_GFp 201#undef EC_POINT_get_Jprojective_coordinates_GFp 202#define EC_POINT_get_Jprojective_coordinates_GFp \ 203 EC_POINT_get_Jproj_coords_GFp 204#undef EC_POINT_set_affine_coordinates_GFp 205#define EC_POINT_set_affine_coordinates_GFp EC_POINT_set_affine_coords_GFp 206#undef EC_POINT_get_affine_coordinates_GFp 207#define EC_POINT_get_affine_coordinates_GFp EC_POINT_get_affine_coords_GFp 208#undef EC_POINT_set_compressed_coordinates_GFp 209#define EC_POINT_set_compressed_coordinates_GFp EC_POINT_set_compr_coords_GFp 210#undef ec_GFp_simple_group_set_curve_GFp 211#define ec_GFp_simple_group_set_curve_GFp ec_GFp_simple_grp_set_curve_GFp 212#undef ec_GFp_simple_group_get_curve_GFp 213#define ec_GFp_simple_group_get_curve_GFp ec_GFp_simple_grp_get_curve_GFp 214#undef ec_GFp_simple_group_clear_finish 215#define ec_GFp_simple_group_clear_finish ec_GFp_simple_grp_clear_finish 216#undef ec_GFp_simple_group_set_generator 217#define ec_GFp_simple_group_set_generator ec_GFp_simple_grp_set_generator 218#undef ec_GFp_simple_group_get0_generator 219#define ec_GFp_simple_group_get0_generator ec_GFp_simple_grp_gt0_generator 220#undef ec_GFp_simple_group_get_cofactor 221#define ec_GFp_simple_group_get_cofactor ec_GFp_simple_grp_get_cofactor 222#undef ec_GFp_simple_point_clear_finish 223#define ec_GFp_simple_point_clear_finish ec_GFp_simple_pt_clear_finish 224#undef ec_GFp_simple_point_set_to_infinity 225#define ec_GFp_simple_point_set_to_infinity ec_GFp_simple_pt_set_to_inf 226#undef ec_GFp_simple_points_make_affine 227#define ec_GFp_simple_points_make_affine ec_GFp_simple_pts_make_affine 228#undef ec_GFp_simple_group_get_curve_GFp 229#define ec_GFp_simple_group_get_curve_GFp ec_GFp_simple_grp_get_curve_GFp 230#undef ec_GFp_simple_set_Jprojective_coordinates_GFp 231#define ec_GFp_simple_set_Jprojective_coordinates_GFp \ 232 ec_GFp_smp_set_Jproj_coords_GFp 233#undef ec_GFp_simple_get_Jprojective_coordinates_GFp 234#define ec_GFp_simple_get_Jprojective_coordinates_GFp \ 235 ec_GFp_smp_get_Jproj_coords_GFp 236#undef ec_GFp_simple_point_set_affine_coordinates_GFp 237#define ec_GFp_simple_point_set_affine_coordinates_GFp \ 238 ec_GFp_smp_pt_set_af_coords_GFp 239#undef ec_GFp_simple_point_get_affine_coordinates_GFp 240#define ec_GFp_simple_point_get_affine_coordinates_GFp \ 241 ec_GFp_smp_pt_get_af_coords_GFp 242#undef ec_GFp_simple_set_compressed_coordinates_GFp 243#define ec_GFp_simple_set_compressed_coordinates_GFp \ 244 ec_GFp_smp_set_compr_coords_GFp 245 246#endif /* defined OPENSSL_SYS_VMS */ 247 248 249/* Case insensiteve linking causes problems.... */ 250#if defined(OPENSSL_SYS_WIN16) || defined(OPENSSL_SYS_VMS) || defined(OPENSSL_SYS_OS2) 251#undef ERR_load_CRYPTO_strings 252#define ERR_load_CRYPTO_strings ERR_load_CRYPTOlib_strings 253#undef OCSP_crlID_new 254#define OCSP_crlID_new OCSP_crlID2_new 255 256/* These functions do not seem to exist! However, I'm paranoid... 257 Original command in x509v3.h: 258 These functions are being redefined in another directory, 259 and clash when the linker is case-insensitive, so let's 260 hide them a little, by giving them an extra 'o' at the 261 beginning of the name... */ 262#undef X509v3_cleanup_extensions 263#define X509v3_cleanup_extensions oX509v3_cleanup_extensions 264#undef X509v3_add_extension 265#define X509v3_add_extension oX509v3_add_extension 266#undef X509v3_add_netscape_extensions 267#define X509v3_add_netscape_extensions oX509v3_add_netscape_extensions 268#undef X509v3_add_standard_extensions 269#define X509v3_add_standard_extensions oX509v3_add_standard_extensions 270 271 272#endif 273 274 275#endif /* ! defined HEADER_VMS_IDHACKS_H */ 276