Check for the existence of openssl version funcs.

Check for the existence of openssl version functions and use the ones
detected instead of trying to guess based on the int32 version
identifier.  Fixes builds with LibreSSL.
This commit is contained in:
Darren Tucker 2018-10-27 16:45:59 +11:00
parent 406a24b25d
commit 262d81a259
1 changed files with 12 additions and 5 deletions

View File

@ -2585,6 +2585,9 @@ if test "x$openssl" = "xyes" ; then
] ]
) )
# Determining OpenSSL library version is version dependent.
AC_CHECK_FUNCS([OpenSSL_version OpenSSL_version_num])
# Determine OpenSSL library version # Determine OpenSSL library version
AC_MSG_CHECKING([OpenSSL library version]) AC_MSG_CHECKING([OpenSSL library version])
AC_RUN_IFELSE( AC_RUN_IFELSE(
@ -2601,10 +2604,14 @@ if test "x$openssl" = "xyes" ; then
fd = fopen(DATA,"w"); fd = fopen(DATA,"w");
if(fd == NULL) if(fd == NULL)
exit(1); exit(1);
#if OPENSSL_VERSION_NUMBER < 0x10100000L #ifndef OPENSSL_VERSION
# define OpenSSL_version_num SSLeay
# define OpenSSL_version SSLeay_version
# define OPENSSL_VERSION SSLEAY_VERSION # define OPENSSL_VERSION SSLEAY_VERSION
#endif
#ifndef HAVE_OPENSSL_VERSION
# define OpenSSL_version SSLeay_version
#endif
#ifndef HAVE_OPENSSL_VERSION_NUM
# define OpenSSL_version_num SSLeay
#endif #endif
if ((rc = fprintf(fd, "%08lx (%s)\n", if ((rc = fprintf(fd, "%08lx (%s)\n",
(unsigned long)OpenSSL_version_num(), (unsigned long)OpenSSL_version_num(),
@ -2650,7 +2657,7 @@ if test "x$openssl" = "xyes" ; then
#include <openssl/opensslv.h> #include <openssl/opensslv.h>
#include <openssl/crypto.h> #include <openssl/crypto.h>
]], [[ ]], [[
#if OPENSSL_VERSION_NUMBER < 0x10100000L #ifndef HAVE_OPENSSL_VERSION_NUM
# define OpenSSL_version_num SSLeay # define OpenSSL_version_num SSLeay
#endif #endif
exit(OpenSSL_version_num() == OPENSSL_VERSION_NUMBER ? 0 : 1); exit(OpenSSL_version_num() == OPENSSL_VERSION_NUMBER ? 0 : 1);