Commit 4d3db136 authored by Peter Eisentraut's avatar Peter Eisentraut

Define OPENSSL_API_COMPAT

This avoids deprecation warnings from newer OpenSSL versions (3.0.0 in
particular).

Discussion: https://www.postgresql.org/message-id/flat/FEF81714-D479-4512-839B-C769D2605F8A%40yesql.se
parent 9b14280b
...@@ -12174,6 +12174,10 @@ fi ...@@ -12174,6 +12174,10 @@ fi
fi fi
if test "$with_openssl" = yes ; then if test "$with_openssl" = yes ; then
# Minimum required OpenSSL version is 1.0.1
$as_echo "#define OPENSSL_API_COMPAT 0x10001000L" >>confdefs.h
if test "$PORTNAME" != "win32"; then if test "$PORTNAME" != "win32"; then
{ $as_echo "$as_me:${as_lineno-$LINENO}: checking for CRYPTO_new_ex_data in -lcrypto" >&5 { $as_echo "$as_me:${as_lineno-$LINENO}: checking for CRYPTO_new_ex_data in -lcrypto" >&5
$as_echo_n "checking for CRYPTO_new_ex_data in -lcrypto... " >&6; } $as_echo_n "checking for CRYPTO_new_ex_data in -lcrypto... " >&6; }
......
...@@ -1206,6 +1206,9 @@ fi ...@@ -1206,6 +1206,9 @@ fi
if test "$with_openssl" = yes ; then if test "$with_openssl" = yes ; then
dnl Order matters! dnl Order matters!
# Minimum required OpenSSL version is 1.0.1
AC_DEFINE(OPENSSL_API_COMPAT, [0x10001000L],
[Define to the OpenSSL API version in use. This avoids deprecation warnings from newer OpenSSL versions.])
if test "$PORTNAME" != "win32"; then if test "$PORTNAME" != "win32"; then
AC_CHECK_LIB(crypto, CRYPTO_new_ex_data, [], [AC_MSG_ERROR([library 'crypto' is required for OpenSSL])]) AC_CHECK_LIB(crypto, CRYPTO_new_ex_data, [], [AC_MSG_ERROR([library 'crypto' is required for OpenSSL])])
AC_CHECK_LIB(ssl, SSL_new, [], [AC_MSG_ERROR([library 'ssl' is required for OpenSSL])]) AC_CHECK_LIB(ssl, SSL_new, [], [AC_MSG_ERROR([library 'ssl' is required for OpenSSL])])
......
...@@ -749,6 +749,10 @@ ...@@ -749,6 +749,10 @@
/* Define bytes to use libc memset(). */ /* Define bytes to use libc memset(). */
#undef MEMSET_LOOP_LIMIT #undef MEMSET_LOOP_LIMIT
/* Define to the OpenSSL API version in use. This avoids deprecation warnings
from newer OpenSSL versions. */
#undef OPENSSL_API_COMPAT
/* Define to the address where bug reports for this package should be sent. */ /* Define to the address where bug reports for this package should be sent. */
#undef PACKAGE_BUGREPORT #undef PACKAGE_BUGREPORT
......
...@@ -152,6 +152,8 @@ sub GenerateFiles ...@@ -152,6 +152,8 @@ sub GenerateFiles
my $package_bugreport; my $package_bugreport;
my $package_url; my $package_url;
my ($majorver, $minorver); my ($majorver, $minorver);
my $ac_define_openssl_api_compat_found = 0;
my $openssl_api_compat;
# Parse configure.in to get version numbers # Parse configure.in to get version numbers
open(my $c, '<', "configure.in") open(my $c, '<', "configure.in")
...@@ -176,10 +178,15 @@ sub GenerateFiles ...@@ -176,10 +178,15 @@ sub GenerateFiles
$majorver = sprintf("%d", $1); $majorver = sprintf("%d", $1);
$minorver = sprintf("%d", $2 ? $2 : 0); $minorver = sprintf("%d", $2 ? $2 : 0);
} }
elsif (/\bAC_DEFINE\(OPENSSL_API_COMPAT, \[([0-9xL]+)\]/)
{
$ac_define_openssl_api_compat_found = 1;
$openssl_api_compat = $1;
}
} }
close($c); close($c);
confess "Unable to parse configure.in for all variables!" confess "Unable to parse configure.in for all variables!"
unless $ac_init_found; unless $ac_init_found && $ac_define_openssl_api_compat_found;
if (IsNewer("src/include/pg_config_os.h", "src/include/port/win32.h")) if (IsNewer("src/include/pg_config_os.h", "src/include/port/win32.h"))
{ {
...@@ -433,6 +440,7 @@ sub GenerateFiles ...@@ -433,6 +440,7 @@ sub GenerateFiles
LOCALE_T_IN_XLOCALE => undef, LOCALE_T_IN_XLOCALE => undef,
MAXIMUM_ALIGNOF => 8, MAXIMUM_ALIGNOF => 8,
MEMSET_LOOP_LIMIT => 1024, MEMSET_LOOP_LIMIT => 1024,
OPENSSL_API_COMPAT => $openssl_api_compat,
PACKAGE_BUGREPORT => qq{"$package_bugreport"}, PACKAGE_BUGREPORT => qq{"$package_bugreport"},
PACKAGE_NAME => qq{"$package_name"}, PACKAGE_NAME => qq{"$package_name"},
PACKAGE_STRING => qq{"$package_name $package_version"}, PACKAGE_STRING => qq{"$package_name $package_version"},
......
Markdown is supported
0% or
You are about to add 0 people to the discussion. Proceed with caution.
Finish editing this message first!
Please register or to comment