Skip to content

Commit eaabf25

Browse files
fanquakedeadalnix
authored andcommitted
build: fix OpenSSL EC detection on macOS
Summary: * build: add SECP_TEST_INCLUDES to bench_verify CPPFLAGS This is needed so that bench_verify gets CRYPTO_CPPFLAGS, which would otherwise not be included, at least on macOS. This is a backport of linsecp256k1 [[bitcoin-core/secp256k1#735 | PR735]] Test Plan: I don't have an OSX machine, so \o/ Reviewers: #bitcoin_abc, majcosta Reviewed By: #bitcoin_abc, majcosta Differential Revision: https://reviews.bitcoinabc.org/D7583
1 parent aab4b77 commit eaabf25

File tree

3 files changed

+7
-1
lines changed

3 files changed

+7
-1
lines changed

Makefile.am

Lines changed: 2 additions & 0 deletions
Original file line numberDiff line numberDiff line change
@@ -88,6 +88,8 @@ if USE_BENCHMARK
8888
noinst_PROGRAMS += bench_verify bench_sign bench_internal bench_ecmult
8989
bench_verify_SOURCES = src/bench_verify.c
9090
bench_verify_LDADD = libsecp256k1.la $(SECP_LIBS) $(SECP_TEST_LIBS) $(COMMON_LIB)
91+
# SECP_TEST_INCLUDES are only used here for CRYPTO_CPPFLAGS
92+
bench_verify_CPPFLAGS = -DSECP256K1_BUILD $(SECP_TEST_INCLUDES)
9193
bench_sign_SOURCES = src/bench_sign.c
9294
bench_sign_LDADD = libsecp256k1.la $(SECP_LIBS) $(SECP_TEST_LIBS) $(COMMON_LIB)
9395
bench_internal_SOURCES = src/bench_internal.c

build-aux/m4/bitcoin_secp.m4

Lines changed: 3 additions & 0 deletions
Original file line numberDiff line numberDiff line change
@@ -38,6 +38,8 @@ AC_DEFUN([SECP_OPENSSL_CHECK],[
3838
fi
3939
if test x"$has_libcrypto" = x"yes" && test x"$has_openssl_ec" = x; then
4040
AC_MSG_CHECKING(for EC functions in libcrypto)
41+
CPPFLAGS_TEMP="$CPPFLAGS"
42+
CPPFLAGS="$CRYPTO_CPPFLAGS $CPPFLAGS"
4143
AC_COMPILE_IFELSE([AC_LANG_PROGRAM([[
4244
#include <openssl/ec.h>
4345
#include <openssl/ecdsa.h>
@@ -51,6 +53,7 @@ if test x"$has_libcrypto" = x"yes" && test x"$has_openssl_ec" = x; then
5153
ECDSA_SIG_free(sig_openssl);
5254
]])],[has_openssl_ec=yes],[has_openssl_ec=no])
5355
AC_MSG_RESULT([$has_openssl_ec])
56+
CPPFLAGS="$CPPFLAGS_TEMP"
5457
fi
5558
])
5659

configure.ac

Lines changed: 2 additions & 1 deletion
Original file line numberDiff line numberDiff line change
@@ -46,6 +46,7 @@ case $host_os in
4646
if test x$openssl_prefix != x; then
4747
PKG_CONFIG_PATH="$openssl_prefix/lib/pkgconfig:$PKG_CONFIG_PATH"
4848
export PKG_CONFIG_PATH
49+
CRYPTO_CPPFLAGS="-I$openssl_prefix/include"
4950
fi
5051
if test x$gmp_prefix != x; then
5152
GMP_CPPFLAGS="-I$gmp_prefix/include"
@@ -466,7 +467,7 @@ if test x"$use_tests" = x"yes"; then
466467
if test x"$has_openssl_ec" = x"yes"; then
467468
if test x"$enable_openssl_tests" != x"no"; then
468469
AC_DEFINE(ENABLE_OPENSSL_TESTS, 1, [Define this symbol if OpenSSL EC functions are available])
469-
SECP_TEST_INCLUDES="$SSL_CFLAGS $CRYPTO_CFLAGS"
470+
SECP_TEST_INCLUDES="$SSL_CFLAGS $CRYPTO_CFLAGS $CRYPTO_CPPFLAGS"
470471
SECP_TEST_LIBS="$CRYPTO_LIBS"
471472

472473
case $host in

0 commit comments

Comments
 (0)