123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354555657585960616263646566676869707172737475767778798081828384858687888990919293949596979899100101102103104105106107108109110111112113114115116117118119120121122123124125126127128129130131132133134135136137138139140141142143144145146147148149150151152153154155156157158159160161162163164165166167168169170171172173174175176177178179180181182183184185 |
- #***************************************************************************
- # _ _ ____ _
- # Project ___| | | | _ \| |
- # / __| | | | |_) | |
- # | (__| |_| | _ <| |___
- # \___|\___/|_| \_\_____|
- #
- # Copyright (C) Daniel Stenberg, <daniel@haxx.se>, et al.
- #
- # This software is licensed as described in the file COPYING, which
- # you should have received as part of this distribution. The terms
- # are also available at https://curl.se/docs/copyright.html.
- #
- # You may opt to use, copy, modify, merge, publish, distribute and/or sell
- # copies of the Software, and permit persons to whom the Software is
- # furnished to do so, under the terms of the COPYING file.
- #
- # This software is distributed on an "AS IS" basis, WITHOUT WARRANTY OF ANY
- # KIND, either express or implied.
- #
- # SPDX-License-Identifier: curl
- #
- #***************************************************************************
- AC_DEFUN([CURL_WITH_WOLFSSL], [
- dnl ----------------------------------------------------
- dnl check for wolfSSL
- dnl ----------------------------------------------------
- case "$OPT_WOLFSSL" in
- yes|no)
- wolfpkg=""
- ;;
- *)
- wolfpkg="$withval/lib/pkgconfig"
- ;;
- esac
- if test "x$OPT_WOLFSSL" != xno; then
- _cppflags=$CPPFLAGS
- _ldflags=$LDFLAGS
- ssl_msg=
- if test X"$OPT_WOLFSSL" != Xno; then
- if test "$OPT_WOLFSSL" = "yes"; then
- OPT_WOLFSSL=""
- fi
- dnl try pkg-config magic
- CURL_CHECK_PKGCONFIG(wolfssl, [$wolfpkg])
- AC_MSG_NOTICE([Check dir $wolfpkg])
- addld=""
- addlib=""
- addcflags=""
- if test "$PKGCONFIG" != "no" ; then
- addlib=`CURL_EXPORT_PCDIR([$wolfpkg])
- $PKGCONFIG --libs-only-l wolfssl`
- addld=`CURL_EXPORT_PCDIR([$wolfpkg])
- $PKGCONFIG --libs-only-L wolfssl`
- addcflags=`CURL_EXPORT_PCDIR([$wolfpkg])
- $PKGCONFIG --cflags-only-I wolfssl`
- version=`CURL_EXPORT_PCDIR([$wolfpkg])
- $PKGCONFIG --modversion wolfssl`
- wolfssllibpath=`echo $addld | $SED -e 's/^-L//'`
- else
- addlib=-lwolfssl
- dnl use system defaults if user does not supply a path
- if test -n "$OPT_WOLFSSL"; then
- addld=-L$OPT_WOLFSSL/lib$libsuff
- addcflags=-I$OPT_WOLFSSL/include
- wolfssllibpath=$OPT_WOLFSSL/lib$libsuff
- fi
- fi
- if test "x$USE_WOLFSSL" != "xyes"; then
- LDFLAGS="$LDFLAGS $addld"
- AC_MSG_NOTICE([Add $addld to LDFLAGS])
- if test "$addcflags" != "-I/usr/include"; then
- CPPFLAGS="$CPPFLAGS $addcflags"
- AC_MSG_NOTICE([Add $addcflags to CPPFLAGS])
- fi
- my_ac_save_LIBS="$LIBS"
- LIBS="$addlib $LIBS"
- AC_MSG_NOTICE([Add $addlib to LIBS])
- AC_MSG_CHECKING([for wolfSSL_Init in -lwolfssl])
- AC_LINK_IFELSE([
- AC_LANG_PROGRAM([[
- /* These are not needed for detection and confuse wolfSSL.
- They are set up properly later if it is detected. */
- #undef SIZEOF_LONG
- #undef SIZEOF_LONG_LONG
- #include <wolfssl/options.h>
- #include <wolfssl/ssl.h>
- ]],[[
- return wolfSSL_Init();
- ]])
- ],[
- AC_MSG_RESULT(yes)
- AC_DEFINE(USE_WOLFSSL, 1, [if wolfSSL is enabled])
- AC_SUBST(USE_WOLFSSL, [1])
- WOLFSSL_ENABLED=1
- USE_WOLFSSL="yes"
- ssl_msg="wolfSSL"
- QUIC_ENABLED=yes
- test wolfssl != "$DEFAULT_SSL_BACKEND" || VALID_DEFAULT_SSL_BACKEND=yes
- ],
- [
- AC_MSG_RESULT(no)
- CPPFLAGS=$_cppflags
- LDFLAGS=$_ldflags
- wolfssllibpath=""
- ])
- LIBS="$my_ac_save_LIBS"
- fi
- if test "x$USE_WOLFSSL" = "xyes"; then
- AC_MSG_NOTICE([detected wolfSSL])
- check_for_ca_bundle=1
- dnl wolfssl/ctaocrypt/types.h needs SIZEOF_LONG_LONG defined!
- CURL_SIZEOF(long long)
- LIBS="$addlib -lm $LIBS"
- dnl wolfSSL needs configure --enable-opensslextra to have *get_peer*
- dnl DES* is needed for NTLM support and lives in the OpenSSL compatibility
- dnl layer
- AC_CHECK_FUNCS(wolfSSL_get_peer_certificate \
- wolfSSL_UseALPN )
- dnl if this symbol is present, we want the include path to include the
- dnl OpenSSL API root as well
- AC_CHECK_FUNC(wolfSSL_DES_ecb_encrypt,
- [
- AC_DEFINE(HAVE_WOLFSSL_DES_ECB_ENCRYPT, 1,
- [if you have wolfSSL_DES_ecb_encrypt])
- WOLFSSL_NTLM=1
- ]
- )
- dnl if this symbol is present, we can make use of BIO filter chains
- AC_CHECK_FUNC(wolfSSL_BIO_new,
- [
- AC_DEFINE(HAVE_WOLFSSL_BIO, 1,
- [if you have wolfSSL_BIO_new])
- WOLFSSL_BIO=1
- ]
- )
- dnl if this symbol is present, we have the full BIO feature set
- AC_CHECK_FUNC(wolfSSL_BIO_set_shutdown,
- [
- AC_DEFINE(HAVE_WOLFSSL_FULL_BIO, 1,
- [if you have wolfSSL_BIO_set_shutdown])
- WOLFSSL_FULL_BIO=1
- ]
- )
- if test -n "$wolfssllibpath"; then
- dnl when shared libs were found in a path that the run-time
- dnl linker doesn't search through, we need to add it to
- dnl CURL_LIBRARY_PATH to prevent further configure tests to fail
- dnl due to this
- if test "x$cross_compiling" != "xyes"; then
- CURL_LIBRARY_PATH="$CURL_LIBRARY_PATH:$wolfssllibpath"
- export CURL_LIBRARY_PATH
- AC_MSG_NOTICE([Added $wolfssllibpath to CURL_LIBRARY_PATH])
- fi
- fi
- LIBCURL_PC_REQUIRES_PRIVATE="$LIBCURL_PC_REQUIRES_PRIVATE wolfssl"
- else
- AC_MSG_ERROR([--with-wolfssl but wolfSSL was not found or doesn't work])
- fi
- fi dnl wolfSSL not disabled
- test -z "$ssl_msg" || ssl_backends="${ssl_backends:+$ssl_backends, }$ssl_msg"
- fi
- ])
|