summaryrefslogtreecommitdiffstats
path: root/configure.ac
diff options
context:
space:
mode:
Diffstat (limited to 'configure.ac')
-rw-r--r--configure.ac2901
1 files changed, 2901 insertions, 0 deletions
diff --git a/configure.ac b/configure.ac
new file mode 100644
index 0000000..3d90a11
--- /dev/null
+++ b/configure.ac
@@ -0,0 +1,2901 @@
+##
+## Configure template file for FRRouting.
+## autoconf will generate a configure script.
+##
+## Copyright (c) 1996, 97, 98, 99, 2000 Kunihiro Ishiguro <kunihiro@zebra.org>
+## Portions Copyright (c) 2003 Paul Jakma <paul@dishone.st>
+##
+AC_PREREQ([2.69])
+
+AC_INIT([frr], [9.1], [https://github.com/frrouting/frr/issues])
+PACKAGE_URL="https://frrouting.org/"
+AC_SUBST([PACKAGE_URL])
+PACKAGE_FULLNAME="FRRouting"
+AC_SUBST([PACKAGE_FULLNAME])
+
+CONFIG_ARGS="`echo $ac_configure_args | sed -e \"s% '[[A-Z]]*FLAGS=[[^']]\+'%%g\"`"
+AC_SUBST([CONFIG_ARGS])
+
+AC_CONFIG_SRCDIR([lib/zebra.h])
+AC_CONFIG_MACRO_DIR([m4])
+AC_CONFIG_AUX_DIR([m4/ac])
+
+dnl -----------------------------------
+dnl Get hostname and other information.
+dnl -----------------------------------
+AC_CANONICAL_BUILD()
+AC_CANONICAL_HOST()
+
+AC_ARG_VAR([AR],[archiver command])
+AC_ARG_VAR([LD],[linker command])
+AC_ARG_VAR([OBJCOPY],[objcopy command])
+AC_ARG_VAR([OBJDUMP],[objdump command])
+AC_ARG_VAR([RANLIB],[ranlib command])
+AC_ARG_VAR([STRIP],[strip command])
+
+hosttools_clippy="false"
+build_clippy="true"
+
+dnl case 1: external clippy
+if test -n "$with_clippy" -a "$with_clippy" != "no" -a "$with_clippy" != "yes"; then
+ if test "$enable_clippy_only" = "yes"; then
+ AC_MSG_ERROR([--enable-clippy-only does not make sense with --with-clippy])
+ fi
+
+ CLIPPY="$with_clippy"
+ build_clippy="false"
+ if test ! -x "$with_clippy"; then
+ AC_MSG_ERROR([clippy tool ($with_clippy) is not executable])
+ fi
+
+dnl case 2: cross-compiling internal clippy
+elif test "$host" != "$build"; then
+ if test "$srcdir" = "."; then
+ AC_MSG_ERROR([cross-compilation is only possible with builddir separate from srcdir or by building clippy separately and using the --with-clippy option. create a separate directory and run as .../path-to-frr/configure.])
+ fi
+ test -d hosttools || mkdir hosttools
+ abssrc="`cd \"${srcdir}\"; pwd`"
+
+ AC_MSG_NOTICE([...])
+ AC_MSG_NOTICE([... cross-compilation: creating hosttools directory and self-configuring for build platform tools])
+ AC_MSG_NOTICE([... use HOST_CPPFLAGS / HOST_CFLAGS / HOST_LDFLAGS if necessary])
+ AC_MSG_NOTICE([...])
+
+ (
+ for var in $ac_precious_vars; do
+ dnl special cases
+ case "$var" in
+ YACC|YFLAGS) continue;;
+ PYTHON*) retain=true;;
+ *) retain=false;
+ esac
+
+ eval "hostvar=\"\${HOST_$var}\""
+ eval "targetvar=\"\${$var}\""
+ if test -n "$hostvar"; then
+ eval "$var='$hostvar'"
+ _AS_ECHO_LOG([host $var='$hostvar'])
+ elif $retain; then
+ _AS_ECHO_LOG([host retain $var='$targetvar'])
+ else
+ eval "unset $var"
+ _AS_ECHO_LOG([host unset $var])
+ fi
+ done
+ cd hosttools
+ "${abssrc}/configure" "--host=$build" "--build=$build" "--enable-clippy-only" "--disable-nhrpd" "--disable-vtysh"
+ ) || exit 1
+
+ AC_MSG_NOTICE([...])
+ AC_MSG_NOTICE([... cross-compilation: finished self-configuring for build platform tools])
+ AC_MSG_NOTICE([...])
+
+ build_clippy="false"
+ hosttools_clippy="true"
+ CLIPPY="hosttools/lib/clippy"
+
+dnl case 3: normal build internal clippy
+else
+ CLIPPY="lib/clippy\$(EXEEXT)"
+fi
+AC_SUBST([CLIPPY])
+AM_CONDITIONAL([BUILD_CLIPPY], [$build_clippy])
+AM_CONDITIONAL([HOSTTOOLS_CLIPPY], [$hosttools_clippy])
+AM_CONDITIONAL([ONLY_CLIPPY], [test "$enable_clippy_only" = "yes"])
+
+# Disable portability warnings -- our automake code (in particular
+# common.am) uses some constructs specific to gmake.
+AM_INIT_AUTOMAKE([1.12 -Wno-portability foreign])
+m4_ifndef([AM_SILENT_RULES], [m4_define([AM_SILENT_RULES],[])])
+AM_SILENT_RULES([yes])
+AC_CONFIG_HEADERS([config.h])
+
+AC_PATH_PROG([PERL], [perl])
+PKG_PROG_PKG_CONFIG
+
+dnl default is to match previous behavior
+pkgsrcrcdir=""
+AC_ARG_ENABLE([pkgsrcrcdir],
+ AS_HELP_STRING([--enable-pkgsrcrcdir],
+ [specify directory for rc.d scripts]),
+ pkgsrcrcdir="$enableval",)
+dnl XXX add --pkgsrcrcdir to autoconf standard directory list somehow
+AC_SUBST([pkgsrcrcdir])
+AM_CONDITIONAL([PKGSRC], [test "$pkgsrcrcdir" != ""])
+
+AC_ARG_WITH([moduledir], [AS_HELP_STRING([--with-moduledir=DIR], [module directory (${libdir}/frr/modules)])], [
+ moduledir="$withval"
+], [
+ moduledir="\${libdir}/frr/modules"
+])
+AC_SUBST([moduledir], [$moduledir])
+
+AC_ARG_WITH([scriptdir], [AS_HELP_STRING([--with-scriptdir=DIR], [script directory (${sysconfdir}/scripts)])], [
+ scriptdir="$withval"
+], [
+ scriptdir="\${sysconfdir}/scripts"
+])
+AC_SUBST([scriptdir], [$scriptdir])
+
+AC_ARG_WITH([yangmodelsdir], [AS_HELP_STRING([--with-yangmodelsdir=DIR], [yang models directory (${datarootdir}/yang)])], [
+ yangmodelsdir="$withval"
+], [
+ yangmodelsdir="\${datarootdir}/yang"
+])
+AC_SUBST([yangmodelsdir])
+
+AC_ARG_WITH([vici-socket], [AS_HELP_STRING([--with-vici-socket=PATH], [vici-socket (/var/run/charon.vici)])], [
+ vici_socket="$withval"
+], [
+ vici_socket="/var/run/charon.vici"
+])
+AC_DEFINE_UNQUOTED([VICI_SOCKET], ["$vici_socket"], [StrongSWAN vici socket path])
+
+AC_ARG_ENABLE(tcmalloc,
+ AS_HELP_STRING([--enable-tcmalloc], [Turn on tcmalloc]),
+[case "${enableval}" in
+ yes) tcmalloc_enabled=true
+LIBS="$LIBS -ltcmalloc_minimal"
+ ;;
+ no) tcmalloc_enabled=false ;;
+ *) AC_MSG_ERROR([bad value ${enableval} for --enable-tcmalloc]) ;;
+esac],[tcmalloc_enabled=false])
+
+
+dnl Thanks autoconf, but we don't want a default -g -O2. We have our own
+dnl flag determination logic.
+CFLAGS="${CFLAGS:-}"
+
+dnl --------------------
+dnl Check CC and friends
+dnl --------------------
+dnl note orig_cflags is also used further down
+orig_cflags="$CFLAGS"
+orig_cxxflags="$CXXFLAGS"
+AC_LANG([C])
+AC_PROG_CC
+AC_PROG_CPP
+AC_PROG_CXX
+AM_PROG_CC_C_O
+dnl remove autoconf default "-g -O2"
+CFLAGS="$orig_cflags"
+CXXFLAGS="$orig_cxxflags"
+
+dnl Some special handling for ICC later on
+if test "$CC" = "icc"; then
+ cc_is_icc="yes"
+fi
+
+PKG_PROG_PKG_CONFIG
+
+dnl it's 2019, sed is sed.
+SED=sed
+AC_SUBST([SED])
+
+dnl try and enable CFLAGS that are useful for FRR
+dnl - specifically, options to control warnings
+
+AC_SUBST([AC_CFLAGS])
+AC_USE_SYSTEM_EXTENSIONS
+AC_DEFUN([AC_C_FLAG], [{
+ m4_pushdef([cachename],[m4_translit([frr_cv_$1],[ =-+/{}$],[________])])
+ AC_CACHE_CHECK([[whether $CC supports $1]], cachename, [
+ AC_LANG_PUSH([C])
+ ac_c_flag_save="$CFLAGS"
+ CFLAGS="$CFLAGS $1"
+ AC_COMPILE_IFELSE(
+ [AC_LANG_PROGRAM([[$4]])],
+ [
+ cachename=yes
+ ], [
+ cachename=no
+ ])
+ CFLAGS="$ac_c_flag_save"
+ AC_LANG_POP([C])
+ ])
+ if test "$cachename" = "yes"; then
+ m4_if([$3], [], [AC_CFLAGS="$AC_CFLAGS $1"], [$3])
+ else
+ :
+ $2
+ fi
+ m4_popdef([cachename])
+}])
+
+AC_DEFUN([AC_LINK_IFELSE_FLAGS], [{
+ AC_LANG_PUSH([C])
+ ac_cflags_save="$CFLAGS"
+ ac_libs_save="$LIBS"
+ CFLAGS="$CFLAGS $1"
+ LIBS="$LIBS $2"
+ AC_LINK_IFELSE(
+ [$3],
+ [
+ CFLAGS="$ac_cflags_save"
+ LIBS="$ac_libs_save"
+ m4_default([$5], [
+ AC_MSG_RESULT([yes])
+ ])
+ ], [
+ CFLAGS="$ac_cflags_save"
+ LIBS="$ac_libs_save"
+ m4_default([$4], [
+ AC_MSG_RESULT([no])
+ ])
+ ])
+ AC_LANG_POP([C])
+ }])
+
+dnl ICC won't bail on unknown options without -diag-error 10006
+dnl need to do this first so we get useful results for the other options
+if test "$cc_is_icc" = "yes"; then
+ AC_C_FLAG([-diag-error 10006])
+fi
+
+dnl autoconf 2.69 AC_PROG_CC_C99 is "state of the art"
+dnl autoconf 2.70 AC_PROG_CC_C99 is deprecated and AC_PROC_CC tries to do C11
+m4_if(m4_version_compare(m4_defn([AC_AUTOCONF_VERSION]), [2.70]), [-1], [dnl
+ dnl autoconf < 2.70
+ AC_PROG_CC_C99
+
+ dnl AC_PROG_CC_C99 may change CC to include -std=gnu99 or something
+ ac_cc="$CC"
+ CC="${CC% -std=gnu99}"
+ CC="${CC% -std=c99}"
+
+ AC_C_FLAG([-std=gnu11], [CC="$ac_cc"], [CC="$CC -std=gnu11"])
+], [
+ dnl autoconf >= 2.70
+ if test "$ac_cv_prog_cc_c11" = "no"; then
+ AC_MSG_ERROR([ISO C11 compiler support (with GNU extensions) is required.])
+ fi
+])
+
+dnl if the user has specified any CFLAGS, override our settings
+if test "$enable_gcov" = "yes"; then
+ if test "$orig_cflags" = ""; then
+ AC_C_FLAG([--coverage])
+ AC_C_FLAG([-O0])
+ fi
+
+ AC_LDFLAGS="${AC_LDFLAGS} --coverage"
+fi
+
+if test "$enable_clang_coverage" = "yes"; then
+ AC_C_FLAG([-fprofile-instr-generate], [
+ AC_MSG_ERROR([$CC does not support -fprofile-instr-generate.])
+ ])
+ AC_C_FLAG([-fcoverage-mapping], [
+ AC_MSG_ERROR([$CC does not support -fcoverage-mapping.])
+ ])
+fi
+
+AM_CONDITIONAL([SCRIPTING], [test "$enable_scripting" = "yes"])
+
+if test "$enable_scripting" = "yes"; then
+ AX_PROG_LUA([5.3], [5.4], [], [
+ AC_MSG_ERROR([Lua 5.3 is required to build with Lua support. No other version is supported.])
+ ])
+ AX_LUA_HEADERS([], [
+ AC_MSG_ERROR([Lua 5.3 headers are required to build with Lua support. No other version is supported.])
+ ])
+ PKG_CHECK_MODULES([LUA], [lua5.3], [
+ AC_DEFINE([HAVE_SCRIPTING], [1], [Have support for scripting])
+ LIBS="$LIBS $LUA_LIBS"
+ SCRIPTING=true
+ ], [
+ AX_LUA_LIBS([
+ AC_DEFINE([HAVE_SCRIPTING], [1], [Have support for scripting])
+ LIBS="$LIBS $LUA_LIB"
+ SCRIPTING=true
+ ], [
+ SCRIPTING=false
+ AC_MSG_ERROR([Lua 5.3 libraries are required to build with Lua support. No other version is supported.])
+ ])
+ ])
+fi
+
+dnl the following flags go in CFLAGS rather than AC_CFLAGS since they make
+dnl sense to be overridden by the user
+if test "$enable_dev_build" = "yes"; then
+ AC_DEFINE([DEV_BUILD], [1], [Build for development])
+ if test "$orig_cflags" = ""; then
+ AC_C_FLAG([-O0],,[CFLAGS="$CFLAGS -O0"])
+ AC_C_FLAG([-g3],,[CFLAGS="$CFLAGS -g3"])
+ AC_C_FLAG([-ggdb3],,[CFLAGS="$CFLAGS -ggdb3"])
+ fi
+else
+ if test "$orig_cflags" = ""; then
+ AC_C_FLAG([-g],,[CFLAGS="$CFLAGS -g"])
+ AC_C_FLAG([-O2],,[CFLAGS="$CFLAGS -O2"])
+ fi
+fi
+
+dnl just stick -g into LDFLAGS, if we don't have it in CFLAGS it won't do much
+LDFLAGS="$LDFLAGS -g"
+
+AM_CONDITIONAL([DEV_BUILD], [test "$enable_dev_build" = "yes"])
+
+dnl -fms-extensions causes clang to have a built-in __wchar_t on OpenBSD,
+dnl which just straight up breaks compiling any code.
+dnl (2022-04-04 / OpenBSD 7 / clang 11.1.0)
+AH_VERBATIM([OpenBSD], [
+#ifdef __OpenBSD__
+#define __wchar_t __wchar_t_ignore
+#include <stdint.h>
+#undef __wchar_t
+#endif
+])
+
+dnl always want these CFLAGS
+AC_C_FLAG([-fms-extensions], [
+ AC_MSG_ERROR([$CC does not support unnamed struct fields (-fms-extensions)])
+])
+AC_C_FLAG([-fno-omit-frame-pointer])
+AC_C_FLAG([-funwind-tables])
+AC_C_FLAG([-Wall])
+AC_C_FLAG([-Wextra])
+AC_C_FLAG([-Wformat-nonliteral])
+AC_C_FLAG([-Wformat-security])
+AC_C_FLAG([-Wswitch-enum])
+AC_C_FLAG([-Wstrict-prototypes])
+AC_C_FLAG([-Wmissing-prototypes])
+AC_C_FLAG([-Wmissing-declarations])
+AC_C_FLAG([-Wpointer-arith])
+AC_C_FLAG([-Wbad-function-cast])
+AC_C_FLAG([-Wwrite-strings])
+AC_C_FLAG([-Wundef])
+if test "$enable_gcc_ultra_verbose" = "yes" ; then
+ AC_C_FLAG([-Wcast-qual])
+ AC_C_FLAG([-Wmissing-noreturn])
+ AC_C_FLAG([-Wmissing-format-attribute])
+ AC_C_FLAG([-Wunreachable-code])
+ AC_C_FLAG([-Wpacked])
+ AC_C_FLAG([-Wpadded])
+ AC_C_FLAG([-Wshadow])
+else
+ AC_C_FLAG([-Wno-unused-result])
+fi
+AC_C_FLAG([-Wno-unused-parameter])
+AC_C_FLAG([-Wno-missing-field-initializers])
+
+AC_C_FLAG([-Wc++-compat], [], [CXX_COMPAT_CFLAGS="-Wc++-compat"])
+AC_SUBST([CXX_COMPAT_CFLAGS])
+
+dnl ICC emits a broken warning for const char *x = a ? "b" : "c";
+dnl for some reason the string consts get 'promoted' to char *,
+dnl triggering a const to non-const conversion warning.
+if test "$cc_is_icc" = "yes"; then
+ AC_C_FLAG([-diag-disable 3179])
+fi
+
+if test "$enable_werror" = "yes" ; then
+ WERROR="-Werror"
+fi
+AC_SUBST([WERROR])
+
+SAN_FLAGS=""
+if test "$enable_address_sanitizer" = "yes"; then
+ AC_C_FLAG([-fsanitize=address], [
+ AC_MSG_ERROR([$CC does not support Address Sanitizer.])
+ ], [
+ SAN_FLAGS="$SAN_FLAGS -fsanitize=address"
+ ])
+fi
+if test "$enable_thread_sanitizer" = "yes"; then
+ AC_C_FLAG([-fsanitize=thread], [
+ AC_MSG_ERROR([$CC does not support Thread Sanitizer.])
+ ], [
+ SAN_FLAGS="$SAN_FLAGS -fsanitize=thread"
+ ])
+fi
+if test "$enable_memory_sanitizer" = "yes"; then
+ AC_C_FLAG([-fsanitize=memory -fPIE -pie], [
+ AC_MSG_ERROR([$CC does not support Memory Sanitizer.])
+ ], [
+ SAN_FLAGS="$SAN_FLAGS -fsanitize=memory -fPIE -pie"
+ ])
+fi
+if test "$enable_undefined_sanitizer" = "yes"; then
+ AC_C_FLAG([-fsanitize=undefined], [
+ AC_MSG_ERROR([$CC does not support UndefinedBehaviorSanitizer.])
+ ], [
+ SAN_FLAGS="$SAN_FLAGS -fsanitize=undefined"
+ ])
+fi
+AC_SUBST([SAN_FLAGS])
+
+dnl frr-format.so
+if test "$with_frr_format" != "no" -a "$with_frr_format" != "yes" -a -n "$with_frr_format"; then
+ AC_C_FLAG([-fplugin=${with_frr_format}], [
+ AC_MSG_ERROR([specified frr-format plugin ($with_frr_format) does not work])
+ ],,[
+#ifndef _FRR_ATTRIBUTE_PRINTFRR
+#error plugin not loaded
+#endif
+#if _FRR_ATTRIBUTE_PRINTFRR < 0x10000
+#error plugin too old
+#endif
+ ])
+elif test "$with_frr_format" = "no"; then
+ : #nothing
+else
+ AC_C_FLAG([-fplugin=tools/gcc-plugins/frr-format.so],[
+ AC_C_FLAG([-fplugin=frr-format],[
+ if test "$with_frr_format" = "yes"; then
+ AC_MSG_ERROR([frr-format plugin requested but not found])
+ fi
+ ],,[
+#ifndef _FRR_ATTRIBUTE_PRINTFRR
+#error plugin not loaded
+#endif
+#if _FRR_ATTRIBUTE_PRINTFRR < 0x10000
+#error plugin too old
+#endif
+ ])
+ ],,[
+#ifndef _FRR_ATTRIBUTE_PRINTFRR
+#error plugin not loaded
+#endif
+#if _FRR_ATTRIBUTE_PRINTFRR < 0x10000
+#error plugin too old
+#endif
+ ])
+fi
+
+AC_MSG_CHECKING([whether linker supports __start/stop_section symbols])
+AC_LINK_IFELSE([AC_LANG_PROGRAM([[
+#include <stdio.h>
+int __attribute__((section("secttest"))) var = 1;
+extern int __start_secttest, __stop_secttest;
+]], [[
+ void *a = &var, *b = &__start_secttest, *c = &__stop_secttest;
+ printf("%p %p %p\n", a, b, c);
+]])], [
+ AC_MSG_RESULT(yes)
+ AC_DEFINE(HAVE_SECTION_SYMS, 1, [have __start/stop_section symbols])
+], [
+ AC_MSG_RESULT(no)
+])
+
+dnl ----------
+dnl Essentials
+dnl ----------
+
+AX_PTHREAD([
+ CC="$PTHREAD_CC"
+ AC_CFLAGS="$AC_CFLAGS $PTHREAD_CFLAGS"
+ LIBS="$PTHREAD_LIBS $LIBS"
+], [
+ AC_MSG_FAILURE([This FRR version needs pthreads])
+])
+
+orig_cflags="$CFLAGS"
+CFLAGS="$CFLAGS $PTHREAD_CFLAGS"
+
+AC_SEARCH_LIBS([pthread_condattr_setclock], [],
+ [frr_cv_pthread_condattr_setclock=yes],
+ [frr_cv_pthread_condattr_setclock=no])
+if test "$frr_cv_pthread_condattr_setclock" = "yes"; then
+ AC_DEFINE([HAVE_PTHREAD_CONDATTR_SETCLOCK], [1], [Have pthread.h pthread_condattr_setclock])
+fi
+
+AC_CHECK_HEADERS([pthread_np.h],,, [
+#include <pthread.h>
+])
+AC_CHECK_FUNCS([pthread_setname_np pthread_set_name_np pthread_getthreadid_np])
+
+CFLAGS="$orig_cflags"
+
+dnl --------------
+dnl Check programs
+dnl --------------
+AC_PROG_INSTALL
+AC_PROG_LN_S
+AC_CHECK_TOOL([AR], [ar])
+
+dnl -------
+dnl libtool
+dnl -------
+AC_ARG_ENABLE([static-bin],
+ AS_HELP_STRING([--enable-static-bin], [link binaries statically]))
+LT_INIT
+_LT_CONFIG_LIBTOOL([
+ patch -N -i "${srcdir}/m4/libtool-whole-archive.patch" libtool >&AS_MESSAGE_LOG_FD || \
+ AC_MSG_WARN([Could not patch libtool for static linking support. Loading modules into a statically linked daemon will fail.])
+dnl the -i option is not POSIX sed and the BSDs implement it differently
+dnl cat'ing the output back instead of mv/cp keeps permissions on libtool intact
+ sed -e 's%func_warning "relinking%true #\0%' libtool > libtool.sed && cat libtool.sed > libtool
+ sed -e 's%func_warning "remember to run%true #\0%' libtool > libtool.sed && cat libtool.sed > libtool
+ sed -e 's%func_warning ".*has not been installed in%true #\0%' libtool > libtool.sed && cat libtool.sed > libtool
+ test -f libtool.sed && rm libtool.sed
+])
+if test "$enable_static_bin" = "yes"; then
+ AC_LDFLAGS_EXEC="-static"
+ if test "$enable_static" != "yes"; then
+ AC_MSG_ERROR([The --enable-static-bin option must be combined with --enable-static.])
+ fi
+fi
+if test "$enable_shared" != "yes"; then
+ AC_MSG_ERROR([FRR cannot be built with --disable-shared. If you want statically linked daemons, use --enable-shared --enable-static --enable-static-bin])
+fi
+AC_SUBST([AC_LDFLAGS])
+AC_SUBST([AC_LDFLAGS_EXEC])
+AM_CONDITIONAL([STATIC_BIN], [test "$enable_static_bin" = "yes"])
+
+dnl libtool, the repository of all knowledge related linkers, is too stupid to
+dnl correctly tell the linker how to build modules.
+if test -z "$module_cmds"; then
+ module_cmds="`echo \"$archive_cmds\" | sed -e 's%$wl-soname $wl$soname%%'`"
+fi
+if test -z "$module_expsym_cmds"; then
+ module_expsym_cmds="`echo \"$archive_expsym_cmds\" | sed -e 's%$wl-soname $wl$soname%%'`"
+fi
+
+AC_ARG_ENABLE([rpath],
+ [AS_HELP_STRING([--enable-rpath], [set hardcoded rpaths in the executable @<:@default=yes@:>@])],
+ [],
+ [enable_rpath=yes])
+
+dnl $AR and $RANLIB are set by LT_INIT above
+AC_MSG_CHECKING([whether $AR supports D option])
+if $AR crD conftest.a >/dev/null 2>/dev/null; then
+ AC_MSG_RESULT([yes])
+ dnl ARFLAGS is for automake, AR_FLAGS for libtool m-(
+ ARFLAGS="crD"
+ AR_FLAGS="crD"
+else
+ AC_MSG_RESULT([no])
+ ARFLAGS="cru"
+ AR_FLAGS="cru"
+fi
+AC_SUBST([ARFLAGS])
+AC_SUBST([AR_FLAGS])
+
+AC_MSG_CHECKING([whether $RANLIB supports D option])
+if $RANLIB -D conftest.a >conftest.err 2>&1; then
+ if grep -q -- '-D' conftest.err; then
+ AC_MSG_RESULT([no])
+ else
+ AC_MSG_RESULT([yes])
+ RANLIB="$RANLIB -D"
+ fi
+else
+ AC_MSG_RESULT([no])
+fi
+AC_SUBST([RANLIB])
+
+test -f conftest.err && rm conftest.err
+test -f conftest.a && rm conftest.a
+
+dnl ----------------------
+dnl Packages configuration
+dnl ----------------------
+if test -f config.version; then
+ . ./config.version
+elif test -f "${srcdir}/config.version"; then
+ . "${srcdir}/config.version"
+fi
+AC_ARG_WITH([pkg-extra-version],
+ AS_HELP_STRING([--with-pkg-extra-version=VER], [add extra version field, for packagers/distributions]), [
+ if test "$withval" = "no"; then
+ EXTRAVERSION=
+ else
+ EXTRAVERSION=$withval
+ fi
+], [])
+AC_ARG_WITH([pkg-git-version],
+ AS_HELP_STRING([--with-pkg-git-version], [add git information to MOTD and build version string]),
+ [ test "$withval" != "no" && with_pkg_git_version="yes" ])
+AC_ARG_WITH([clippy],
+ AS_HELP_STRING([--with-clippy=PATH], [use external clippy helper program]))
+AC_ARG_WITH([vtysh_pager],
+ AS_HELP_STRING([--with-vtysh-pager=PAGER], [control what pager is compiled in as default]),
+ VTYSH_PAGER=$withval, VTYSH_PAGER="more")
+AC_ARG_ENABLE([vtysh],
+ AS_HELP_STRING([--disable-vtysh], [do not build integrated vty shell for FRR]))
+AC_ARG_ENABLE([doc],
+ AS_HELP_STRING([--disable-doc], [do not build docs]))
+AC_ARG_ENABLE([doc-html],
+ AS_HELP_STRING([--enable-doc-html], [build HTML docs]))
+AC_ARG_ENABLE([zebra],
+ AS_HELP_STRING([--disable-zebra], [do not build zebra daemon]))
+AC_ARG_ENABLE([bgpd],
+ AS_HELP_STRING([--disable-bgpd], [do not build bgpd]))
+AC_ARG_ENABLE([mgmtd],
+ AS_HELP_STRING([--disable-mgmtd], [do not build mgmtd]))
+AC_ARG_ENABLE([mgmtd_local_validations],
+ AS_HELP_STRING([--enable-mgmtd-local-validations], [dev: unimplemented local validation]))
+AC_ARG_ENABLE([ripd],
+ AS_HELP_STRING([--disable-ripd], [do not build ripd]))
+AC_ARG_ENABLE([ripngd],
+ AS_HELP_STRING([--disable-ripngd], [do not build ripngd]))
+AC_ARG_ENABLE([ospfd],
+ AS_HELP_STRING([--disable-ospfd], [do not build ospfd]))
+AC_ARG_ENABLE([ospf6d],
+ AS_HELP_STRING([--disable-ospf6d], [do not build ospf6d]))
+AC_ARG_ENABLE([ldpd],
+ AS_HELP_STRING([--disable-ldpd], [do not build ldpd]))
+AC_ARG_ENABLE([nhrpd],
+ AS_HELP_STRING([--disable-nhrpd], [do not build nhrpd]))
+AC_ARG_ENABLE([eigrpd],
+ AS_HELP_STRING([--disable-eigrpd], [do not build eigrpd]))
+AC_ARG_ENABLE([babeld],
+ AS_HELP_STRING([--disable-babeld], [do not build babeld]))
+AC_ARG_ENABLE([watchfrr],
+ AS_HELP_STRING([--disable-watchfrr], [do not build watchfrr]))
+AC_ARG_ENABLE([isisd],
+ AS_HELP_STRING([--disable-isisd], [do not build isisd]))
+AC_ARG_ENABLE([pimd],
+ AS_HELP_STRING([--disable-pimd], [do not build pimd]))
+AC_ARG_ENABLE([pim6d],
+ AS_HELP_STRING([--disable-pim6d], [do not build pim6d]))
+AC_ARG_ENABLE([pbrd],
+ AS_HELP_STRING([--disable-pbrd], [do not build pbrd]))
+AC_ARG_ENABLE([sharpd],
+ AS_HELP_STRING([--enable-sharpd], [build sharpd]))
+AC_ARG_ENABLE([staticd],
+ AS_HELP_STRING([--disable-staticd], [do not build staticd]))
+AC_ARG_ENABLE([fabricd],
+ AS_HELP_STRING([--disable-fabricd], [do not build fabricd]))
+AC_ARG_ENABLE([vrrpd],
+ AS_HELP_STRING([--disable-vrrpd], [do not build vrrpd]))
+AC_ARG_ENABLE([pathd],
+ AS_HELP_STRING([--disable-pathd], [do not build pathd]))
+AC_ARG_ENABLE([bgp-announce],
+ AS_HELP_STRING([--disable-bgp-announce], [turn off BGP route announcement]))
+AC_ARG_ENABLE([bgp-vnc],
+ AS_HELP_STRING([--disable-bgp-vnc],[turn off BGP VNC support]))
+AC_ARG_ENABLE([bgp-bmp],
+ AS_HELP_STRING([--disable-bgp-bmp],[turn off BGP BMP support]))
+AC_ARG_ENABLE([snmp],
+ AS_HELP_STRING([--enable-snmp], [enable SNMP support for agentx]))
+AC_ARG_ENABLE([config_rollbacks],
+ AS_HELP_STRING([--enable-config-rollbacks], [enable configuration rollbacks (requires sqlite3)]))
+AC_ARG_ENABLE([confd],
+ AS_HELP_STRING([--enable-confd=ARG], [enable confd integration]))
+AC_ARG_ENABLE([sysrepo],
+ AS_HELP_STRING([--enable-sysrepo], [enable sysrepo integration]))
+AC_ARG_ENABLE([grpc],
+ AS_HELP_STRING([--enable-grpc], [enable the gRPC northbound plugin]))
+AC_ARG_ENABLE([zeromq],
+ AS_HELP_STRING([--enable-zeromq], [enable ZeroMQ handler (libfrrzmq)]))
+AC_ARG_ENABLE([lttng],
+ AS_HELP_STRING([--enable-lttng], [enable LTTng tracing]))
+AC_ARG_ENABLE([usdt],
+ AS_HELP_STRING([--enable-usdt], [enable USDT probes]))
+AC_ARG_WITH([libpam],
+ AS_HELP_STRING([--with-libpam], [use libpam for PAM support in vtysh]))
+AC_ARG_ENABLE([ospfapi],
+ AS_HELP_STRING([--disable-ospfapi], [do not build OSPFAPI to access the OSPF LSA Database]))
+AC_ARG_ENABLE([ospfclient],
+ AS_HELP_STRING([--disable-ospfclient], [do not build OSPFAPI client for OSPFAPI,
+ (this is the default if --disable-ospfapi is set)]))
+AC_ARG_WITH([log_timestamp_precision],
+ AS_HELP_STRING([--with-log-timestamp-precision=ARG], [set startup log timestamp precision, ARG must be 0-12]))
+AC_ARG_ENABLE([multipath],
+ AS_HELP_STRING([--enable-multipath=ARG], [enable multipath function, ARG must be digit]))
+AC_ARG_WITH([service_timeout],
+ AS_HELP_STRING([--with-service-timeout=ARG], [set service timeout value (2 minutes by default), ARG must be digit]))
+AC_ARG_ENABLE([user],
+ AS_HELP_STRING([--enable-user=USER], [user to run FRR suite as (default frr)]))
+AC_ARG_ENABLE([group],
+ AS_HELP_STRING([--enable-group=GROUP], [group to run FRR suite as (default frr)]))
+AC_ARG_ENABLE([vty_group],
+ AS_HELP_STRING([--enable-vty-group=ARG], [set vty sockets to have specified group as owner]))
+AC_ARG_ENABLE([configfile_mask],
+ AS_HELP_STRING([--enable-configfile-mask=ARG], [set mask for config files]))
+AC_ARG_ENABLE([logfile_mask],
+ AS_HELP_STRING([--enable-logfile-mask=ARG], [set mask for log files]))
+AC_ARG_ENABLE([shell_access],
+ AS_HELP_STRING([--enable-shell-access], [Allow users to access shell/telnet/ssh]))
+AC_ARG_ENABLE([realms],
+ AS_HELP_STRING([--enable-realms], [enable REALMS support under Linux]))
+AC_ARG_ENABLE([rtadv],
+ AS_HELP_STRING([--disable-rtadv], [disable IPV6 router advertisement feature]))
+AC_ARG_ENABLE([irdp],
+ AS_HELP_STRING([--disable-irdp], [disable IRDP server support in zebra (enabled by default if supported)]))
+AC_ARG_ENABLE([capabilities],
+ AS_HELP_STRING([--disable-capabilities], [disable using POSIX capabilities]))
+AC_ARG_ENABLE([gcc_ultra_verbose],
+ AS_HELP_STRING([--enable-gcc-ultra-verbose], [enable ultra verbose GCC warnings]))
+AC_ARG_ENABLE([backtrace],
+ AS_HELP_STRING([--disable-backtrace], [disable crash backtraces (default autodetect)]))
+AC_ARG_ENABLE([pcreposix],
+ AS_HELP_STRING([--enable-pcreposix], [enable using PCRE Posix libs for regex functions]))
+AC_ARG_ENABLE([pcre2posix],
+ AS_HELP_STRING([--enable-pcre2posix], [enable using PCRE2 Posix libs for regex functions]))
+AC_ARG_ENABLE([fpm],
+ AS_HELP_STRING([--enable-fpm], [enable Forwarding Plane Manager support]))
+AC_ARG_ENABLE([werror],
+ AS_HELP_STRING([--enable-werror], [enable -Werror (recommended for developers only)]))
+AC_ARG_ENABLE([cumulus],
+ AS_HELP_STRING([--enable-cumulus], [enable Cumulus Switch Special Extensions]))
+AC_ARG_ENABLE([datacenter],
+ AS_HELP_STRING([--enable-datacenter], [enable Compilation for Data Center Extensions]))
+AC_ARG_ENABLE([protobuf],
+ AS_HELP_STRING([--enable-protobuf], [Enable experimental protobuf support]))
+AC_ARG_ENABLE([oldvpn_commands],
+ AS_HELP_STRING([--enable-oldvpn-commands], [Keep old vpn commands]))
+AC_ARG_ENABLE([rpki],
+ AS_HELP_STRING([--enable-rpki], [enable RPKI prefix validation support]))
+AC_ARG_ENABLE([clippy-only],
+ AS_HELP_STRING([--enable-clippy-only], [Only build clippy]))
+AC_ARG_ENABLE([numeric_version],
+ AS_HELP_STRING([--enable-numeric-version], [Only numeric digits allowed in version (for Alpine)]))
+AC_ARG_ENABLE([gcov],
+ AS_HELP_STRING([--enable-gcov], [Collect coverage information with gcov]))
+AC_ARG_ENABLE([clang_coverage],
+ AS_HELP_STRING([--enable-clang-coverage], [Collect coverage information with Clang Coverage]))
+AC_ARG_ENABLE([bfdd],
+ AS_HELP_STRING([--disable-bfdd], [do not build bfdd]))
+AC_ARG_ENABLE([address-sanitizer],
+ AS_HELP_STRING([--enable-address-sanitizer], [enable AddressSanitizer support for detecting a wide variety of memory allocation and deallocation errors]))
+AC_ARG_ENABLE([thread-sanitizer],
+ AS_HELP_STRING([--enable-thread-sanitizer], [enable ThreadSanitizer support for detecting data races]))
+AC_ARG_ENABLE([memory-sanitizer],
+ AS_HELP_STRING([--enable-memory-sanitizer], [enable MemorySanitizer support for detecting uninitialized memory reads]))
+AC_ARG_ENABLE([undefined-sanitizer],
+ AS_HELP_STRING([--enable-undefined-sanitizer], [enable UndefinedBehaviorSanitizer support for detecting undefined behavior]))
+AC_ARG_WITH([crypto],
+ AS_HELP_STRING([--with-crypto=<internal|openssl>], [choose between different implementations of cryptographic functions(default value is --with-crypto=internal)]))
+AC_ARG_WITH([frr-format],
+ AS_HELP_STRING([--with-frr-format[=<.../frr-format.so>]], [use frr-format GCC plugin]))
+
+AC_ARG_ENABLE([version-build-config],
+ AS_HELP_STRING([--disable-version-build-config], [do not include build configs in show version command]))
+
+#if openssl, else use the internal
+AS_IF([test "$with_crypto" = "openssl"], [
+AC_CHECK_LIB([crypto], [EVP_DigestInit], [LIBS="$LIBS -lcrypto"], [], [])
+if test "$ac_cv_lib_crypto_EVP_DigestInit" = "no"; then
+ AC_MSG_ERROR([build with openssl has been specified but openssl library was not found on your system])
+else
+ AC_DEFINE([CRYPTO_OPENSSL], [1], [Compile with openssl support])
+fi
+], [test "$with_crypto" = "internal" || test "$with_crypto" = "" ], [AC_DEFINE([CRYPTO_INTERNAL], [1], [Compile with internal cryptographic implementation])
+], [AC_MSG_ERROR([Unknown value for --with-crypto])]
+)
+
+AS_IF([test "$enable_clippy_only" != "yes"], [
+AC_CHECK_HEADERS([json-c/json.h])
+AC_CHECK_LIB([json-c], [json_object_get], [LIBS="$LIBS -ljson-c"], [], [-lm])
+if test "$ac_cv_lib_json_c_json_object_get" = "no"; then
+ AC_CHECK_LIB([json], [json_object_get], [LIBS="$LIBS -ljson"])
+ if test "$ac_cv_lib_json_json_object_get" = "no"; then
+ AC_MSG_ERROR([libjson is needed to compile])
+ fi
+fi
+])
+
+AC_ARG_ENABLE([ccls],
+AS_HELP_STRING([--enable-ccls], [Write .ccls config for this build]))
+
+AC_ARG_ENABLE([dev_build],
+ AS_HELP_STRING([--enable-dev-build], [build for development]))
+
+AC_ARG_ENABLE([scripting],
+ AS_HELP_STRING([--enable-scripting], [Build with scripting support]))
+
+AC_ARG_ENABLE([netlink-debug],
+ AS_HELP_STRING([--disable-netlink-debug], [don't pretty print netlink debug messages]))
+
+if test "$enable_netlink_debug" != "no" ; then
+ AC_DEFINE([NETLINK_DEBUG], [1], [Netlink extra debugging code])
+fi
+
+AM_CONDITIONAL([NETLINK_DEBUG], [test "$enable_netlink_debug" != "no"])
+
+if test "$enable_datacenter" = "yes" ; then
+ AC_DEFINE([HAVE_DATACENTER], [1], [Compile extensions for a DataCenter])
+ DFLT_NAME="datacenter"
+else
+ DFLT_NAME="traditional"
+fi
+
+if test "$enable_cumulus" = "yes" ; then
+ AC_DEFINE([HAVE_CUMULUS], [1], [Compile Special Cumulus Code in])
+fi
+
+AC_SUBST([DFLT_NAME])
+AC_DEFINE_UNQUOTED([DFLT_NAME], ["$DFLT_NAME"], [Name of the configuration default set])
+
+if test "$enable_shell_access" = "yes"; then
+ AC_DEFINE([HAVE_SHELL_ACCESS], [1], [Allow user to use ssh/telnet/bash, be aware this is considered insecure])
+fi
+
+#
+# Python for clippy
+#
+
+AS_IF([test "$host" = "$build"], [
+ AM_PATH_PYTHON([3])
+ AC_CHECK_HEADER([gelf.h], [], [
+ AC_MSG_ERROR([libelf headers are required for building clippy. (Host only when cross-compiling.)])
+ ])
+
+ LIBS_save="$LIBS"
+ AC_CHECK_LIB([elf], [elf_memory], [], [
+ AC_MSG_ERROR([libelf is required for building clippy. (Host only when cross-compiling.)])
+ ])
+
+ AC_CHECK_LIB([elf], [elf_getdata_rawchunk], [
+ AC_DEFINE([HAVE_ELF_GETDATA_RAWCHUNK], [1], [Have elf_getdata_rawchunk()])
+ ])
+ AC_CHECK_LIB([elf], [gelf_getnote], [
+ AC_DEFINE([HAVE_GELF_GETNOTE], [1], [Have gelf_getnote()])
+ ])
+ LIBS="$LIBS_save"
+ unset LIBS_save
+
+ FRR_PYTHON_DEV
+], [
+ FRR_PYTHON
+])
+
+FRR_PYTHON_MODULES([pytest])
+
+if test "$enable_doc" != "no"; then
+ FRR_PYTHON_MODULES([sphinx], , [
+ if test "$enable_doc" = "yes"; then
+ AC_MSG_ERROR([Documentation was explicitly requested with --enable-doc but sphinx is not available for $PYTHON. Please disable docs or install sphinx.])
+ fi
+ ])
+fi
+AM_CONDITIONAL([DOC], [test "$enable_doc" != "no" -a "$frr_py_mod_sphinx" != "false"])
+AM_CONDITIONAL([DOC_HTML], [test "$enable_doc_html" = "yes"])
+
+FRR_PYTHON_MOD_EXEC([sphinx], [--version], [
+ PYSPHINX="-m sphinx"
+], [
+ PYSPHINX="-c 'import sys; from sphinx import main; sys.exit(main(sys.argv))'"
+])
+AC_SUBST([PYSPHINX])
+
+#
+# Logic for old vpn commands support.
+#
+if test "$enable_oldvpn_commands" = "yes"; then
+ AC_DEFINE([KEEP_OLD_VPN_COMMANDS], [1], [Define for compiling with old vpn commands])
+fi
+
+AC_MSG_CHECKING([if zebra should be configurable to send Route Advertisements])
+if test "$enable_rtadv" != "no"; then
+ AC_MSG_RESULT([yes])
+ AC_DEFINE([HAVE_RTADV], [1], [Enable IPv6 Routing Advertisement support])
+else
+ AC_MSG_RESULT([no])
+fi
+
+if test "$enable_user" = "no"; then
+ enable_user=""
+else
+ if test "$enable_user" = "yes" || test "$enable_user" = ""; then
+ enable_user="frr"
+ fi
+ AC_DEFINE_UNQUOTED([FRR_USER], ["${enable_user}"], [frr User])
+fi
+
+if test "$enable_group" = "no"; then
+ enable_group=""
+else
+ if test "$enable_group" = "yes" || test "$enable_group" = ""; then
+ enable_group="frr"
+ fi
+ AC_DEFINE_UNQUOTED([FRR_GROUP], ["${enable_group}"], [frr Group])
+fi
+
+if test "$enable_vty_group" = "yes" ; then
+ AC_MSG_ERROR([--enable-vty-group requires a group as argument, not yes])
+elif test "$enable_vty_group" != ""; then
+ if test "$enable_vty_group" != "no"; then
+ AC_DEFINE_UNQUOTED([VTY_GROUP], ["${enable_vty_group}"], [VTY Sockets Group])
+ fi
+fi
+AC_SUBST([enable_user])
+AC_SUBST([enable_group])
+AC_SUBST([enable_vty_group])
+
+enable_configfile_mask=${enable_configfile_mask:-0600}
+AC_DEFINE_UNQUOTED([CONFIGFILE_MASK], [${enable_configfile_mask}], [Mask for config files])
+AC_SUBST([enable_configfile_mask])
+
+enable_logfile_mask=${enable_logfile_mask:-0600}
+AC_DEFINE_UNQUOTED([LOGFILE_MASK], [${enable_logfile_mask}], [Mask for log files])
+
+MPATH_NUM=16
+
+case "${enable_multipath}" in
+ 0)
+ MPATH_NUM=64
+ ;;
+ [[1-9]|[1-9][0-9]|[1-9][0-9][0-9]])
+ MPATH_NUM="${enable_multipath}"
+ ;;
+ "")
+ ;;
+ *)
+ AC_MSG_FAILURE([Please specify digit to enable multipath ARG])
+ ;;
+esac
+
+AC_DEFINE_UNQUOTED([MULTIPATH_NUM], [$MPATH_NUM], [Maximum number of paths for a route])
+
+case "${with_log_timestamp_precision}" in
+[[0-9]|1[012]])
+;;
+"")
+;;
+*)
+AC_MSG_FAILURE([Please specify a number from 0-12 for log precision ARG])
+;;
+esac
+with_log_timestamp_precision=${with_log_timestamp_precision:-0}
+AC_DEFINE_UNQUOTED([LOG_TIMESTAMP_PRECISION], [${with_log_timestamp_precision}], [Startup zlog timestamp precision])
+
+AC_DEFINE_UNQUOTED([VTYSH_PAGER], ["$VTYSH_PAGER"], [What pager to use])
+
+TIMEOUT_MIN=2
+case "${with_service_timeout}" in
+ [[1-9]|[1-9][0-9]|[1-9][0-9][0-9]])
+ TIMEOUT_MIN="${with_service_timeout}"
+ ;;
+ 0|"")
+ ;;
+ *)
+ AC_MSG_FAILURE([Please specify digit for timeout ARG])
+ ;;
+esac
+AC_SUBST([TIMEOUT_MIN])
+
+dnl --------------------
+dnl Enable code coverage
+dnl --------------------
+AM_CONDITIONAL([HAVE_GCOV], [test "$enable_gcov" != "no"])
+
+dnl ------------------------------------
+dnl Alpine only accepts numeric versions
+dnl ------------------------------------
+if test "$enable_numeric_version" != "" ; then
+ VERSION="`echo ${VERSION} | tr -c -d '[[.0-9]]'`"
+ PACKAGE_VERSION="`echo ${PACKAGE_VERSION} | tr -c -d '[[.0-9]]'`"
+fi
+
+dnl -----------------------------------
+dnl Add extra version string to package
+dnl name, string and version fields.
+dnl -----------------------------------
+if test "$EXTRAVERSION" != "" ; then
+ VERSION="${VERSION}${EXTRAVERSION}"
+ PACKAGE_VERSION="${PACKAGE_VERSION}${EXTRAVERSION}"
+ AC_SUBST(PACKAGE_EXTRAVERSION, ["${EXTRAVERSION}"])
+ PACKAGE_STRING="${PACKAGE_STRING}${EXTRAVERSION}"
+fi
+AC_SUBST([EXTRAVERSION])
+
+if test "$with_pkg_git_version" = "yes"; then
+ if test -e "${srcdir}/.git"; then
+ AC_DEFINE([GIT_VERSION], [1], [include git version info])
+ else with_pkg_git_version="no"
+ AC_MSG_WARN([--with-pkg-git-version given, but this is not a git checkout])
+ fi
+fi
+AM_CONDITIONAL([GIT_VERSION], [test "$with_pkg_git_version" = "yes"])
+
+AC_CHECK_TOOL([OBJCOPY], [objcopy], [:])
+if test "$OBJCOPY" != ":"; then
+ AC_CACHE_CHECK([for .interp value to use], [frr_cv_interp], [
+ frr_cv_interp=""
+ AC_LINK_IFELSE([AC_LANG_SOURCE([[int main() { return 0; }]])], [
+ if $OBJCOPY -j.interp -Obinary conftest conftest.interp; then
+ frr_cv_interp="`xargs -0 echo < conftest.interp`"
+ fi
+ test -f conftest.interp && rm conftest.interp
+ ])
+ ])
+fi
+if test -n "$frr_cv_interp"; then
+ AC_DEFINE_UNQUOTED([INTERP], ["$frr_cv_interp"], [.interp value])
+fi
+
+dnl -------------------------
+dnl Check other header files.
+dnl -------------------------
+AC_CHECK_HEADERS([stropts.h sys/ksym.h \
+ linux/version.h asm/types.h endian.h sys/endian.h])
+
+ac_stdatomic_ok=false
+AC_DEFINE([FRR_AUTOCONF_ATOMIC], [1], [did autoconf checks for atomic funcs])
+AC_CHECK_HEADER([stdatomic.h],[
+
+ AC_MSG_CHECKING([whether _Atomic qualifier works])
+ AC_LINK_IFELSE([AC_LANG_SOURCE([[
+#include <stdatomic.h>
+int main(int argc, char **argv) {
+ _Atomic int i = 0;
+ return i;
+}
+]])], [
+ AC_DEFINE([HAVE_STDATOMIC_H], [1], [found stdatomic.h])
+ AC_MSG_RESULT([yes])
+ ac_stdatomic_ok=true
+ ], [
+ AC_MSG_RESULT([no])
+ ])
+])
+
+AS_IF([$ac_stdatomic_ok], [true], [
+ AC_MSG_CHECKING([for __atomic_* builtins])
+ AC_LINK_IFELSE([AC_LANG_SOURCE([[
+int main(int argc, char **argv) {
+ volatile int i = 1;
+ __atomic_store_n (&i, 0, __ATOMIC_RELEASE);
+ return __atomic_load_n (&i, __ATOMIC_ACQUIRE);
+}
+]])], [
+ AC_DEFINE([HAVE___ATOMIC], [1], [found __atomic builtins])
+ AC_MSG_RESULT([yes])
+ ], [
+ AC_MSG_RESULT([no])
+
+ dnl FreeBSD 9 has a broken stdatomic.h where _Atomic doesn't work
+ AC_MSG_CHECKING([for __sync_* builtins])
+ AC_LINK_IFELSE([AC_LANG_SOURCE([[
+int main(int argc, char **argv) {
+ volatile int i = 1;
+ __sync_fetch_and_sub (&i, 1);
+ return __sync_val_compare_and_swap (&i, 0, 1);
+}
+]])], [
+ AC_DEFINE([HAVE___SYNC], [1], [found __sync builtins])
+ AC_MSG_RESULT([yes])
+
+ AC_MSG_CHECKING([for __sync_swap builtin])
+ AC_LINK_IFELSE([AC_LANG_SOURCE([[
+int main(int argc, char **argv) {
+ volatile int i = 1;
+ return __sync_swap (&i, 2);
+}
+]])], [
+ AC_DEFINE([HAVE___SYNC_SWAP], 1, [found __sync_swap builtin])
+ AC_MSG_RESULT([yes])
+ ], [
+ AC_MSG_RESULT([no])
+ ])
+
+ ], [
+ AC_MSG_RESULT([no])
+ AC_MSG_FAILURE([stdatomic.h unavailable and $CC has neither __atomic nor __sync builtins])
+ ])
+ ])
+])
+
+needsync=true
+
+AS_IF([$needsync], [
+ dnl Linux
+ AC_MSG_CHECKING([for Linux futex() support])
+ AC_LINK_IFELSE([AC_LANG_PROGRAM([
+#ifndef _GNU_SOURCE
+#define _GNU_SOURCE
+#endif
+#include <unistd.h>
+#include <limits.h>
+#include <sys/time.h>
+#include <sys/syscall.h>
+#include <linux/futex.h>
+
+int main(void);
+],
+[
+{
+ return syscall(SYS_futex, NULL, FUTEX_WAIT, 0, NULL, NULL, 0);
+}
+])], [
+ AC_MSG_RESULT([yes])
+ AC_DEFINE(HAVE_SYNC_LINUX_FUTEX,,Have Linux futex support)
+ needsync=false
+ ], [
+ AC_MSG_RESULT([no])
+ ])
+])
+
+AS_IF([$needsync], [
+ dnl FreeBSD
+ AC_MSG_CHECKING([for FreeBSD _umtx_op() support])
+ AC_LINK_IFELSE([AC_LANG_PROGRAM([
+#include <errno.h>
+#include <stdlib.h>
+#include <sys/types.h>
+#include <sys/umtx.h>
+int main(void);
+],
+[
+{
+ return _umtx_op(NULL, UMTX_OP_WAIT_UINT, 0, NULL, NULL);
+}
+])], [
+ AC_MSG_RESULT([yes])
+ AC_DEFINE(HAVE_SYNC_UMTX_OP,,Have FreeBSD _umtx_op() support)
+ needsync=false
+ ], [
+ AC_MSG_RESULT([no])
+ ])
+])
+
+AS_IF([$needsync], [
+ dnl OpenBSD patch (not upstream at the time of writing this)
+ dnl https://marc.info/?l=openbsd-tech&m=147299508409549&w=2
+ AC_MSG_CHECKING([for OpenBSD futex() support])
+ AC_LINK_IFELSE([AC_LANG_PROGRAM([
+#include <sys/futex.h>
+int main(void);
+],
+[
+{
+ return futex(NULL, FUTEX_WAIT, 0, NULL, NULL, 0);
+}
+])], [
+ AC_MSG_RESULT([yes])
+ AC_DEFINE(HAVE_SYNC_OPENBSD_FUTEX,,Have OpenBSD futex support)
+ needsync=false
+ ], [
+ AC_MSG_RESULT([no])
+ ])
+])
+
+dnl Utility macro to avoid retyping includes all the time
+m4_define([FRR_INCLUDES],
+[#ifdef SUNOS_5
+#define _POSIX_C_SOURCE 200809L
+#define __EXTENSIONS__
+#endif
+#include <stdio.h>
+#include <stdlib.h>
+#include <stddef.h>
+#include <sys/types.h>
+/* sys/conf.h depends on param.h on FBSD at least */
+#include <sys/param.h>
+/* Required for MAXSIG */
+#include <signal.h>
+#include <sys/socket.h>
+#ifdef __APPLE__
+# define __APPLE_USE_RFC_3542
+#endif
+#include <netinet/in.h>
+#include <sys/time.h>
+#include <time.h>
+#include <net/if.h>
+])dnl
+
+dnl Same applies for HAVE_NET_IF_VAR_H, which HAVE_NETINET6_ND6_H and
+dnl HAVE_NETINET_IN_VAR_H depend upon. But if_var.h depends on if.h, hence
+dnl an additional round for it.
+
+AC_CHECK_HEADERS([net/if_var.h], [], [], [FRR_INCLUDES])
+
+m4_define([FRR_INCLUDES],
+FRR_INCLUDES
+[#ifdef HAVE_NET_IF_VAR_H
+# include <net/if_var.h>
+#endif
+])dnl
+
+AC_CHECK_HEADERS([netinet/in_var.h \
+ net/if_dl.h net/netopt.h \
+ inet/nd.h netinet/ip_icmp.h \
+ sys/sysctl.h sys/sockio.h sys/conf.h],
+ [], [], [FRR_INCLUDES])
+
+AC_CHECK_HEADERS([ucontext.h], [], [],
+[#ifndef __USE_GNU
+#define __USE_GNU
+#endif /* __USE_GNU */
+FRR_INCLUDES
+])
+
+m4_define([UCONTEXT_INCLUDES],
+[#include <ucontext.h>])dnl
+
+AC_CHECK_MEMBERS([ucontext_t.uc_mcontext.uc_regs],
+ [], [], [UCONTEXT_INCLUDES])
+AC_CHECK_MEMBERS([ucontext_t.uc_mcontext.regs],
+ [AC_CHECK_MEMBERS([ucontext_t.uc_mcontext.regs.nip],
+ [], [], [UCONTEXT_INCLUDES])],
+ [], [UCONTEXT_INCLUDES])
+AC_CHECK_MEMBERS([ucontext_t.uc_mcontext.gregs],
+ [], [], [UCONTEXT_INCLUDES])
+
+m4_define([FRR_INCLUDES],
+FRR_INCLUDES
+[
+#include <sys/un.h>
+#include <netinet/in_systm.h>
+#ifdef HAVE_NETINET_IN_VAR_H
+# include <netinet/in_var.h>
+#endif
+#ifdef HAVE_NET_IF_DL_H
+# include <net/if_dl.h>
+#endif
+#ifdef HAVE_NET_NETOPT_H
+# include <net/netopt.h>
+#endif
+#include <net/route.h>
+#ifdef HAVE_INET_ND_H
+# include <inet/nd.h>
+#endif
+#include <arpa/inet.h>
+/* Required for IDRP */
+#ifdef HAVE_NETINET_IP_ICMP_H
+# include <netinet/ip_icmp.h>
+#endif
+])dnl
+
+dnl V6 headers are checked below, after we check for v6
+
+is_linux=false
+
+AC_MSG_CHECKING([which operating system interface to use])
+case "$host_os" in
+ sunos* | solaris2*)
+ AC_MSG_FAILURE([Solaris support has been removed please see versions prior or equal to 7.5])
+ ;;
+ linux*)
+ AC_MSG_RESULT([Linux])
+
+ AC_DEFINE([GNU_LINUX], [1], [GNU Linux])
+ AC_DEFINE([HAVE_NETLINK], [1], [netlink])
+ AC_DEFINE([LINUX_IPV6], [1], [Linux IPv6 stack])
+
+ dnl Linux has a compilation problem with mixing
+ dnl netinet/in.h and linux/in6.h they are not
+ dnl compatible. There has been discussion on
+ dnl how to fix it but no real progress on implementation
+ dnl when they fix it, remove this
+ AC_DEFINE([IPV6_MINHOPCOUNT], [73], [Linux ipv6 Min Hop Count])
+
+ is_linux=true
+ ;;
+ openbsd*)
+ AC_MSG_RESULT([OpenBSD])
+
+ AC_DEFINE([OPEN_BSD], [1], [OpenBSD])
+ AC_DEFINE([KAME], [1], [KAME IPv6])
+ AC_DEFINE([BSD_V6_SYSCTL], [1], [BSD v6 sysctl to turn on and off forwarding])
+ ;;
+ *)
+ AC_MSG_RESULT([BSD])
+
+ AC_DEFINE([HAVE_NET_RT_IFLIST], [1], [NET_RT_IFLIST])
+ AC_DEFINE([KAME], [1], [KAME IPv6])
+ AC_DEFINE([BSD_V6_SYSCTL], [1], [BSD v6 sysctl to turn on and off forwarding])
+ ;;
+esac
+AM_CONDITIONAL([LINUX], [${is_linux}])
+
+AC_SYS_LARGEFILE
+
+dnl ------------------------
+dnl Integrated REALMS option
+dnl ------------------------
+if test "$enable_realms" = "yes"; then
+ case "$host_os" in
+ linux*)
+ AC_DEFINE([SUPPORT_REALMS], [1], [Realms support])
+ ;;
+ *)
+ echo "Sorry, only Linux has REALMS support"
+ exit 1
+ ;;
+ esac
+fi
+
+dnl ---------------
+dnl other functions
+dnl ---------------
+AC_CHECK_FUNCS([ \
+ strlcat strlcpy \
+ getgrouplist \
+ openat \
+ unlinkat \
+ posix_fallocate \
+ sendmmsg \
+ explicit_bzero \
+ ])
+
+AC_CHECK_MEMBERS([struct mmsghdr.msg_hdr], [], [], FRR_INCLUDES)
+
+dnl ##########################################################################
+dnl LARGE if block spans a lot of "configure"!
+if test "$enable_clippy_only" != "yes"; then
+dnl ##########################################################################
+
+#
+# Logic for protobuf support.
+#
+PROTO3=false
+# Enable Protobuf by default at all times.
+# Check for protoc & protoc-c
+# protoc is not required, it's only for a "be nice" helper target
+AC_CHECK_PROGS([PROTOC], [protoc], [/bin/false])
+
+AC_CHECK_PROGS([PROTOC_C], [protoc-c], [/bin/false])
+if test "$PROTOC_C" = "/bin/false"; then
+ AC_MSG_FAILURE([protobuf requested but protoc-c not found. Install protobuf-c.])
+fi
+
+PKG_CHECK_MODULES([PROTOBUF_C], [libprotobuf-c >= 1.1.0],, [
+ AC_MSG_FAILURE([minimum version (1.1.0) of libprotobuf-c not found. Install minimum required version of protobuf-c.])
+])
+
+if test "$enable_protobuf3" = "yes"; then
+ PROTO3=true
+ AC_CHECK_HEADER([google/protobuf-c/protobuf-c.h],
+ [AC_CHECK_DECLS(PROTOBUF_C_LABEL_NONE,
+ AC_DEFINE([HAVE_PROTOBUF_VERSION_3],
+ [1], [Have Protobuf version 3]),
+ [PROTO3=false],
+ [#include <google/protobuf-c/protobuf-c.h>])],
+ [PROTO3=false && AC_MSG_FAILURE([protobuf3 requested but protobuf-c.h not found. Install protobuf-c.])])
+fi
+
+if test "$enable_protobuf" != "no"; then
+ AC_DEFINE([HAVE_PROTOBUF], [1], [protobuf])
+fi
+#
+# End of logic for protobuf support.
+#
+
+
+dnl ---------------------
+dnl Integrated VTY option
+dnl ---------------------
+case "${enable_vtysh}" in
+"no")
+ VTYSH="";;
+*)
+ VTYSH="vtysh";
+ AC_DEFINE([VTYSH], [1], [VTY shell])
+
+ prev_libs="$LIBS"
+ AC_CHECK_LIB([readline], [readline], [
+ LIBREADLINE="-lreadline"
+ ], [
+ dnl readline failed - it might be incorrectly linked and missing its
+ dnl termcap/tinfo/curses dependency. see if we can fix that...
+ AC_SEARCH_LIBS([tputs], [termcap tinfo curses ncurses], [
+ LIBREADLINE="$ac_cv_search_tputs"
+ ], [
+ AC_MSG_ERROR([libreadline (needed for vtysh) not found and/or missing dependencies])
+ ])
+
+ dnl re-try with the lib we found above
+ unset ac_cv_lib_readline_main
+ AC_CHECK_LIB([readline], [main], [
+ LIBREADLINE="-lreadline $LIBREADLINE"
+ ], [
+ AC_MSG_ERROR([libreadline (needed for vtysh) not found and/or missing dependencies])
+ ], [$LIBREADLINE])
+ ], [])
+ LIBS="$LIBS -lreadline"
+ AC_CHECK_FUNCS([rl_clear_visible_line])
+ LIBS="$prev_libs"
+
+ AC_CHECK_HEADER([readline/history.h])
+ if test "$ac_cv_header_readline_history_h" = "no"; then
+ AC_MSG_ERROR([readline is too old to have readline/history.h, please update to the latest readline library.])
+ fi
+ AC_CHECK_LIB([readline], [rl_completion_matches], [true], [], [$LIBREADLINE])
+ if test "$ac_cv_lib_readline_rl_completion_matches" = "no"; then
+ AC_DEFINE([rl_completion_matches], [completion_matches], [Old readline])
+ fi
+ AC_CHECK_LIB([readline], [append_history], [frr_cv_append_history=yes], [frr_cv_append_history=no], [$LIBREADLINE])
+ if test "$frr_cv_append_history" = "yes"; then
+ AC_DEFINE([HAVE_APPEND_HISTORY], [1], [Have history.h append_history])
+ fi
+ ;;
+esac
+AC_SUBST([LIBREADLINE])
+
+dnl ----------
+dnl PAM module
+dnl
+dnl FRR detects the PAM library it is built against by checking for a
+dnl functional pam_misc.h (Linux-PAM) or openpam.h (OpenPAM) header. pam_misc.h
+dnl is known to #include pam_appl.h, the standard header of a PAM library, and
+dnl openpam.h doesn't do that, although depends on the header too. Hence a
+dnl little assistance to AC_CHECK_HEADER is necessary for the proper detection
+dnl of OpenPAM.
+dnl ----------
+if test "$with_libpam" = "yes"; then
+ AC_CHECK_HEADER([security/pam_misc.h],
+ [AC_DEFINE([HAVE_PAM_MISC_H], [1], [Have pam_misc.h])
+ AC_DEFINE([PAM_CONV_FUNC], [misc_conv], [Have misc_conv])
+ pam_conv_func="misc_conv"
+ ],
+ [], FRR_INCLUDES)
+ AC_CHECK_HEADER([security/openpam.h],
+ [AC_DEFINE([HAVE_OPENPAM_H], [1], [Have openpam.h])
+ AC_DEFINE([PAM_CONV_FUNC], [openpam_ttyconv], [Have openpam_ttyconv])
+ pam_conv_func="openpam_ttyconv"
+ ],
+ [], FRR_INCLUDES[#include <security/pam_appl.h>])
+ if test -z "$ac_cv_header_security_pam_misc_h$ac_cv_header_security_openpam_h" ; then
+ AC_MSG_WARN([*** pam support will not be built ***])
+ with_libpam="no"
+ fi
+fi
+
+if test "$with_libpam" = "yes"; then
+dnl took this test from proftpds configure.in and suited to our needs
+dnl -------------------------------------------------------------------------
+dnl
+dnl This next check looks funky due to a linker problem with some versions
+dnl of the PAM library. Prior to 0.72 release, the Linux PAM shared library
+dnl omitted requiring libdl linking information. PAM-0.72 or better ships
+dnl with RedHat 6.2 and Debian 2.2 or better.
+AC_CHECK_LIB([pam], [pam_start],
+ [AC_CHECK_LIB([pam], [$pam_conv_func],
+ [AC_DEFINE([USE_PAM], [1], [Use PAM for authentication])
+ LIBPAM="-lpam"],
+ [AC_DEFINE([USE_PAM], [1], [Use PAM for authentication])
+ LIBPAM="-lpam -lpam_misc"]
+ )
+ ],
+
+ [AC_CHECK_LIB([pam], [pam_end],
+ [AC_CHECK_LIB([pam], [$pam_conv_func],
+ [AC_DEFINE([USE_PAM], [1], [Use PAM for authentication])
+ LIBPAM="-lpam -ldl"],
+ [AC_DEFINE([USE_PAM], [1], [Use PAM for authentication])
+ LIBPAM="-lpam -ldl -lpam_misc"]
+ )
+ ],AC_MSG_WARN([*** pam support will not be built ***]),
+ [-ldl])
+ ]
+)
+fi
+AC_SUBST([LIBPAM])
+
+dnl -------------------------------
+dnl bgpd needs pow() and hence libm
+dnl -------------------------------
+TMPLIBS="$LIBS"
+LIBS=""
+AC_SEARCH_LIBS([pow], [m], [
+ LIBM="$LIBS"
+], [
+ AC_MSG_WARN([Unable to find working pow function - bgpd may not link])
+])
+LIBS="$TMPLIBS"
+AC_SUBST([LIBM])
+
+AC_CHECK_FUNCS([ppoll], [
+ AC_DEFINE([HAVE_PPOLL], [1], [have Linux/BSD ppoll()])
+])
+AC_CHECK_FUNCS([pollts], [
+ AC_DEFINE([HAVE_POLLTS], [1], [have NetBSD pollts()])
+])
+
+AC_CHECK_HEADER([asm-generic/unistd.h],
+ [AC_CHECK_DECL(__NR_setns,
+ AC_DEFINE([HAVE_NETNS], [1], [Have netns]),,
+ FRR_INCLUDES [#include <asm-generic/unistd.h>
+ ])
+ AC_CHECK_FUNCS([setns])]
+ )
+
+dnl --------------------------
+dnl Determine IS-IS I/O method
+dnl --------------------------
+AC_DEFINE([ISIS_METHOD_PFPACKET], [1], [constant value for isis method pfpacket])
+AC_DEFINE([ISIS_METHOD_DLPI], [2], [constant value for isis method dlpi])
+AC_DEFINE([ISIS_METHOD_BPF], [3], [constant value for isis method bpf])
+AC_CHECK_HEADER([net/bpf.h])
+AC_CHECK_HEADER([sys/dlpi.h])
+AC_MSG_CHECKING([zebra IS-IS I/O method])
+
+case "$host_os" in
+ linux*)
+ AC_MSG_RESULT([pfpacket])
+ ISIS_METHOD_MACRO="ISIS_METHOD_PFPACKET"
+ ;;
+ *)
+ if test "$ac_cv_header_net_bpf_h" = "no"; then
+ if test "$ac_cv_header_sys_dlpi_h" = "no"; then
+ AC_MSG_RESULT([none])
+ if test "$enable_isisd" = "yes" -o "$enable_fabricd" = "yes"; then
+ AC_MSG_FAILURE([IS-IS support requested but no packet backend found])
+ fi
+ AC_MSG_WARN([*** IS-IS support will not be built ***])
+ enable_isisd="no"
+ enable_fabricd="no"
+ else
+ AC_MSG_RESULT([DLPI])
+ fi
+ ISIS_METHOD_MACRO="ISIS_METHOD_DLPI"
+ else
+ AC_MSG_RESULT([BPF])
+ ISIS_METHOD_MACRO="ISIS_METHOD_BPF"
+ fi
+ ;;
+esac
+AC_DEFINE_UNQUOTED([ISIS_METHOD], [$ISIS_METHOD_MACRO], [selected method for isis, == one of the constants])
+
+dnl ---------------------------------------------------------------
+dnl figure out how to specify an interface in multicast sockets API
+dnl ---------------------------------------------------------------
+AC_CHECK_MEMBERS([struct ip_mreqn.imr_ifindex], [], [], FRR_INCLUDES)
+
+AC_CHECK_HEADERS([linux/mroute.h], [], [],[
+ #include <sys/socket.h>
+ #include <netinet/in.h>
+ #define _LINUX_IN_H /* For Linux <= 2.6.25 */
+ #include <linux/types.h>
+])
+
+AC_CHECK_HEADERS([linux/mroute6.h], [], [],[
+ #include <sys/socket.h>
+ #include <netinet/in.h>
+ #define _LINUX_IN_H /* For Linux <= 2.6.25 */
+ #include <linux/types.h>
+])
+
+m4_define([FRR_INCLUDES],
+FRR_INCLUDES
+[#ifdef HAVE_LINUX_MROUTE_H
+# include <linux/mroute.h>
+#endif
+])dnl
+
+AC_CHECK_HEADERS([netinet/ip_mroute.h], [], [],[
+ #include <sys/socket.h>
+ #include <sys/types.h>
+ #include <netinet/in.h>
+ #include <net/route.h>
+])
+
+m4_define([FRR_INCLUDES],
+FRR_INCLUDES
+[#ifdef HAVE_NETINET_IP_MROUTE_H
+# include <netinet/ip_mroute.h>
+#endif
+])dnl
+
+AC_MSG_CHECKING([for RFC3678 protocol-independed API])
+AC_COMPILE_IFELSE(
+[ AC_LANG_PROGRAM([[
+ #include <sys/types.h>
+ #include <netinet/in.h>
+ ]], [[
+ struct group_req gr;
+ int sock;
+ setsockopt(sock, IPPROTO_IP, MCAST_JOIN_GROUP, (void*)&gr, sizeof(gr));
+ ]])
+],[
+ AC_MSG_RESULT([yes])
+ AC_DEFINE([HAVE_RFC3678], [1], [Have RFC3678 protocol-independed API])
+],[
+ AC_MSG_RESULT(no)
+])
+
+dnl ---------------------------------------------------------------
+dnl figure out how to check link-state
+dnl ---------------------------------------------------------------
+AC_CHECK_HEADER([net/if_media.h],
+ [m4_define([LINK_DETECT_INCLUDES],
+ FRR_INCLUDES
+ [#include <net/if_media.h>
+ ])
+ AC_CHECK_MEMBERS([struct ifmediareq.ifm_status],
+ AC_DEFINE([HAVE_BSD_LINK_DETECT], [1], [BSD link-detect]),
+ [], LINK_DETECT_INCLUDES)],
+ [],
+ FRR_INCLUDES)
+
+dnl ---------------------------------------------------------------
+dnl Additional, newer way to check link-state using ifi_link_state.
+dnl Not available in all BSD's when ifmediareq available
+dnl ---------------------------------------------------------------
+AC_CHECK_MEMBERS([struct if_data.ifi_link_state],
+ AC_DEFINE([HAVE_BSD_IFI_LINK_STATE], [1], [BSD ifi_link_state available]),
+ [], FRR_INCLUDES)
+
+dnl ------------------------
+dnl TCP_MD5SIG socket option
+dnl ------------------------
+
+AC_CHECK_HEADER([netinet/tcp.h],
+ [m4_define([MD5_INCLUDES],
+ FRR_INCLUDES
+ [#include <netinet/tcp.h>
+ ])
+ AC_CHECK_DECLS([TCP_MD5SIG], [], [], MD5_INCLUDES)],
+ [],
+ FRR_INCLUDES)
+if test "$ac_cv_have_decl_TCP_MD5SIG" = "no"; then
+ AC_CHECK_HEADER([linux/tcp.h],
+ [m4_define([MD5_INCLUDES],
+ FRR_INCLUDES
+ [#include <linux/tcp.h>
+ ])
+ AC_CHECK_DECLS([TCP_MD5SIG], [], [], MD5_INCLUDES)])
+fi
+
+LIBS_save="$LIBS"
+AC_CHECK_LIB([crypt], [crypt], [], [
+ AC_CHECK_LIB([crypto], [DES_crypt])
+])
+LIBCRYPT="$LIBS"
+LIBCRYPT="${LIBCRYPT%$LIBS_save}"
+LIBCRYPT="${LIBCRYPT#$LIBS_save}"
+AC_SUBST([LIBCRYPT])
+LIBS="$LIBS_save"
+unset LIBS_save
+
+AC_CHECK_LIB([resolv], [res_init])
+
+dnl ---------------------------
+dnl check system has PCRE regexp
+dnl ---------------------------
+if test "$enable_pcreposix" = "yes"; then
+ AC_CHECK_LIB([pcreposix], [regexec], [], [
+ AC_MSG_ERROR([--enable-pcreposix given but unable to find libpcreposix])
+ ])
+fi
+AC_SUBST([HAVE_LIBPCREPOSIX])
+
+dnl ---------------------------
+dnl check system has PCRE2 regexp
+dnl ---------------------------
+if test "$enable_pcre2posix" = "yes"; then
+ AC_CHECK_LIB([pcre2-posix], [regexec], [], [
+ AC_MSG_ERROR([--enable-pcre2posix given but unable to find libpcre2-posix])
+ ])
+fi
+AC_SUBST([HAVE_LIBPCRE2_POSIX])
+
+dnl ##########################################################################
+dnl test "$enable_clippy_only" != "yes"
+fi
+dnl END OF LARGE if block
+dnl ##########################################################################
+
+dnl ------------------
+dnl check C-Ares library
+dnl ------------------
+PKG_CHECK_MODULES([CARES], [libcares], [
+ c_ares_found=true
+],[
+ c_ares_found=false
+])
+AM_CONDITIONAL([CARES], [$c_ares_found])
+
+
+dnl ----------------------------------------------------------------------------
+dnl figure out if domainname is available in the utsname struct (GNU extension).
+dnl ----------------------------------------------------------------------------
+AC_CHECK_MEMBERS([struct utsname.domainname], [], [], [#include <sys/utsname.h>])
+
+dnl ------------------
+dnl IPv6 header checks
+dnl ------------------
+AC_CHECK_HEADERS([netinet6/in6.h netinet/in6_var.h \
+ netinet6/in6_var.h netinet6/nd6.h], [], [],
+ FRR_INCLUDES)
+
+m4_define([FRR_INCLUDES],dnl
+FRR_INCLUDES
+[#ifdef HAVE_NETINET6_IN6_H
+#include <netinet6/in6.h>
+#endif
+#ifdef HAVE_NETINET_IN6_VAR_H
+#include <netinet/in6_var.h>
+#endif
+#include <netinet/icmp6.h>
+#ifdef HAVE_NETINET6_IN6_VAR_H
+# include <netinet6/in6_var.h>
+#endif
+#ifdef HAVE_NETINET6_ND6_H
+# include <netinet6/nd6.h>
+#endif
+])dnl
+
+dnl --------------------
+dnl Daemon disable check
+dnl --------------------
+
+AS_IF([test "$enable_bgpd" != "no"], [
+ AC_DEFINE([HAVE_BGPD], [1], [bgpd])
+])
+
+AS_IF([test "$enable_mgmtd" != "no"], [
+
+ AC_DEFINE([HAVE_MGMTD], [1], [mgmtd])
+
+ # Enable MGMTD local validations
+ AS_IF([test "$enable_mgmtd_local_validations" == "yes"], [
+ AC_DEFINE([MGMTD_LOCAL_VALIDATIONS_ENABLED], [1], [Enable mgmtd local validations.])
+ ])
+])
+
+AS_IF([test "$enable_ripd" != "no"], [
+ AC_DEFINE([HAVE_RIPD], [1], [ripd])
+])
+
+AS_IF([test "$enable_ripngd" != "no"], [
+ AC_DEFINE([HAVE_RIPNGD], [1], [ripngd])
+])
+
+AS_IF([test "$enable_ospfd" != "no"], [
+ AC_DEFINE([HAVE_OSPFD], [1], [ospfd])
+])
+
+AS_IF([test "$enable_ospf6d" != "no"], [
+ AC_DEFINE([HAVE_OSPF6D], [1], [ospf6d])
+])
+
+AS_IF([test "$enable_ldpd" != "no"], [
+ AC_DEFINE([HAVE_LDPD], [1], [ldpd])
+])
+
+AS_IF([test "$enable_nhrpd" != "no"], [
+ AC_DEFINE([HAVE_NHRPD], [1], [nhrpd])
+])
+
+AS_IF([test "$enable_eigrpd" != "no"], [
+ AC_DEFINE([HAVE_EIGRPD], [1], [eigrpd])
+])
+
+AS_IF([test "$enable_babeld" != "no"], [
+ AC_DEFINE([HAVE_BABELD], [1], [babeld])
+])
+
+AS_IF([test "$enable_isisd" != "no"], [
+ AC_DEFINE([HAVE_ISISD], [1], [isisd])
+])
+
+AS_IF([test "$enable_pimd" != "no"], [
+ AC_DEFINE([HAVE_PIMD], [1], [pimd])
+])
+
+AS_IF([test "$enable_pim6d" != "no"], [
+ AC_DEFINE([HAVE_PIM6D], [1], [pim6d])
+])
+
+AS_IF([test "$enable_pbrd" != "no"], [
+ AC_DEFINE([HAVE_PBRD], [1], [pbrd])
+])
+
+AS_IF([test "$enable_sharpd" = "yes"], [
+ AC_DEFINE([HAVE_SHARPD], [1], [sharpd])
+])
+
+AS_IF([test "$enable_staticd" != "no"], [
+ AC_DEFINE([HAVE_STATICD], [1], [staticd])
+])
+
+AS_IF([test "$enable_fabricd" != "no"], [
+ AC_DEFINE([HAVE_FABRICD], [1], [fabricd])
+])
+
+AS_IF([test "$enable_vrrpd" != "no"], [
+ AC_DEFINE([HAVE_VRRPD], [1], [vrrpd])
+])
+
+if test "$enable_bfdd" = "no"; then
+ AC_DEFINE([HAVE_BFDD], [0], [bfdd])
+ BFDD=""
+else
+ AC_DEFINE([HAVE_BFDD], [1], [bfdd])
+ BFDD="bfdd"
+
+ case $host_os in
+ linux*)
+ AC_DEFINE([BFD_LINUX], [1], [bfdd])
+ ;;
+
+ *)
+ AC_DEFINE([BFD_BSD], [1], [bfdd])
+ ;;
+ esac
+fi
+
+AS_IF([test "$enable_pathd" != "no"], [
+ AC_DEFINE([HAVE_PATHD], [1], [pathd])
+])
+
+if test "$ac_cv_lib_json_c_json_object_get" = "no" -a "$BFDD" = "bfdd"; then
+ AC_MSG_ERROR(["you must use json-c library to use bfdd"])
+fi
+
+NHRPD=""
+case "$host_os" in
+ linux*)
+ case "${enable_nhrpd}" in
+ no)
+ ;;
+ yes)
+ if test "$enable_clippy_only" != "yes"; then
+ if test "$c_ares_found" != "true" ; then
+ AC_MSG_ERROR([nhrpd requires libcares. Please install c-ares and its -dev headers.])
+ fi
+ fi
+ NHRPD="nhrpd"
+ ;;
+ *)
+ if test "$c_ares_found" = "true" ; then
+ NHRPD="nhrpd"
+ fi
+ ;;
+ esac
+ ;;
+ *)
+ if test "$enable_nhrpd" = "yes"; then
+ AC_MSG_ERROR([nhrpd requires kernel APIs that are only present on Linux.])
+ fi
+ ;;
+esac
+
+if test "$enable_watchfrr" = "no";then
+ WATCHFRR=""
+else
+ WATCHFRR="watchfrr"
+fi
+
+OSPFCLIENT=""
+if test "$enable_ospfapi" != "no";then
+ AC_DEFINE([SUPPORT_OSPF_API], [1], [OSPFAPI])
+
+ if test "$enable_ospfclient" != "no";then
+ OSPFCLIENT="ospfclient"
+ fi
+fi
+
+if test "$enable_bgp_announce" = "no";then
+ AC_DEFINE([DISABLE_BGP_ANNOUNCE], [1], [Disable BGP installation to zebra])
+else
+ AC_DEFINE([DISABLE_BGP_ANNOUNCE], [0], [Disable BGP installation to zebra])
+fi
+
+if test "$enable_bgp_vnc" != "no";then
+ AC_DEFINE([ENABLE_BGP_VNC], [1], [Enable BGP VNC support])
+fi
+
+bgpd_bmp=false
+case "${enable_bgp_bmp}" in
+ no)
+ ;;
+ yes)
+ if test "$c_ares_found" != "true" ; then
+ AC_MSG_ERROR([BMP support requires libcares. Please install c-ares and its -dev headers.])
+ fi
+ bgpd_bmp=true
+ ;;
+ *)
+ if test "$c_ares_found" = "true" ; then
+ bgpd_bmp=true
+ fi
+ ;;
+esac
+
+if test "$enable_version_build_config" != "no";then
+ AC_DEFINE([ENABLE_VERSION_BUILD_CONFIG], [1], [Report build configs in show version])
+fi
+
+dnl ##########################################################################
+dnl LARGE if block
+if test "$enable_clippy_only" != "yes"; then
+dnl ##########################################################################
+
+dnl ------------------
+dnl check Net-SNMP library
+dnl ------------------
+if test "$enable_snmp" != "" -a "$enable_snmp" != "no"; then
+ AC_PATH_TOOL([NETSNMP_CONFIG], [net-snmp-config], [no])
+ if test "$NETSNMP_CONFIG" = "no"; then
+ AC_MSG_ERROR([--enable-snmp given but unable to find net-snmp-config])
+ fi
+ SNMP_LIBS="`${NETSNMP_CONFIG} --agent-libs`"
+ SNMP_CFLAGS="`${NETSNMP_CONFIG} --base-cflags`"
+ # net-snmp lists all of its own dependencies. we absolutely do not want that
+ # among other things we avoid a GPL vs. OpenSSL license conflict here
+ for removelib in crypto ssl sensors pci wrap; do
+ SNMP_LIBS="`echo $SNMP_LIBS | sed -e 's/\(^\|\s\)-l'$removelib'\b/ /g' -e 's/\(^\|\s\)\([^\s]*\/\)\?lib'$removelib'\.[^\s]\+\b/ /g'`"
+ done
+ AC_MSG_CHECKING([whether we can link to Net-SNMP])
+ AC_LINK_IFELSE_FLAGS([$SNMP_CFLAGS], [$SNMP_LIBS], [AC_LANG_PROGRAM([
+int main(void);
+],
+[
+{
+ return 0;
+}
+])], [
+ AC_MSG_RESULT([no])
+ AC_MSG_ERROR([--enable-snmp given but not usable])])
+ case "${enable_snmp}" in
+ yes)
+ SNMP_METHOD=agentx
+ ;;
+ agentx)
+ SNMP_METHOD="${enable_snmp}"
+ ;;
+ *)
+ AC_MSG_ERROR([--enable-snmp given with an unknown method (${enable_snmp}). Use yes or agentx])
+ ;;
+ esac
+ AH_TEMPLATE([SNMP_AGENTX], [Use SNMP AgentX to interface with snmpd])
+ AC_DEFINE_UNQUOTED(AS_TR_CPP(SNMP_${SNMP_METHOD}),,[SNMP method to interface with snmpd])
+fi
+AC_SUBST([SNMP_LIBS])
+AC_SUBST([SNMP_CFLAGS])
+
+dnl ---------------
+dnl libyang
+dnl ---------------
+PKG_CHECK_MODULES([LIBYANG], [libyang >= 2.0.0], , [
+ AC_MSG_ERROR([libyang (>= 2.0.0) was not found on your system.])
+])
+ac_cflags_save="$CFLAGS"
+CFLAGS="$CFLAGS $LIBYANG_CFLAGS"
+AC_CHECK_MEMBER([struct lyd_node.priv], [], [
+ AC_MSG_ERROR([m4_normalize([
+ libyang needs to be compiled with ENABLE_LYD_PRIV=ON.
+ Instructions for this are included in the build documentation for your platform at http://docs.frrouting.org/projects/dev-guide/en/latest/building.html])
+ ])
+], [[#include <libyang/libyang.h>]])
+CFLAGS="$ac_cflags_save"
+
+dnl ---------------
+dnl configuration rollbacks
+dnl ---------------
+SQLITE3=false
+if test "$enable_config_rollbacks" = "yes"; then
+ PKG_CHECK_MODULES([SQLITE3], [sqlite3], [
+ AC_DEFINE([HAVE_CONFIG_ROLLBACKS], [1], [Enable configuration rollbacks])
+ AC_DEFINE([HAVE_SQLITE3], [1], [Enable sqlite3 database])
+ SQLITE3=true
+ ], [
+ AC_MSG_ERROR([--enable-config-rollbacks given but sqlite3 was not found on your system.])
+ ])
+fi
+
+dnl ---------------
+dnl confd
+dnl ---------------
+if test "$enable_confd" != "" -a "$enable_confd" != "no"; then
+ AC_CHECK_PROG([CONFD], [confd], [confd], [/bin/false], "${enable_confd}/bin")
+ if test "$CONFD" = "/bin/false"; then
+ AC_MSG_ERROR([confd was not found on your system.])]
+ fi
+ AC_CHECK_PROG([CONFDC], [confdc], [confdc], [/bin/false], "${enable_confd}/bin")
+ CONFD_CFLAGS="-I${enable_confd}/include -L${enable_confd}/lib"
+ AC_SUBST([CONFD_CFLAGS])
+ CONFD_LIBS="-lconfd"
+ AC_SUBST([CONFD_LIBS])
+ AC_DEFINE([HAVE_CONFD], [1], [Enable confd integration])
+fi
+
+dnl ---------------
+dnl sysrepo
+dnl ---------------
+if test "$enable_sysrepo" = "yes"; then
+ PKG_CHECK_MODULES([SYSREPO], [sysrepo >= 2.1.42],
+ [AC_DEFINE([HAVE_SYSREPO], [1], [Enable sysrepo integration])
+ SYSREPO=true],
+ [SYSREPO=false
+ AC_MSG_ERROR([sysrepo was not found on your system.])]
+ )
+fi
+
+dnl ---------------
+dnl gRPC
+dnl ---------------
+if test "$enable_grpc" = "yes"; then
+ AC_LANG_PUSH([C++])
+ AX_CXX_COMPILE_STDCXX([11], [ext])
+ PKG_CHECK_MODULES([GRPC], [grpc >= 6.0.0 grpc++ >= 1.16.1 protobuf >= 3.6.1 ], [
+ AC_CHECK_PROGS([PROTOC], [protoc], [/bin/false])
+ if test "$PROTOC" = "/bin/false"; then
+ AC_MSG_FAILURE([grpc requested but protoc not found.])
+ fi
+
+ AC_DEFINE([HAVE_GRPC], [1], [Enable the gRPC northbound plugin])
+ GRPC=true
+ ], [
+ GRPC=false
+ AC_MSG_ERROR([grpc/grpc++ were not found on your system.])
+ ])
+ AC_LANG_POP([C++])
+fi
+
+dnl ---------
+dnl DPDK
+dnl ---------
+if test "$enable_dp_dpdk" = "yes"; then
+ PKG_CHECK_MODULES([DPDK], [libdpdk], [
+ AC_DEFINE([HAVE_DPDK], [1], [Enable DPDK backend])
+ DPDK=true
+ ], [
+ AC_MSG_ERROR([configuration specifies --enable-dp-dpdk but DPDK libs were not found])
+ ])
+fi
+
+dnl -----
+dnl LTTng
+dnl -----
+if test "$enable_lttng" = "yes"; then
+ PKG_CHECK_MODULES([UST], [lttng-ust >= 2.9.0], [
+ AC_DEFINE([HAVE_LTTNG], [1], [Enable LTTng support])
+ LTTNG=true
+ ], [
+ AC_MSG_ERROR([configuration specifies --enable-lttng but lttng-ust was not found])
+ ])
+fi
+
+dnl ----
+dnl USDT
+dnl ----
+if test "$enable_usdt" = "yes"; then
+ AC_CHECK_HEADERS([sys/sdt.h], [
+ AC_DEFINE([HAVE_USDT], [1], [Enable USDT probes])
+ USDT=true
+ ], [
+ AC_MSG_ERROR([configuration specifies --enable-usdt but no USDT kernel headers (sys/sdt.h) found])
+ ])
+fi
+
+dnl ------
+dnl ZeroMQ
+dnl ------
+if test "$enable_zeromq" != "no"; then
+ PKG_CHECK_MODULES([ZEROMQ], [libzmq >= 4.0.0], [
+ AC_DEFINE([HAVE_ZEROMQ], [1], [Enable ZeroMQ support])
+ ZEROMQ=true
+ ], [
+ if test "$enable_zeromq" = "yes"; then
+ AC_MSG_ERROR([configuration specifies --enable-zeromq but libzmq was not found])
+ fi
+ ])
+fi
+
+dnl ------------------------------------
+dnl Enable RPKI and add librtr to libs
+dnl ------------------------------------
+if test "$enable_rpki" = "yes"; then
+ PKG_CHECK_MODULES([RTRLIB], [rtrlib >= 0.8.0],
+ [RPKI=true],
+ [RPKI=false
+ AC_MSG_ERROR([rtrlib was not found on your system or is too old.])]
+ )
+fi
+
+dnl ------------------------------------
+dnl pimd and pim6d not supported on OpenBSD and MacOS
+dnl ------------------------------------
+if test "$enable_pimd" != "no"; then
+AC_MSG_CHECKING([for pimd OS support])
+case "$host_os" in
+ darwin*)
+ AC_MSG_RESULT([no])
+ enable_pimd="no"
+ ;;
+ openbsd*)
+ AC_MSG_RESULT([no])
+ enable_pimd="no"
+ ;;
+ *)
+ AC_MSG_RESULT([yes])
+ ;;
+esac
+fi
+
+if test "$enable_pim6d" != "no"; then
+AC_MSG_CHECKING([for pim6d OS support])
+case "$host_os" in
+ linux*)
+ AC_MSG_RESULT([yes])
+ ;;
+ *)
+ AC_MSG_RESULT([no])
+ enable_pim6d="no"
+ ;;
+esac
+fi
+
+dnl -------------------------------------
+dnl VRRP is only supported on linux
+dnl -------------------------------------
+if test "$enable_vrrpd" != "no"; then
+AC_MSG_CHECKING([for VRRP OS support])
+case "$host_os" in
+ linux*)
+ AC_MSG_RESULT([yes])
+ ;;
+ *)
+ AC_MSG_RESULT([no])
+ enable_vrrpd="no"
+ ;;
+esac
+fi
+
+dnl ------------------------------------------
+dnl Check whether rtrlib was build with ssh support
+dnl ------------------------------------------
+AC_MSG_CHECKING([whether the RTR Library is compiled with SSH])
+AC_LINK_IFELSE([AC_LANG_PROGRAM([[#include "rtrlib/rtrlib.h"]],
+ [[struct tr_ssh_config config;]])],
+ [AC_MSG_RESULT([yes])
+ AC_DEFINE([FOUND_SSH], [1], [found_ssh])],
+ AC_MSG_RESULT([no])
+)
+
+dnl ---------------
+dnl dlopen & dlinfo
+dnl ---------------
+LIBS_save="$LIBS"
+AC_SEARCH_LIBS([dlopen], [dl dld], [], [
+ AC_MSG_ERROR([unable to find the dlopen()])
+])
+
+AC_CHECK_HEADERS([link.h])
+
+AC_CACHE_CHECK([for dlinfo(RTLD_DI_ORIGIN)], [frr_cv_rtld_di_origin], [
+ AC_LINK_IFELSE([AC_LANG_PROGRAM([[
+#include <stdlib.h>
+#ifdef HAVE_LINK_H
+#include <link.h>
+#endif
+#include <dlfcn.h>
+]], [[
+ char origin[1];
+ dlinfo (NULL, RTLD_DI_ORIGIN, &origin);
+]])], [
+ frr_cv_rtld_di_origin=yes
+ ], [
+ frr_cv_rtld_di_origin=no
+ ])
+])
+if test "$frr_cv_rtld_di_origin" = "yes"; then
+ AC_DEFINE([HAVE_DLINFO_ORIGIN], [1], [Have dlinfo RTLD_DI_ORIGIN])
+fi
+
+AC_CACHE_CHECK([for dlinfo(RTLD_DI_LINKMAP)], [frr_cv_rtld_di_linkmap], [
+ AC_LINK_IFELSE([AC_LANG_PROGRAM([[
+#include <stdlib.h>
+#ifdef HAVE_LINK_H
+#include <link.h>
+#endif
+#include <dlfcn.h>
+]], [[
+ struct link_map *lm = NULL;
+ dlinfo (NULL, RTLD_DI_LINKMAP, &lm);
+]])], [
+ frr_cv_rtld_di_linkmap=yes
+ ], [
+ frr_cv_rtld_di_linkmap=no
+ ])
+])
+if test "$frr_cv_rtld_di_linkmap" = "yes"; then
+ AC_DEFINE([HAVE_DLINFO_LINKMAP], [1], [Have dlinfo RTLD_DI_LINKMAP])
+fi
+
+LIBDL="$LIBS"
+LIBDL="${LIBDL%$LIBS_save}"
+LIBDL="${LIBDL#$LIBS_save}"
+AC_SUBST([LIBDL])
+LIBS="$LIBS_save"
+unset LIBS_save
+
+dnl ##########################################################################
+dnl test "$enable_clippy_only" != "yes"
+fi
+dnl END OF LARGE if block
+dnl ##########################################################################
+
+dnl ---------------------------
+dnl sockaddr and netinet checks
+dnl ---------------------------
+AC_CHECK_TYPES([
+ struct sockaddr_dl,
+ struct vifctl, struct mfcctl, struct sioc_sg_req,
+ vifi_t, struct sioc_vif_req, struct igmpmsg,
+ struct ifaliasreq, struct if6_aliasreq, struct in6_aliasreq,
+ struct nd_opt_adv_interval,
+ struct nd_opt_homeagent_info, struct nd_opt_adv_interval,
+ struct nd_opt_rdnss, struct nd_opt_dnssl],
+ [], [], FRR_INCLUDES)
+
+AC_CHECK_MEMBERS([struct sockaddr.sa_len,
+ struct sockaddr_in.sin_len, struct sockaddr_un.sun_len,
+ struct sockaddr_dl.sdl_len,
+ struct if6_aliasreq.ifra_lifetime,
+ struct nd_opt_adv_interval.nd_opt_ai_type],
+ [], [], FRR_INCLUDES)
+
+dnl ---------------------------
+dnl IRDP/pktinfo/icmphdr checks
+dnl ---------------------------
+
+AC_CHECK_TYPES([struct in_pktinfo], [
+ AC_CHECK_TYPES([struct icmphdr], [
+ IRDP=true
+ ], [
+ IRDP=false
+ ], [FRR_INCLUDES])
+], [
+ IRDP=false
+], [FRR_INCLUDES])
+
+case "${enable_irdp}" in
+yes)
+ $IRDP || AC_MSG_ERROR(['IRDP requires in_pktinfo at the moment!'])
+ ;;
+no)
+ IRDP=false
+ ;;
+esac
+
+
+dnl -----------------------
+dnl checking for IP_PKTINFO
+dnl -----------------------
+AC_MSG_CHECKING([for IP_PKTINFO])
+AC_COMPILE_IFELSE(
+[ AC_LANG_PROGRAM([[
+ #include <netdb.h>
+ ]], [[
+ int opt = IP_PKTINFO;
+ ]])
+],[
+ AC_MSG_RESULT([yes])
+ AC_DEFINE([HAVE_IP_PKTINFO], [1], [Have IP_PKTINFO])
+],[
+ AC_MSG_RESULT([no])
+])
+
+dnl ---------------------------
+dnl checking for IP_RECVDSTADDR
+dnl ---------------------------
+AC_MSG_CHECKING([for IP_RECVDSTADDR])
+AC_COMPILE_IFELSE(
+[ AC_LANG_PROGRAM([[
+ #include <netinet/in.h>
+ ]], [[
+ int opt = IP_RECVDSTADDR;
+ ]])
+],[
+ AC_MSG_RESULT([yes])
+ AC_DEFINE([HAVE_IP_RECVDSTADDR], [1], [Have IP_RECVDSTADDR])
+],[
+ AC_MSG_RESULT([no])
+])
+
+dnl ----------------------
+dnl checking for IP_RECVIF
+dnl ----------------------
+AC_MSG_CHECKING([for IP_RECVIF])
+AC_COMPILE_IFELSE(
+[ AC_LANG_PROGRAM([[
+ #include <netinet/in.h>
+ ]], [[
+ int opt = IP_RECVIF;
+ ]])
+],[
+ AC_MSG_RESULT([yes])
+ AC_DEFINE([HAVE_IP_RECVIF], [1], [Have IP_RECVIF])
+],[
+ AC_MSG_RESULT([no])
+])
+
+dnl ----------------------
+dnl checking for SO_BINDANY
+dnl ----------------------
+AC_MSG_CHECKING([for SO_BINDANY])
+AC_COMPILE_IFELSE(
+[ AC_LANG_PROGRAM([[
+ #include <sys/socket.h>
+ ]], [[
+ int opt = SO_BINDANY;
+ ]])
+],[
+ AC_MSG_RESULT([yes])
+ AC_DEFINE([HAVE_SO_BINDANY], [1], [Have SO_BINDANY])
+],[
+ AC_MSG_RESULT([no])
+])
+
+dnl ----------------------
+dnl checking for IP_FREEBIND
+dnl ----------------------
+AC_MSG_CHECKING([for IP_FREEBIND])
+AC_COMPILE_IFELSE(
+[ AC_LANG_PROGRAM([[
+ #include <netinet/in.h>
+ ]], [[
+ int opt = IP_FREEBIND;
+ ]])
+],[
+ AC_MSG_RESULT([yes])
+ AC_DEFINE([HAVE_IP_FREEBIND], [1], [Have IP_FREEBIND])
+],[
+ AC_MSG_RESULT([no])
+])
+
+dnl --------------------------------------
+dnl checking for be32dec existence or not
+dnl --------------------------------------
+AC_CHECK_DECLS([be32enc, be32dec], [], [], [
+ #ifdef HAVE_SYS_ENDIAN_H
+ #include <sys/endian.h>
+ #endif
+ #ifdef HAVE_ENDIAN_H
+ #include <endian.h>
+ #endif
+])
+
+dnl --------------------------------------
+dnl checking for clock_time monotonic struct and call
+dnl --------------------------------------
+AC_CHECK_DECL([CLOCK_MONOTONIC],
+ [AC_CHECK_LIB([rt], [clock_gettime], [LIBS="$LIBS -lrt"])
+ AC_DEFINE([HAVE_CLOCK_MONOTONIC], [1], [Have monotonic clock])
+], [AC_MSG_RESULT([no])], [FRR_INCLUDES])
+
+AC_CHECK_DECL([CLOCK_THREAD_CPUTIME_ID], [
+ AC_DEFINE([HAVE_CLOCK_THREAD_CPUTIME_ID], [1], [Have cpu-time clock])
+], [AC_MSG_RESULT([no])], [FRR_INCLUDES])
+
+AC_SEARCH_LIBS([clock_nanosleep], [rt], [
+ AC_DEFINE([HAVE_CLOCK_NANOSLEEP], [1], [Have clock_nanosleep()])
+])
+
+dnl --------------------------------------
+dnl checking for flex and bison
+dnl --------------------------------------
+
+dnl autoconf 2.69 AC_PROG_LEX has no parameters
+dnl autoconf 2.70 AC_PROG_LEX prints a deprecation warning without params
+m4_if(m4_version_compare(m4_defn([AC_AUTOCONF_VERSION]), [2.70]), [-1], [dnl
+ dnl autoconf < 2.70
+ AC_PROG_LEX
+], [
+ dnl autoconf >= 2.70
+ AC_PROG_LEX([noyywrap])
+])
+
+AC_MSG_CHECKING([version of flex])
+frr_ac_flex_version="$(eval $LEX -V | grep flex | head -n 1)"
+frr_ac_flex_version="${frr_ac_flex_version##* }"
+AC_MSG_RESULT([$frr_ac_flex_version])
+AX_COMPARE_VERSION([$frr_ac_flex_version], [lt], [2.5.20], [
+ LEX="$SHELL $missing_dir/missing flex"
+ if test -f "${srcdir}/lib/command_lex.c" -a -f "${srcdir}/lib/command_lex.h"; then
+ AC_MSG_WARN([using pregenerated flex output files])
+ else
+ AC_MSG_ERROR([flex failure and pregenerated files not included (probably a git build)])
+ fi
+ AC_SUBST([LEX_OUTPUT_ROOT], [lex.yy])
+ AC_SUBST([LEXLIB], [''])
+])
+
+AC_PROG_YACC
+dnl thanks GNU bison for this b*llshit...
+AC_MSG_CHECKING([version of bison])
+frr_ac_bison_version="$(eval $YACC -V | grep bison | head -n 1)"
+frr_ac_bison_version="${frr_ac_bison_version##* }"
+frr_ac_bison_missing="false"
+case "x${frr_ac_bison_version}x" in
+ x2.7*)
+ BISON_OPENBRACE='"'
+ BISON_CLOSEBRACE='"'
+ BISON_VERBOSE=''
+ AC_MSG_RESULT([$frr_ac_bison_version - 2.7 or older])
+ ;;
+ x2.*|x1.*)
+ AC_MSG_RESULT([$frr_ac_bison_version])
+ AC_MSG_WARN([installed bison is too old. Please install GNU bison 2.7.x or newer.])
+ frr_ac_bison_missing="true"
+ ;;
+ x)
+ AC_MSG_RESULT([none])
+ AC_MSG_WARN([could not determine bison version. Please install GNU bison 2.7.x or newer.])
+ frr_ac_bison_missing="true"
+ ;;
+ x3.[012][^0-9]*)
+ BISON_OPENBRACE='{'
+ BISON_CLOSEBRACE='}'
+ BISON_VERBOSE='-Dparse.error=verbose'
+ AC_MSG_RESULT([$frr_ac_bison_version - 3.0 to 3.2])
+ ;;
+ *)
+ BISON_OPENBRACE='{'
+ BISON_CLOSEBRACE='}'
+ BISON_VERBOSE='-Dparse.error=verbose -Wno-yacc'
+ AC_MSG_RESULT([$frr_ac_bison_version - 3.3 or newer])
+ ;;
+esac
+AC_SUBST([BISON_OPENBRACE])
+AC_SUBST([BISON_CLOSEBRACE])
+AC_SUBST([BISON_VERBOSE])
+
+if $frr_ac_bison_missing; then
+ YACC="$SHELL $missing_dir/missing bison -y"
+ if test -f "${srcdir}/lib/command_parse.c" -a -f "${srcdir}/lib/command_parse.h"; then
+ AC_MSG_WARN([using pregenerated bison output files])
+ else
+ AC_MSG_ERROR([bison failure and pregenerated files not included (probably a git build)])
+ fi
+fi
+
+dnl -------------------
+dnl capabilities checks
+dnl -------------------
+if test "$enable_capabilities" != "no"; then
+ AC_MSG_CHECKING([whether prctl PR_SET_KEEPCAPS is available])
+ AC_COMPILE_IFELSE(
+ [ AC_LANG_PROGRAM([[
+ #include <sys/prctl.h>
+ ]], [[
+ prctl(PR_SET_KEEPCAPS, 1, 0, 0, 0);
+ ]])
+ ],[AC_MSG_RESULT([yes])
+ AC_DEFINE([HAVE_PR_SET_KEEPCAPS], [1], [prctl])
+ frr_ac_keepcaps="yes"
+ ],[AC_MSG_RESULT(no)
+ ])
+ if test "$frr_ac_keepcaps" = "yes"; then
+ AC_CHECK_HEADERS([sys/capability.h])
+ fi
+ if test "$ac_cv_header_sys_capability_h" = "yes"; then
+ AC_CHECK_LIB([cap], [cap_init],
+ [AC_DEFINE([HAVE_LCAPS], [1], [Capabilities])
+ LIBCAP="-lcap"
+ frr_ac_lcaps="yes"]
+ )
+ fi
+ if test "$frr_ac_scaps" = "yes" \
+ -o "$frr_ac_lcaps" = "yes"; then
+ AC_DEFINE([HAVE_CAPABILITIES], [1], [capabilities])
+ fi
+
+ case "$host_os" in
+ linux*)
+ if test "$enable_clippy_only" != "yes"; then
+ if test "$frr_ac_lcaps" != "yes"; then
+ AC_MSG_ERROR([libcap and/or its headers were not found. Running FRR without libcap support built in causes a huge performance penalty.])
+ fi
+ fi
+ ;;
+ esac
+else
+ case "$host_os" in
+ linux*)
+ AC_MSG_WARN([Running FRR without libcap support built in causes a huge performance penalty.])
+ ;;
+ esac
+fi
+AC_SUBST([LIBCAP])
+
+dnl ---------------------------
+dnl check for glibc 'backtrace'
+dnl ---------------------------
+if test "$enable_backtrace" != "no" ; then
+ backtrace_ok=no
+ PKG_CHECK_MODULES([UNWIND], [libunwind], [
+ AC_DEFINE([HAVE_LIBUNWIND], [1], [libunwind])
+ backtrace_ok=yes
+ ], [
+ true
+ ])
+
+ if test "$backtrace_ok" = "no"; then
+ AC_CHECK_HEADER([unwind.h], [
+ AC_SEARCH_LIBS([unw_getcontext], [unwind], [
+ AC_DEFINE([HAVE_LIBUNWIND], [1], [libunwind])
+ backtrace_ok=yes
+ ])
+ ])
+ fi
+
+ if test "$backtrace_ok" = "no"; then
+ AC_CHECK_HEADER([execinfo.h], [
+ AC_SEARCH_LIBS([backtrace], [execinfo], [
+ AC_DEFINE([HAVE_GLIBC_BACKTRACE], [1], [Glibc backtrace])
+ backtrace_ok=yes
+ ],, [-lm])
+ ])
+ fi
+
+ if test "$enable_backtrace" = "yes" -a "$backtrace_ok" = "no"; then
+ dnl user explicitly requested backtrace but we failed to find support
+ AC_MSG_FAILURE([failed to find backtrace or libunwind support])
+ fi
+fi
+
+dnl -----------------------------------------
+dnl check for malloc mallinfo struct and call
+dnl this must try and link using LIBS, in
+dnl order to check no alternative allocator
+dnl has been specified, which might not provide
+dnl mallinfo
+dnl -----------------------------------------
+AC_CHECK_HEADERS([malloc.h malloc_np.h malloc/malloc.h],,, [FRR_INCLUDES])
+
+AC_CACHE_CHECK([whether mallinfo is available], [frr_cv_mallinfo], [
+ AC_LINK_IFELSE([AC_LANG_PROGRAM([FRR_INCLUDES [
+#ifdef HAVE_MALLOC_H
+#include <malloc.h>
+#endif
+#ifdef HAVE_MALLOC_NP_H
+#include <malloc_np.h>
+#endif
+#ifdef HAVE_MALLOC_MALLOC_H
+#include <malloc/malloc.h>
+#endif
+]], [[
+struct mallinfo ac_x; ac_x = mallinfo ();
+]])], [
+ frr_cv_mallinfo=yes
+ ], [
+ frr_cv_mallinfo=no
+ ])
+])
+if test "$frr_cv_mallinfo" = "yes"; then
+ AC_DEFINE([HAVE_MALLINFO], [1], [mallinfo])
+fi
+
+AC_CACHE_CHECK([whether mallinfo2 is available], [frr_cv_mallinfo2], [
+ AC_LINK_IFELSE([AC_LANG_PROGRAM([FRR_INCLUDES [
+#ifdef HAVE_MALLOC_H
+#include <malloc.h>
+#endif
+#ifdef HAVE_MALLOC_NP_H
+#include <malloc_np.h>
+#endif
+#ifdef HAVE_MALLOC_MALLOC_H
+#include <malloc/malloc.h>
+#endif
+]], [[
+struct mallinfo2 ac_x; ac_x = mallinfo2 ();
+]])], [
+ frr_cv_mallinfo2=yes
+ ], [
+ frr_cv_mallinfo2=no
+ ])
+])
+if test "$frr_cv_mallinfo2" = "yes"; then
+ AC_DEFINE([HAVE_MALLINFO2], [1], [mallinfo2])
+fi
+
+AC_MSG_CHECKING([whether malloc_usable_size is available])
+AC_LINK_IFELSE([AC_LANG_PROGRAM([FRR_INCLUDES [
+#ifdef HAVE_MALLOC_H
+#include <malloc.h>
+#endif
+#ifdef HAVE_MALLOC_MALLOC_H
+#include <malloc/malloc.h>
+#endif
+]], [[
+size_t ac_x; ac_x = malloc_usable_size(NULL);
+]])], [
+ AC_MSG_RESULT([yes])
+ AC_DEFINE([HAVE_MALLOC_USABLE_SIZE], [1], [malloc_usable_size])
+], [
+ AC_MSG_RESULT([no])
+
+ AC_MSG_CHECKING([whether malloc_size is available])
+ AC_LINK_IFELSE([AC_LANG_PROGRAM([[
+#ifdef HAVE_MALLOC_H
+#include <malloc.h>
+#endif
+#ifdef HAVE_MALLOC_MALLOC_H
+#include <malloc/malloc.h>
+#endif
+]], [[
+size_t ac_x; ac_x = malloc_size(NULL);
+]])], [
+ AC_MSG_RESULT([yes])
+ AC_DEFINE([HAVE_MALLOC_SIZE], [1], [malloc_size])
+ ], [
+ AC_MSG_RESULT([no])
+ ])
+])
+
+dnl ----------
+dnl configure date
+dnl ----------
+dev_version=`echo $VERSION | grep dev`
+#don't expire deprecated code in non 'dev' branch
+if test "$dev_version" = ""; then
+ CONFDATE=0
+else
+ CONFDATE=`date '+%Y%m%d'`
+fi
+AC_SUBST([CONFDATE])
+
+dnl ------------------------------
+dnl set paths for state directory
+dnl ------------------------------
+AC_MSG_CHECKING([directory to use for state file])
+if test "$prefix" = "NONE"; then
+ frr_statedir_prefix="";
+else
+ frr_statedir_prefix=${prefix}
+fi
+if test "$localstatedir" = '${prefix}/var'; then
+ for FRR_STATE_DIR in ${frr_statedir_prefix}/var/run dnl
+ ${frr_statedir_prefix}/var/adm dnl
+ ${frr_statedir_prefix}/etc dnl
+ /var/run dnl
+ /var/adm dnl
+ /etc dnl
+ /dev/null;
+ do
+ test -d $FRR_STATE_DIR && break
+ done
+ frr_statedir=$FRR_STATE_DIR
+else
+ frr_statedir=${localstatedir}
+fi
+if test "$frr_statedir" = "/dev/null"; then
+ AC_MSG_ERROR([STATE DIRECTORY NOT FOUND! FIX OR SPECIFY --localstatedir!])
+fi
+AC_MSG_RESULT([${frr_statedir}])
+AC_SUBST([frr_statedir])
+
+AC_DEFINE_UNQUOTED([LDPD_SOCKET], ["$frr_statedir%s%s/ldpd.sock"], [ldpd control socket])
+AC_DEFINE_UNQUOTED([ZEBRA_SERV_PATH], ["$frr_statedir%s%s/zserv.api"], [zebra api socket])
+AC_DEFINE_UNQUOTED([BFDD_CONTROL_SOCKET], ["$frr_statedir%s%s/bfdd.sock"], [bfdd control socket])
+AC_DEFINE_UNQUOTED([OSPFD_GR_STATE], ["$frr_statedir%s/ospfd-gr.json"], [ospfd GR state information])
+AC_DEFINE_UNQUOTED([MGMTD_FE_SERVER_PATH], ["$frr_statedir/mgmtd_fe.sock"], [mgmtd frontend server socket])
+AC_DEFINE_UNQUOTED([MGMTD_BE_SERVER_PATH], ["$frr_statedir/mgmtd_be.sock"], [mgmtd backend server socket])
+AC_DEFINE_UNQUOTED([OSPF6D_GR_STATE], ["$frr_statedir/ospf6d-gr.json"], [ospf6d GR state information])
+AC_DEFINE_UNQUOTED([ISISD_RESTART], ["$frr_statedir%s/isid-restart.json"], [isisd restart information])
+AC_DEFINE_UNQUOTED([OSPF6_AUTH_SEQ_NUM_FILE], ["$frr_statedir/ospf6d-at-seq-no.dat"], [ospf6d AT Sequence number information])
+AC_DEFINE_UNQUOTED([DAEMON_VTY_DIR], ["$frr_statedir%s%s"], [daemon vty directory])
+AC_DEFINE_UNQUOTED([DAEMON_DB_DIR], ["$frr_statedir"], [daemon database directory])
+
+dnl autoconf does this, but it does it too late...
+test "$prefix" = "NONE" && prefix=$ac_default_prefix
+test "$exec_prefix" = "NONE" && exec_prefix='${prefix}'
+
+dnl get the full path, recursing through variables...
+vtysh_bin="$bindir/vtysh"
+for I in 1 2 3 4 5 6 7 8 9 10; do
+ eval vtysh_bin="\"$vtysh_bin\""
+done
+AC_DEFINE_UNQUOTED([VTYSH_BIN_PATH], ["$vtysh_bin"], [path to vtysh binary])
+AC_SUBST([vtysh_bin])
+
+CFG_SYSCONF="$sysconfdir"
+CFG_SBIN="$sbindir"
+CFG_BIN="$bindir"
+CFG_STATE="$frr_statedir"
+CFG_MODULE="$moduledir"
+CFG_YANGMODELS="$yangmodelsdir"
+CFG_SCRIPT="$scriptdir"
+for I in 1 2 3 4 5 6 7 8 9 10; do
+ eval CFG_SYSCONF="\"$CFG_SYSCONF\""
+ eval CFG_SBIN="\"$CFG_SBIN\""
+ eval CFG_BIN="\"$CFG_BIN\""
+ eval CFG_STATE="\"$CFG_STATE\""
+ eval CFG_MODULE="\"$CFG_MODULE\""
+ eval CFG_YANGMODELS="\"$CFG_YANGMODELS\""
+ eval CFG_SCRIPT="\"$CFG_SCRIPT\""
+done
+AC_SUBST([CFG_SYSCONF])
+AC_SUBST([CFG_SBIN])
+AC_SUBST([CFG_BIN])
+AC_SUBST([CFG_STATE])
+AC_SUBST([CFG_MODULE])
+AC_SUBST([CFG_SCRIPT])
+AC_SUBST([CFG_YANGMODELS])
+AC_DEFINE_UNQUOTED([MODULE_PATH], ["$CFG_MODULE"], [path to modules])
+AC_DEFINE_UNQUOTED([SCRIPT_PATH], ["$CFG_SCRIPT"], [path to scripts])
+AC_DEFINE_UNQUOTED([YANG_MODELS_PATH], ["$CFG_YANGMODELS"], [path to YANG data models])
+AC_DEFINE_UNQUOTED([WATCHFRR_SH_PATH], ["${CFG_SBIN%/}/watchfrr.sh"], [path to watchfrr.sh])
+
+dnl various features
+AM_CONDITIONAL([SUPPORT_REALMS], [test "$enable_realms" = "yes"])
+AM_CONDITIONAL([ENABLE_BGP_VNC], [test "$enable_bgp_vnc" != "no"])
+AM_CONDITIONAL([BGP_BMP], [$bgpd_bmp])
+dnl northbound
+AM_CONDITIONAL([SQLITE3], [$SQLITE3])
+AM_CONDITIONAL([CONFD], [test "$enable_confd" != ""])
+AM_CONDITIONAL([SYSREPO], [test "$enable_sysrepo" = "yes"])
+AM_CONDITIONAL([GRPC], [test "$enable_grpc" = "yes"])
+AM_CONDITIONAL([ZEROMQ], [test "$ZEROMQ" = "true"])
+dnl plugins
+AM_CONDITIONAL([RPKI], [test "$RPKI" = "true"])
+AM_CONDITIONAL([SNMP], [test "$SNMP_METHOD" = "agentx"])
+AM_CONDITIONAL([IRDP], [$IRDP])
+AM_CONDITIONAL([FPM], [test "$enable_fpm" = "yes"])
+AM_CONDITIONAL([HAVE_PROTOBUF], [test "$enable_protobuf" != "no"])
+AM_CONDITIONAL([HAVE_PROTOBUF3], [$PROTO3])
+
+dnl PCEP plugin
+AS_IF([test "$enable_pathd" != "no"], [
+ AC_SUBST([PATHD_PCEP_LIBS], ["pceplib/libpcep_pcc.la"])
+ AC_SUBST([PATHD_PCEP_INCL], ["-I./pceplib "])
+ ])
+AC_CHECK_LIB([cunit], [CU_initialize_registry], [pcep_cunit=yes],[pcep_cunit=no])
+AM_CONDITIONAL([PATHD_PCEP_TEST], [test "x${pcep_cunit}" = xyes])
+AC_CHECK_PROG(VALGRIND_CHECK, valgrind, yes)
+AM_CONDITIONAL([HAVE_VALGRIND_PCEP], [test "$VALGRIND_CHECK" = "yes"])
+
+dnl daemons
+AM_CONDITIONAL([VTYSH], [test "$VTYSH" = "vtysh"])
+AM_CONDITIONAL([ZEBRA], [test "$enable_zebra" != "no"])
+AM_CONDITIONAL([BGPD], [test "$enable_bgpd" != "no"])
+AM_CONDITIONAL([MGMTD], [test "$enable_mgmtd" != "no"])
+AM_CONDITIONAL([RIPD], [test "$enable_ripd" != "no"])
+AM_CONDITIONAL([OSPFD], [test "$enable_ospfd" != "no"])
+AM_CONDITIONAL([LDPD], [test "$enable_ldpd" != "no"])
+AM_CONDITIONAL([BFDD], [test "$BFDD" = "bfdd"])
+AM_CONDITIONAL([NHRPD], [test "$NHRPD" = "nhrpd"])
+AM_CONDITIONAL([EIGRPD], [test "$enable_eigrpd" != "no"])
+AM_CONDITIONAL([WATCHFRR], [test "$WATCHFRR" = "watchfrr"])
+AM_CONDITIONAL([OSPFCLIENT], [test "$OSPFCLIENT" = "ospfclient"])
+AM_CONDITIONAL([RIPNGD], [test "$enable_ripngd" != "no"])
+AM_CONDITIONAL([BABELD], [test "$enable_babeld" != "no"])
+AM_CONDITIONAL([OSPF6D], [test "$enable_ospf6d" != "no"])
+AM_CONDITIONAL([ISISD], [test "$enable_isisd" != "no"])
+AM_CONDITIONAL([PIMD], [test "$enable_pimd" != "no"])
+AM_CONDITIONAL([PIM6D], [test "$enable_pim6d" != "no"])
+AM_CONDITIONAL([PBRD], [test "$enable_pbrd" != "no"])
+AM_CONDITIONAL([SHARPD], [test "$enable_sharpd" = "yes"])
+AM_CONDITIONAL([STATICD], [test "$enable_staticd" != "no"])
+AM_CONDITIONAL([FABRICD], [test "$enable_fabricd" != "no"])
+AM_CONDITIONAL([VRRPD], [test "$enable_vrrpd" != "no"])
+AM_CONDITIONAL([PATHD], [test "$enable_pathd" != "no"])
+AM_CONDITIONAL([PATHD_PCEP], [test "$enable_pathd" != "no"])
+AM_CONDITIONAL([DP_DPDK], [test "$enable_dp_dpdk" = "yes"])
+
+AC_CONFIG_FILES([Makefile],[
+ test "$enable_dev_build" = "yes" && makefile_devbuild="--dev-build"
+ ${PYTHON} "${ac_abs_top_srcdir}/python/makefile.py" ${makefile_devbuild} || exit 1
+], [
+ PYTHON="$PYTHON"
+ enable_dev_build="$enable_dev_build"
+])
+
+AC_CONFIG_FILES([
+ config.version
+ redhat/frr.spec
+ alpine/APKBUILD
+ snapcraft/snapcraft.yaml
+ lib/version.h
+ tests/lib/cli/test_cli.refout pkgsrc/mgmtd.sh
+ pkgsrc/bgpd.sh pkgsrc/ospf6d.sh pkgsrc/ospfd.sh
+ pkgsrc/ripd.sh pkgsrc/ripngd.sh pkgsrc/zebra.sh
+ pkgsrc/eigrpd.sh])
+
+AC_CONFIG_FILES([tools/frr], [chmod +x tools/frr])
+AC_CONFIG_FILES([tools/watchfrr.sh], [chmod +x tools/watchfrr.sh])
+AC_CONFIG_FILES([tools/frrinit.sh], [chmod +x tools/frrinit.sh])
+AC_CONFIG_FILES([tools/frrcommon.sh])
+AC_CONFIG_FILES([tools/frr.service])
+AC_CONFIG_FILES([tools/frr@.service])
+
+# dnl write out a ccls file with our compile configuration
+# dnl have to add -Wno-unused-function otherwise foobar_cmd_magic causes
+# dnl all DEFPY(), et al., macros to flag as errors.
+AS_IF([test "$enable_ccls" = "yes"], [
+ AC_CONFIG_COMMANDS([gen-dot-ccls], [
+ cat > "${srcdir}/.ccls" <<EOF
+clang
+-DHAVE_CONFIG_H
+-I.
+-I./include
+-I./lib
+-I./lib/assert
+-DSYSCONFDIR="${ac_frr_sysconfdir}"
+-DCONFDATE=${ac_frr_confdate}
+EOF
+ if test "$ac_abs_top_builddir" != "$ac_abs_top_srcdir"; then
+ echo "-I${ac_abs_top_builddir}" >> "${srcdir}/.ccls"
+ fi
+ if test -n "$FRR_ALL_CCLS_FLAGS"; then
+ echo ${FRR_ALL_CCLS_FLAGS} | tr ' ' '\n' >> "${srcdir}/.ccls"
+ fi
+ if test -n "$FRR_ALL_CCLS_CFLAGS"; then
+ cat >> "${srcdir}/.ccls" <<EOF
+%c $(echo ${FRR_ALL_CCLS_CFLAGS} | sed -e 's/ */\n%c /g')
+%c -Wno-unused-function
+%c -Wno-microsoft
+EOF
+fi
+ ], [
+ FRR_ALL_CCLS_FLAGS="$(echo ${LIBYANG_CFLAGS} ${LUA_INCLUDE} ${SQLITE3_CFLAGS} | sed -e 's/ */ /g')"
+ FRR_ALL_CCLS_CFLAGS="$(echo ${CFLAGS} ${WERROR} ${AC_CFLAGS} ${SAN_FLAGS} | sed -e 's/ */ /g')"
+ ac_frr_confdate="${CONFDATE}"
+ ac_frr_sysconfdir="${sysconfdir}/"
+ ])
+])
+
+
+AS_IF([test "$with_pkg_git_version" = "yes"], [
+ AC_CONFIG_COMMANDS([lib/gitversion.h], [
+ dst="${ac_abs_top_builddir}/lib/gitversion.h"
+ ${PERL} "${ac_abs_top_srcdir}/lib/gitversion.pl" \
+ "${ac_abs_top_srcdir}" \
+ > "${dst}.tmp"
+ test -f "$dst" \
+ && diff "${dst}.tmp" "${dst}" >/dev/null 2>/dev/null \
+ && rm "${dst}.tmp" \
+ || mv "${dst}.tmp" "${dst}"
+ ], [
+ PERL="$PERL"
+ ])
+])
+
+## Hack, but working solution to avoid rebuilding of frr.info.
+## It's already in CVS until texinfo 4.7 is more common.
+AC_OUTPUT
+
+if test "$enable_rpath" = "yes" ; then
+ true
+else
+ # See https://old-en.opensuse.org/openSUSE:Packaging_Guidelines#Removing_Rpath
+ sed -e 's|^hardcode_libdir_flag_spec=.*|hardcode_libdir_flag_spec=""|g' libtool > libtool.sed && cat libtool.sed > libtool
+ sed -e 's|^runpath_var=LD_RUN_PATH|runpath_var=DIE_RPATH_DIE|g' libtool > libtool.sed && cat libtool.sed > libtool
+ test -f libtool.sed && rm libtool.sed
+fi
+
+echo "
+FRRouting configuration
+------------------------------
+FRR version : ${PACKAGE_VERSION}
+host operating system : ${host_os}
+source code location : ${srcdir}
+compiler : ${CC}
+compiler flags : ${CFLAGS} ${WERROR} ${AC_CFLAGS} ${SAN_FLAGS}
+make : ${MAKE-make}
+linker flags : ${LDFLAGS} ${SAN_FLAGS} ${LIBS} ${LIBCAP} ${LIBREADLINE} ${LIBM}
+state file directory : ${frr_statedir}
+config file directory : `eval echo \`echo ${sysconfdir}\``
+module directory : ${CFG_MODULE}
+script directory : ${CFG_SCRIPT}
+user to run as : ${enable_user}
+group to run as : ${enable_group}
+group for vty sockets : ${enable_vty_group}
+config file mask : ${enable_configfile_mask}
+log file mask : ${enable_logfile_mask}
+zebra protobuf enabled : ${enable_protobuf:-no}
+vici socket path : ${vici_socket}
+
+The above user and group must have read/write access to the state file
+directory and to the config files in the config file directory."
+
+if test -n "$enable_datacenter"; then
+ AC_MSG_WARN([The --enable-datacenter compile time option is deprecated. Please modify the init script to pass -F datacenter to the daemons instead.])
+fi
+
+if test "$enable_doc" != "no" -a "$frr_py_mod_sphinx" = "false"; then
+ AC_MSG_WARN([sphinx is missing but required to build documentation])
+fi
+if test "$frr_py_mod_pytest" = "false"; then
+ AC_MSG_WARN([pytest is missing, unit tests cannot be performed])
+fi