The branch master has been updated via 38186bfd4e5be7f212d8e460420e081e0ad852e7 (commit) via 73decf5975ff1249c51baa0cb3956bb67fbd64dc (commit) from 29fa0a1af45a1037850b29f5851f4a054124781b (commit)
- Log ----------------------------------------------------------------- commit 38186bfd4e5be7f212d8e460420e081e0ad852e7 Author: Rich Salz <rs...@openssl.org> Date: Tue Mar 22 13:35:03 2016 -0400 Have only one DSO_METHOD_openssl Instead of have every DSO_METHOD_xxx in all platforms, ensure that only one DSO_METHOD_openssl is available on all platforms. Reviewed-by: Tim Hudson <t...@openssl.org> commit 73decf5975ff1249c51baa0cb3956bb67fbd64dc Author: Rich Salz <rs...@openssl.org> Date: Tue Mar 22 13:16:54 2016 -0400 Make DSO opaque. This was really easy. Reviewed-by: Tim Hudson <t...@openssl.org> ----------------------------------------------------------------------- Summary of changes: crypto/dso/Makefile.in | 4 +- crypto/dso/build.info | 2 +- crypto/dso/dso_dl.c | 16 ++----- crypto/dso/dso_dlfcn.c | 16 ++----- crypto/dso/dso_err.c | 4 +- crypto/dso/dso_lib.c | 5 +- crypto/dso/dso_locl.h | 107 +++++++++++++++++++++++++++++++++++++++++ crypto/dso/dso_null.c | 86 --------------------------------- crypto/dso/dso_openssl.c | 25 ++++------ crypto/dso/dso_vms.c | 20 +++----- crypto/dso/dso_win32.c | 16 ++----- include/openssl/dso.h | 122 +---------------------------------------------- util/libcrypto.num | 10 ++-- util/libssl.num | 2 +- 14 files changed, 145 insertions(+), 290 deletions(-) create mode 100644 crypto/dso/dso_locl.h delete mode 100644 crypto/dso/dso_null.c diff --git a/crypto/dso/Makefile.in b/crypto/dso/Makefile.in index 8c517fe..e2fec28 100644 --- a/crypto/dso/Makefile.in +++ b/crypto/dso/Makefile.in @@ -15,9 +15,9 @@ CFLAGS= $(INCLUDES) $(CFLAG) $(SHARED_CFLAG) GENERAL=Makefile LIB=$(TOP)/libcrypto.a -LIBSRC= dso_dl.c dso_dlfcn.c dso_err.c dso_lib.c dso_null.c \ +LIBSRC= dso_dl.c dso_dlfcn.c dso_err.c dso_lib.c \ dso_openssl.c dso_win32.c dso_vms.c -LIBOBJ= dso_dl.o dso_dlfcn.o dso_err.o dso_lib.o dso_null.o \ +LIBOBJ= dso_dl.o dso_dlfcn.o dso_err.o dso_lib.o \ dso_openssl.o dso_win32.o dso_vms.o SRC= $(LIBSRC) diff --git a/crypto/dso/build.info b/crypto/dso/build.info index 30b3a28..82b592d 100644 --- a/crypto/dso/build.info +++ b/crypto/dso/build.info @@ -1,4 +1,4 @@ LIBS=../../libcrypto SOURCE[../../libcrypto]=\ - dso_dl.c dso_dlfcn.c dso_err.c dso_lib.c dso_null.c \ + dso_dl.c dso_dlfcn.c dso_err.c dso_lib.c \ dso_openssl.c dso_win32.c dso_vms.c diff --git a/crypto/dso/dso_dl.c b/crypto/dso/dso_dl.c index 73d7ca3..72ca454 100644 --- a/crypto/dso/dso_dl.c +++ b/crypto/dso/dso_dl.c @@ -56,17 +56,9 @@ * */ -#include <stdio.h> -#include "internal/cryptlib.h" -#include <openssl/dso.h> -#include "internal/dso_conf.h" +#include "dso_locl.h" -#ifndef DSO_DL -DSO_METHOD *DSO_METHOD_dl(void) -{ - return NULL; -} -#else +#ifdef DSO_DL # include <dl.h> @@ -98,9 +90,9 @@ static DSO_METHOD dso_meth_dl = { dl_globallookup }; -DSO_METHOD *DSO_METHOD_dl(void) +DSO_METHOD *DSO_METHOD_openssl(void) { - return (&dso_meth_dl); + return &dso_meth_dl; } /* diff --git a/crypto/dso/dso_dlfcn.c b/crypto/dso/dso_dlfcn.c index 107abfd..09a4913 100644 --- a/crypto/dso/dso_dlfcn.c +++ b/crypto/dso/dso_dlfcn.c @@ -65,17 +65,9 @@ # define _GNU_SOURCE /* make sure dladdr is declared */ #endif -#include <stdio.h> -#include "internal/cryptlib.h" -#include <openssl/dso.h> -#include "internal/dso_conf.h" +#include "dso_locl.h" -#ifndef DSO_DLFCN -DSO_METHOD *DSO_METHOD_dlfcn(void) -{ - return NULL; -} -#else +#ifdef DSO_DLFCN # ifdef HAVE_DLFCN_H # ifdef __osf__ @@ -120,9 +112,9 @@ static DSO_METHOD dso_meth_dlfcn = { dlfcn_globallookup }; -DSO_METHOD *DSO_METHOD_dlfcn(void) +DSO_METHOD *DSO_METHOD_openssl(void) { - return (&dso_meth_dlfcn); + return &dso_meth_dlfcn; } /* diff --git a/crypto/dso/dso_err.c b/crypto/dso/dso_err.c index 2a7c821..e47f5cd 100644 --- a/crypto/dso/dso_err.c +++ b/crypto/dso/dso_err.c @@ -58,9 +58,7 @@ * only reason strings will be preserved. */ -#include <stdio.h> -#include <openssl/err.h> -#include <openssl/dso.h> +#include "dso_locl.h" /* BEGIN ERROR CODES */ #ifndef OPENSSL_NO_ERR diff --git a/crypto/dso/dso_lib.c b/crypto/dso/dso_lib.c index 3082545..f464fab 100644 --- a/crypto/dso/dso_lib.c +++ b/crypto/dso/dso_lib.c @@ -56,10 +56,7 @@ * */ -#include <stdio.h> -#include <openssl/crypto.h> -#include "internal/cryptlib.h" -#include <openssl/dso.h> +#include "dso_locl.h" static DSO_METHOD *default_DSO_meth = NULL; diff --git a/crypto/dso/dso_locl.h b/crypto/dso/dso_locl.h new file mode 100644 index 0000000..3d7d669 --- /dev/null +++ b/crypto/dso/dso_locl.h @@ -0,0 +1,107 @@ +/* + * Copyright 2016 The OpenSSL Project Authors. All Rights Reserved. + * Licensed under the OpenSSL licenses, (the "License"); + * you may not use this file except in compliance with the License. + * You may obtain a copy of the License at + * https://www.openssl.org/source/license.html + * or in the file LICENSE in the source distribution. + */ +#include <stdio.h> +#include "internal/cryptlib.h" +#include <openssl/dso.h> +#include "internal/dso_conf.h" + +/**********************************************************************/ +/* The low-level handle type used to refer to a loaded shared library */ + +struct dso_st { + DSO_METHOD *meth; + /* + * Standard dlopen uses a (void *). Win32 uses a HANDLE. VMS doesn't use + * anything but will need to cache the filename for use in the dso_bind + * handler. All in all, let each method control its own destiny. + * "Handles" and such go in a STACK. + */ + STACK_OF(void) *meth_data; + int references; + int flags; + /* + * For use by applications etc ... use this for your bits'n'pieces, don't + * touch meth_data! + */ + CRYPTO_EX_DATA ex_data; + /* + * If this callback function pointer is set to non-NULL, then it will be + * used in DSO_load() in place of meth->dso_name_converter. NB: This + * should normally set using DSO_set_name_converter(). + */ + DSO_NAME_CONVERTER_FUNC name_converter; + /* + * If this callback function pointer is set to non-NULL, then it will be + * used in DSO_load() in place of meth->dso_merger. NB: This should + * normally set using DSO_set_merger(). + */ + DSO_MERGER_FUNC merger; + /* + * This is populated with (a copy of) the platform-independent filename + * used for this DSO. + */ + char *filename; + /* + * This is populated with (a copy of) the translated filename by which + * the DSO was actually loaded. It is NULL iff the DSO is not currently + * loaded. NB: This is here because the filename translation process may + * involve a callback being invoked more than once not only to convert to + * a platform-specific form, but also to try different filenames in the + * process of trying to perform a load. As such, this variable can be + * used to indicate (a) whether this DSO structure corresponds to a + * loaded library or not, and (b) the filename with which it was actually + * loaded. + */ + char *loaded_filename; + CRYPTO_RWLOCK *lock; +}; + +struct dso_meth_st { + const char *name; + /* + * Loads a shared library, NB: new DSO_METHODs must ensure that a + * successful load populates the loaded_filename field, and likewise a + * successful unload OPENSSL_frees and NULLs it out. + */ + int (*dso_load) (DSO *dso); + /* Unloads a shared library */ + int (*dso_unload) (DSO *dso); + /* Binds a variable */ + void *(*dso_bind_var) (DSO *dso, const char *symname); + /* + * Binds a function - assumes a return type of DSO_FUNC_TYPE. This should + * be cast to the real function prototype by the caller. Platforms that + * don't have compatible representations for different prototypes (this + * is possible within ANSI C) are highly unlikely to have shared + * libraries at all, let alone a DSO_METHOD implemented for them. + */ + DSO_FUNC_TYPE (*dso_bind_func) (DSO *dso, const char *symname); + /* + * The generic (yuck) "ctrl()" function. NB: Negative return values + * (rather than zero) indicate errors. + */ + long (*dso_ctrl) (DSO *dso, int cmd, long larg, void *parg); + /* + * The default DSO_METHOD-specific function for converting filenames to a + * canonical native form. + */ + DSO_NAME_CONVERTER_FUNC dso_name_converter; + /* + * The default DSO_METHOD-specific function for converting filenames to a + * canonical native form. + */ + DSO_MERGER_FUNC dso_merger; + /* [De]Initialisation handlers. */ + int (*init) (DSO *dso); + int (*finish) (DSO *dso); + /* Return pathname of the module containing location */ + int (*pathbyaddr) (void *addr, char *path, int sz); + /* Perform global symbol lookup, i.e. among *all* modules */ + void *(*globallookup) (const char *symname); +}; diff --git a/crypto/dso/dso_null.c b/crypto/dso/dso_null.c deleted file mode 100644 index fffa592..0000000 --- a/crypto/dso/dso_null.c +++ /dev/null @@ -1,86 +0,0 @@ -/* - * Written by Geoff Thorpe (ge...@geoffthorpe.net) for the OpenSSL project - * 2000. - */ -/* ==================================================================== - * Copyright (c) 2000 The OpenSSL Project. All rights reserved. - * - * Redistribution and use in source and binary forms, with or without - * modification, are permitted provided that the following conditions - * are met: - * - * 1. Redistributions of source code must retain the above copyright - * notice, this list of conditions and the following disclaimer. - * - * 2. Redistributions in binary form must reproduce the above copyright - * notice, this list of conditions and the following disclaimer in - * the documentation and/or other materials provided with the - * distribution. - * - * 3. All advertising materials mentioning features or use of this - * software must display the following acknowledgment: - * "This product includes software developed by the OpenSSL Project - * for use in the OpenSSL Toolkit. (http://www.OpenSSL.org/)" - * - * 4. The names "OpenSSL Toolkit" and "OpenSSL Project" must not be used to - * endorse or promote products derived from this software without - * prior written permission. For written permission, please contact - * licens...@openssl.org. - * - * 5. Products derived from this software may not be called "OpenSSL" - * nor may "OpenSSL" appear in their names without prior written - * permission of the OpenSSL Project. - * - * 6. Redistributions of any form whatsoever must retain the following - * acknowledgment: - * "This product includes software developed by the OpenSSL Project - * for use in the OpenSSL Toolkit (http://www.OpenSSL.org/)" - * - * THIS SOFTWARE IS PROVIDED BY THE OpenSSL PROJECT ``AS IS'' AND ANY - * EXPRESSED OR IMPLIED WARRANTIES, INCLUDING, BUT NOT LIMITED TO, THE - * IMPLIED WARRANTIES OF MERCHANTABILITY AND FITNESS FOR A PARTICULAR - * PURPOSE ARE DISCLAIMED. IN NO EVENT SHALL THE OpenSSL PROJECT OR - * ITS CONTRIBUTORS BE LIABLE FOR ANY DIRECT, INDIRECT, INCIDENTAL, - * SPECIAL, EXEMPLARY, OR CONSEQUENTIAL DAMAGES (INCLUDING, BUT - * NOT LIMITED TO, PROCUREMENT OF SUBSTITUTE GOODS OR SERVICES; - * LOSS OF USE, DATA, OR PROFITS; OR BUSINESS INTERRUPTION) - * HOWEVER CAUSED AND ON ANY THEORY OF LIABILITY, WHETHER IN CONTRACT, - * STRICT LIABILITY, OR TORT (INCLUDING NEGLIGENCE OR OTHERWISE) - * ARISING IN ANY WAY OUT OF THE USE OF THIS SOFTWARE, EVEN IF ADVISED - * OF THE POSSIBILITY OF SUCH DAMAGE. - * ==================================================================== - * - * This product includes cryptographic software written by Eric Young - * (e...@cryptsoft.com). This product includes software written by Tim - * Hudson (t...@cryptsoft.com). - * - */ - -/* - * This "NULL" method is provided as the fallback for systems that have no - * appropriate support for "shared-libraries". - */ - -#include <stdio.h> -#include "internal/cryptlib.h" -#include <openssl/dso.h> - -static DSO_METHOD dso_meth_null = { - "NULL shared library method", - NULL, /* load */ - NULL, /* unload */ - NULL, /* bind_var */ - NULL, /* bind_func */ - NULL, /* ctrl */ - NULL, /* dso_name_converter */ - NULL, /* dso_merger */ - NULL, /* init */ - NULL, /* finish */ - NULL, /* pathbyaddr */ - NULL /* globallookup */ -}; - -DSO_METHOD *DSO_METHOD_null(void) -{ - return (&dso_meth_null); -} diff --git a/crypto/dso/dso_openssl.c b/crypto/dso/dso_openssl.c index 5aa0536..070f116 100644 --- a/crypto/dso/dso_openssl.c +++ b/crypto/dso/dso_openssl.c @@ -56,25 +56,16 @@ * */ -#include <stdio.h> -#include "internal/cryptlib.h" -#include <openssl/dso.h> +#include "dso_locl.h" -/* We just pinch the method from an appropriate "default" method. */ +#if !defined(DSO_VMS) && !defined(DSO_DLCFN) && !defined(DSO_DL) && !defined(DSO_WIN32) && !defined(DSO_DLFCN) + +static DSO_METHOD dso_meth_null = { + "NULL shared library method" +}; DSO_METHOD *DSO_METHOD_openssl(void) { -#ifdef DEF_DSO_METHOD - return (DEF_DSO_METHOD()); -#elif defined(DSO_DLFCN) - return (DSO_METHOD_dlfcn()); -#elif defined(DSO_DL) - return (DSO_METHOD_dl()); -#elif defined(DSO_WIN32) - return (DSO_METHOD_win32()); -#elif defined(DSO_VMS) - return (DSO_METHOD_vms()); -#else - return (DSO_METHOD_null()); -#endif + return dso_meth_null(); } +#endif diff --git a/crypto/dso/dso_vms.c b/crypto/dso/dso_vms.c index a36234d..79e9963 100644 --- a/crypto/dso/dso_vms.c +++ b/crypto/dso/dso_vms.c @@ -56,20 +56,12 @@ * */ -#include <stdio.h> -#include <string.h> -#include <errno.h> -#include "internal/cryptlib.h" -#include <openssl/dso.h> - -#ifndef OPENSSL_SYS_VMS -DSO_METHOD *DSO_METHOD_vms(void) -{ - return NULL; -} -#else +#include "dso_locl.h" + +#ifdef OPENSSL_SYS_VMS # pragma message disable DOLLARID +# include <errno.h> # include <rms.h> # include <lib$routines.h> # include <stsdef.h> @@ -132,9 +124,9 @@ typedef struct dso_internal_st { char imagename[NAMX_MAXRSS + 1]; } DSO_VMS_INTERNAL; -DSO_METHOD *DSO_METHOD_vms(void) +DSO_METHOD *DSO_METHOD_openssl(void) { - return (&dso_meth_vms); + return &dso_meth_vms; } static int vms_load(DSO *dso) diff --git a/crypto/dso/dso_win32.c b/crypto/dso/dso_win32.c index 3d9ee8a..e378d68 100644 --- a/crypto/dso/dso_win32.c +++ b/crypto/dso/dso_win32.c @@ -56,17 +56,9 @@ * */ -#include <stdio.h> -#include <string.h> -#include "internal/cryptlib.h" -#include <openssl/dso.h> +#include "dso_locl.h" -#if !defined(DSO_WIN32) -DSO_METHOD *DSO_METHOD_win32(void) -{ - return NULL; -} -#else +#if defined(DSO_WIN32) # ifdef _WIN32_WCE # if _WIN32_WCE < 300 @@ -141,9 +133,9 @@ static DSO_METHOD dso_meth_win32 = { win32_globallookup }; -DSO_METHOD *DSO_METHOD_win32(void) +DSO_METHOD *DSO_METHOD_openssl(void) { - return (&dso_meth_win32); + return &dso_meth_win32; } /* diff --git a/include/openssl/dso.h b/include/openssl/dso.h index 1eadbd9..70b19b6 100644 --- a/include/openssl/dso.h +++ b/include/openssl/dso.h @@ -109,6 +109,7 @@ extern "C" { typedef void (*DSO_FUNC_TYPE) (void); typedef struct dso_st DSO; +typedef struct dso_meth_st DSO_METHOD; /* * The function prototype used for method functions (or caller-provided @@ -136,101 +137,6 @@ typedef char *(*DSO_NAME_CONVERTER_FUNC)(DSO *, const char *); */ typedef char *(*DSO_MERGER_FUNC)(DSO *, const char *, const char *); -typedef struct dso_meth_st { - const char *name; - /* - * Loads a shared library, NB: new DSO_METHODs must ensure that a - * successful load populates the loaded_filename field, and likewise a - * successful unload OPENSSL_frees and NULLs it out. - */ - int (*dso_load) (DSO *dso); - /* Unloads a shared library */ - int (*dso_unload) (DSO *dso); - /* Binds a variable */ - void *(*dso_bind_var) (DSO *dso, const char *symname); - /* - * Binds a function - assumes a return type of DSO_FUNC_TYPE. This should - * be cast to the real function prototype by the caller. Platforms that - * don't have compatible representations for different prototypes (this - * is possible within ANSI C) are highly unlikely to have shared - * libraries at all, let alone a DSO_METHOD implemented for them. - */ - DSO_FUNC_TYPE (*dso_bind_func) (DSO *dso, const char *symname); - /* - * The generic (yuck) "ctrl()" function. NB: Negative return values - * (rather than zero) indicate errors. - */ - long (*dso_ctrl) (DSO *dso, int cmd, long larg, void *parg); - /* - * The default DSO_METHOD-specific function for converting filenames to a - * canonical native form. - */ - DSO_NAME_CONVERTER_FUNC dso_name_converter; - /* - * The default DSO_METHOD-specific function for converting filenames to a - * canonical native form. - */ - DSO_MERGER_FUNC dso_merger; - /* [De]Initialisation handlers. */ - int (*init) (DSO *dso); - int (*finish) (DSO *dso); - /* Return pathname of the module containing location */ - int (*pathbyaddr) (void *addr, char *path, int sz); - /* Perform global symbol lookup, i.e. among *all* modules */ - void *(*globallookup) (const char *symname); -} DSO_METHOD; - -/**********************************************************************/ -/* The low-level handle type used to refer to a loaded shared library */ - -struct dso_st { - DSO_METHOD *meth; - /* - * Standard dlopen uses a (void *). Win32 uses a HANDLE. VMS doesn't use - * anything but will need to cache the filename for use in the dso_bind - * handler. All in all, let each method control its own destiny. - * "Handles" and such go in a STACK. - */ - STACK_OF(void) *meth_data; - int references; - int flags; - /* - * For use by applications etc ... use this for your bits'n'pieces, don't - * touch meth_data! - */ - CRYPTO_EX_DATA ex_data; - /* - * If this callback function pointer is set to non-NULL, then it will be - * used in DSO_load() in place of meth->dso_name_converter. NB: This - * should normally set using DSO_set_name_converter(). - */ - DSO_NAME_CONVERTER_FUNC name_converter; - /* - * If this callback function pointer is set to non-NULL, then it will be - * used in DSO_load() in place of meth->dso_merger. NB: This should - * normally set using DSO_set_merger(). - */ - DSO_MERGER_FUNC merger; - /* - * This is populated with (a copy of) the platform-independent filename - * used for this DSO. - */ - char *filename; - /* - * This is populated with (a copy of) the translated filename by which - * the DSO was actually loaded. It is NULL iff the DSO is not currently - * loaded. NB: This is here because the filename translation process may - * involve a callback being invoked more than once not only to convert to - * a platform-specific form, but also to try different filenames in the - * process of trying to perform a load. As such, this variable can be - * used to indicate (a) whether this DSO structure corresponds to a - * loaded library or not, and (b) the filename with which it was actually - * loaded. - */ - char *loaded_filename; - CRYPTO_RWLOCK *lock; -}; - DSO *DSO_new(void); DSO *DSO_new_method(DSO_METHOD *method); int DSO_free(DSO *dso); @@ -309,32 +215,6 @@ DSO_FUNC_TYPE DSO_bind_func(DSO *dso, const char *symname); DSO_METHOD *DSO_METHOD_openssl(void); /* - * This method is defined for all platforms - if a platform has no DSO - * support then this will be the only method! - */ -DSO_METHOD *DSO_METHOD_null(void); - -/* - * If DSO_DLFCN is defined, the standard dlfcn.h-style functions (dlopen, - * dlclose, dlsym, etc) will be used and incorporated into this method. If - * not, this method will return NULL. - */ -DSO_METHOD *DSO_METHOD_dlfcn(void); - -/* - * If DSO_DL is defined, the standard dl.h-style functions (shl_load, - * shl_unload, shl_findsym, etc) will be used and incorporated into this - * method. If not, this method will return NULL. - */ -DSO_METHOD *DSO_METHOD_dl(void); - -/* If WIN32 is defined, use DLLs. If not, return NULL. */ -DSO_METHOD *DSO_METHOD_win32(void); - -/* If VMS is defined, use shared images. If not, return NULL. */ -DSO_METHOD *DSO_METHOD_vms(void); - -/* * This function writes null-terminated pathname of DSO module containing * 'addr' into 'sz' large caller-provided 'path' and returns the number of * characters [including trailing zero] written to it. If 'sz' is 0 or diff --git a/util/libcrypto.num b/util/libcrypto.num index 2e2e657..c0918ba 100644 --- a/util/libcrypto.num +++ b/util/libcrypto.num @@ -138,7 +138,7 @@ X509v3_add_ext 135 1_1_0 EXIST::FUNCTION: v3_addr_subset 136 1_1_0 EXIST::FUNCTION:RFC3779 CRYPTO_strndup 137 1_1_0 EXIST::FUNCTION: OCSP_REQ_CTX_free 138 1_1_0 EXIST::FUNCTION: -DSO_METHOD_dlfcn 139 1_1_0 EXIST::FUNCTION: +DSO_METHOD_dlfcn 139 1_1_0 NOEXIST::FUNCTION: X509_STORE_new 140 1_1_0 EXIST::FUNCTION: ASN1_TYPE_free 141 1_1_0 EXIST::FUNCTION: PKCS12_BAGS_new 142 1_1_0 EXIST::FUNCTION: @@ -1491,7 +1491,7 @@ EVP_CIPHER_CTX_set_padding 1444 1_1_0 EXIST::FUNCTION: CTLOG_new_from_base64 1445 1_1_0 EXIST::FUNCTION:CT AES_bi_ige_encrypt 1446 1_1_0 EXIST::FUNCTION:AES ERR_pop_to_mark 1447 1_1_0 EXIST::FUNCTION: -DSO_METHOD_win32 1448 1_1_0 EXIST::FUNCTION: +DSO_METHOD_win32 1448 1_1_0 NOEXIST::FUNCTION: CRL_DIST_POINTS_new 1449 1_1_0 EXIST::FUNCTION: EVP_PKEY_get0_asn1 1450 1_1_0 EXIST::FUNCTION: EVP_camellia_192_ctr 1451 1_1_0 EXIST::FUNCTION:CAMELLIA @@ -1888,7 +1888,7 @@ ASN1_VISIBLESTRING_it 1831 1_1_0 EXIST:!EXPORT_VAR_AS_FUNCTION ASN1_VISIBLESTRING_it 1831 1_1_0 EXIST:EXPORT_VAR_AS_FUNCTION:FUNCTION: X509V3_EXT_REQ_add_conf 1832 1_1_0 EXIST::FUNCTION: ASN1_STRING_to_UTF8 1833 1_1_0 EXIST::FUNCTION: -DSO_METHOD_null 1834 1_1_0 EXIST::FUNCTION: +DSO_METHOD_null 1834 1_1_0 NOEXIST::FUNCTION: EVP_MD_meth_set_update 1835 1_1_0 EXIST::FUNCTION: EVP_camellia_192_cbc 1836 1_1_0 EXIST::FUNCTION:CAMELLIA lh_stats_bio 1837 1_1_0 EXIST::FUNCTION: @@ -3116,7 +3116,7 @@ PEM_read_bio_RSAPublicKey 3009 1_1_0 EXIST::FUNCTION:RSA EVP_PKEY_asn1_set_private 3010 1_1_0 EXIST::FUNCTION: EVP_PKEY_get0_RSA 3011 1_1_0 EXIST::FUNCTION:RSA DES_ede3_cfb64_encrypt 3012 1_1_0 EXIST::FUNCTION:DES -DSO_METHOD_vms 3013 1_1_0 EXIST::FUNCTION: +DSO_METHOD_vms 3013 1_1_0 NOEXIST::FUNCTION: POLICY_MAPPING_free 3014 1_1_0 EXIST::FUNCTION: EVP_aes_128_gcm 3015 1_1_0 EXIST::FUNCTION:AES BIO_dgram_non_fatal_error 3016 1_1_0 EXIST::FUNCTION: @@ -3677,7 +3677,7 @@ EVP_CIPHER_CTX_cipher_data 3561 1_1_0 NOEXIST::FUNCTION: PKCS7_decrypt 3562 1_1_0 EXIST::FUNCTION: X509_STORE_set1_param 3563 1_1_0 EXIST::FUNCTION: RAND_file_name 3564 1_1_0 EXIST::FUNCTION: -DSO_METHOD_dl 3565 1_1_0 EXIST::FUNCTION: +DSO_METHOD_dl 3565 1_1_0 NOEXIST::FUNCTION: EVP_CipherInit_ex 3566 1_1_0 EXIST::FUNCTION: BIO_dgram_sctp_notification_cb 3567 1_1_0 EXIST::FUNCTION:SCTP ERR_load_RAND_strings 3568 1_1_0 EXIST::FUNCTION: diff --git a/util/libssl.num b/util/libssl.num index 7b4a7e6..8b2155e 100644 --- a/util/libssl.num +++ b/util/libssl.num @@ -58,7 +58,7 @@ SSL_get0_dane_authority 57 1_1_0 EXIST::FUNCTION: SSL_set_purpose 58 1_1_0 EXIST::FUNCTION: SSL_CTX_use_PrivateKey_file 59 1_1_0 EXIST::FUNCTION: SSL_get_rfd 60 1_1_0 EXIST::FUNCTION: -DTLSv1_listen 61 1_1_0 EXIST::FUNCTION: +DTLSv1_listen 61 1_1_0 EXIST::FUNCTION:SOCK SSL_set_ssl_method 62 1_1_0 EXIST::FUNCTION: SSL_get0_security_ex_data 63 1_1_0 EXIST::FUNCTION: SSLv3_client_method 64 1_1_0 EXIST::FUNCTION:DEPRECATEDIN_1_1_0,SSL3_METHOD _____ openssl-commits mailing list To unsubscribe: https://mta.openssl.org/mailman/listinfo/openssl-commits