|
Packit |
c22fc9 |
#
|
|
Packit |
c22fc9 |
# Keepalived OpenSource project.
|
|
Packit |
c22fc9 |
#
|
|
Packit |
c22fc9 |
# Configuration template file for keepalived.
|
|
Packit |
c22fc9 |
# autoconf will generate & check deps for proper compilation
|
|
Packit |
c22fc9 |
#
|
|
Packit |
c22fc9 |
# Copyright (C) 2001-2018 Alexandre Cassen, <acassen@linux-vs.org>
|
|
Packit |
c22fc9 |
|
|
Packit |
c22fc9 |
AC_DEFUN([add_to_var], [$1="$$1 $2"])
|
|
Packit |
c22fc9 |
AC_DEFUN([add_to_var_ind], [eval $1=\"\$$1 $2\"]) dnl "
|
|
Packit |
c22fc9 |
|
|
Packit |
c22fc9 |
AC_DEFUN([add_to_var_ind_unique],
|
|
Packit |
c22fc9 |
ADD_NEW=
|
|
Packit |
c22fc9 |
[ eval var=\$$1
|
|
Packit |
c22fc9 |
for item in $2; do
|
|
Packit |
c22fc9 |
echo " $var " | $GREP -q " $item "
|
|
Packit |
c22fc9 |
if test $? -ne 0; then
|
|
Packit |
c22fc9 |
add_to_var([ADD_NEW], [$item])
|
|
Packit |
c22fc9 |
fi
|
|
Packit |
c22fc9 |
done
|
|
Packit |
c22fc9 |
add_to_var_ind([$1], [$ADD_NEW])
|
|
Packit |
c22fc9 |
])
|
|
Packit |
c22fc9 |
|
|
Packit |
c22fc9 |
AC_DEFUN([add_pkg_config],
|
|
Packit |
c22fc9 |
[ if test -n "$2"; then
|
|
Packit |
c22fc9 |
KA_PKG_PFX=$2
|
|
Packit |
c22fc9 |
else
|
|
Packit |
c22fc9 |
KA_PKG_PFX=KA
|
|
Packit |
c22fc9 |
fi
|
|
Packit |
c22fc9 |
add_to_var_ind_unique([${KA_PKG_PFX}_CPPFLAGS], [`$PKG_CONFIG --cflags-only-I $1`])
|
|
Packit |
c22fc9 |
add_to_var_ind_unique([${KA_PKG_PFX}_CFLAGS], [`$PKG_CONFIG --cflags-only-other $1`])
|
|
Packit |
c22fc9 |
|
|
Packit |
c22fc9 |
if test .$3 = .remove-requires; then
|
|
Packit |
c22fc9 |
REQUIRES=`$PKG_CONFIG --print-requires $1`
|
|
Packit |
c22fc9 |
var=`$PKG_CONFIG --libs-only-l $1`
|
|
Packit |
c22fc9 |
for r in $REQUIRES; do
|
|
Packit |
c22fc9 |
REQ_LIBS=`$PKG_CONFIG --libs-only-l $r`
|
|
Packit |
c22fc9 |
for l in $REQ_LIBS; do
|
|
Packit |
c22fc9 |
var=`echo " $var " | sed -e "s: $l : :g"`
|
|
Packit |
c22fc9 |
done
|
|
Packit |
c22fc9 |
done
|
|
Packit |
c22fc9 |
var=`echo $var | sed -e "s:^ *::" -e "s: *$::"`
|
|
Packit |
c22fc9 |
eval ${KA_PKG_PFX}_LIBS="\"$var\""
|
|
Packit |
c22fc9 |
|
|
Packit |
c22fc9 |
var=`echo $var | sed -e "s/-l//g"`
|
|
Packit |
c22fc9 |
eval ${KA_PKG_PFX}_LIB_NAMES="\"$var\""
|
|
Packit |
c22fc9 |
else
|
|
Packit |
c22fc9 |
add_to_var_ind_unique([${KA_PKG_PFX}_LIBS], [`$PKG_CONFIG --libs $1`])
|
|
Packit |
c22fc9 |
fi
|
|
Packit |
c22fc9 |
])
|
|
Packit |
c22fc9 |
|
|
Packit |
c22fc9 |
AC_DEFUN([add_pkg_config_without_libs],
|
|
Packit |
c22fc9 |
[ if test -n "$2"; then
|
|
Packit |
c22fc9 |
KA_PKG_PFX=$2
|
|
Packit |
c22fc9 |
else
|
|
Packit |
c22fc9 |
KA_PKG_PFX=KA
|
|
Packit |
c22fc9 |
fi
|
|
Packit |
c22fc9 |
add_to_var_ind_unique([${KA_PKG_PFX}_CPPFLAGS], [$($PKG_CONFIG --cflags-only-I $1)])
|
|
Packit |
c22fc9 |
add_to_var_ind_unique([${KA_PKG_PFX}_CFLAGS], [$($PKG_CONFIG --cflags-only-other $1)])
|
|
Packit |
c22fc9 |
])
|
|
Packit |
c22fc9 |
|
|
Packit |
c22fc9 |
AC_DEFUN([add_config_opt], [add_to_var([CONFIG_OPTIONS], [$1])])
|
|
Packit |
c22fc9 |
|
|
Packit |
c22fc9 |
AC_DEFUN([add_system_opt], [add_to_var([SYSTEM_OPTIONS], [$1])])
|
|
Packit |
c22fc9 |
|
|
Packit |
c22fc9 |
AC_DEFUN([get_lib_name],
|
|
Packit |
c22fc9 |
[
|
|
Packit |
c22fc9 |
if test $LDD = :; then
|
|
Packit |
c22fc9 |
AC_MSG_ERROR([ldd is required for dynamic run-time linking support])
|
|
Packit |
c22fc9 |
fi
|
|
Packit |
c22fc9 |
|
|
Packit |
c22fc9 |
SAV_LIBS="$LIBS"
|
|
Packit |
c22fc9 |
LIBS=-l$1
|
|
Packit |
c22fc9 |
AC_LINK_IFELSE([AC_LANG_SOURCE([[
|
|
Packit |
c22fc9 |
extern void $2(void);
|
|
Packit |
c22fc9 |
int main(void)
|
|
Packit |
c22fc9 |
{
|
|
Packit |
c22fc9 |
$2();
|
|
Packit |
c22fc9 |
return 0;
|
|
Packit |
c22fc9 |
}
|
|
Packit |
c22fc9 |
]])], [
|
|
Packit |
c22fc9 |
LIB_DETAILS=`$LDD ./conftest$EXEEXT | grep $1.so | sed -e "s/^[[ \t]]*//"`
|
|
Packit |
c22fc9 |
LIB_NAME=`echo $LIB_DETAILS | sed -e "s/ .*//"`
|
|
Packit |
c22fc9 |
],[
|
|
Packit |
c22fc9 |
])
|
|
Packit |
c22fc9 |
LIBS="$SAV_LIBS"
|
|
Packit |
c22fc9 |
])
|
|
Packit |
c22fc9 |
|
|
Packit |
c22fc9 |
# AS_VAR_COPY was introduced in autoconf 2.63b.
|
|
Packit |
c22fc9 |
# Remove the following definition once require autoconf >= 2.64.
|
|
Packit |
c22fc9 |
m4_ifndef([AS_VAR_COPY],
|
|
Packit |
c22fc9 |
[m4_define([AS_VAR_COPY],
|
|
Packit |
c22fc9 |
[AS_LITERAL_IF([$1[]$2], [$1=$$2], [eval $1=\$$2])])])
|
|
Packit |
c22fc9 |
|
|
Packit |
c22fc9 |
dnl ----[ Process this file with autoconf to produce a configure script ]----
|
|
Packit |
c22fc9 |
AC_PREREQ([2.63])
|
|
Packit |
c22fc9 |
AC_INIT([Keepalived], [2.0.10], [keepalived-devel@lists.sourceforge.net], [], [http://www.keepalived.org/])
|
|
Packit |
c22fc9 |
AM_INIT_AUTOMAKE([-Wall -Werror -Woverride foreign])
|
|
Packit |
c22fc9 |
|
|
Packit |
c22fc9 |
AC_CONFIG_SRCDIR([keepalived/core/main.c])
|
|
Packit |
c22fc9 |
|
|
Packit |
c22fc9 |
AC_CONFIG_HEADERS([lib/config.h])
|
|
Packit |
c22fc9 |
AH_TOP(
|
|
Packit |
c22fc9 |
[
|
|
Packit |
c22fc9 |
#ifndef _CONFIG_H
|
|
Packit |
c22fc9 |
#define _CONFIG_H
|
|
Packit |
c22fc9 |
])
|
|
Packit |
c22fc9 |
AH_BOTTOM(
|
|
Packit |
c22fc9 |
[
|
|
Packit |
c22fc9 |
#ifndef _GNU_SOURCE
|
|
Packit |
c22fc9 |
#define _GNU_SOURCE
|
|
Packit |
c22fc9 |
#endif
|
|
Packit |
c22fc9 |
|
|
Packit |
c22fc9 |
#endif])
|
|
Packit |
c22fc9 |
|
|
Packit |
c22fc9 |
AC_CONFIG_FILES([Makefile keepalived/Makefile lib/Makefile keepalived/core/Makefile keepalived.spec \
|
|
Packit |
c22fc9 |
genhash/Makefile keepalived/check/Makefile keepalived/vrrp/Makefile \
|
|
Packit |
c22fc9 |
keepalived/bfd/Makefile doc/Makefile bin_install/Makefile keepalived/dbus/Makefile \
|
|
Packit |
c22fc9 |
keepalived/etc/Makefile keepalived/etc/init/Makefile keepalived/etc/init.d/Makefile \
|
|
Packit |
c22fc9 |
doc/man/man8/Makefile])
|
|
Packit |
c22fc9 |
|
|
Packit |
c22fc9 |
|
|
Packit |
c22fc9 |
MAINTAINERCLEANFILES="*~ *.orig *.rej core core.*"
|
|
Packit |
c22fc9 |
AC_SUBST(MAINTAINERCLEANFILES)
|
|
Packit |
c22fc9 |
CONFIG_OPTIONS=
|
|
Packit |
c22fc9 |
SYSTEM_OPTIONS=
|
|
Packit |
c22fc9 |
|
|
Packit |
c22fc9 |
AM_SILENT_RULES([yes])
|
|
Packit |
c22fc9 |
|
|
Packit |
c22fc9 |
PKG_PROG_PKG_CONFIG
|
|
Packit |
c22fc9 |
|
|
Packit |
c22fc9 |
dnl ----[ Keepalived specific configure options ]----
|
|
Packit |
c22fc9 |
AC_ARG_ENABLE(lvs-syncd,
|
|
Packit |
c22fc9 |
[AS_HELP_STRING([--disable-lvs-syncd], [do not use LVS synchronization daemon])])
|
|
Packit |
c22fc9 |
AC_ARG_ENABLE(lvs,
|
|
Packit |
c22fc9 |
[AS_HELP_STRING([--disable-lvs], [do not use the LVS framework])])
|
|
Packit |
c22fc9 |
AC_ARG_ENABLE(lvs-64bit-stats,
|
|
Packit |
c22fc9 |
[AS_HELP_STRING([--disable-lvs-64bit-stats], [do not use the LVS 64-bit stats])])
|
|
Packit |
c22fc9 |
AC_ARG_ENABLE(vrrp,
|
|
Packit |
c22fc9 |
[AS_HELP_STRING([--disable-vrrp], [do not use the VRRP framework])])
|
|
Packit |
c22fc9 |
AC_ARG_ENABLE(bfd,
|
|
Packit |
c22fc9 |
[AS_HELP_STRING([--enable-bfd], [use the BFD framework])])
|
|
Packit |
c22fc9 |
AC_ARG_WITH(kernel-dir,
|
|
Packit |
c22fc9 |
[AS_HELP_STRING([--with-kernel-dir=DIR], [path to linux kernel source directory])],
|
|
Packit |
c22fc9 |
[AS_HELP_STRING([kernel_src_path="$withval"],], [[kernel_src_path=""])])
|
|
Packit |
c22fc9 |
AC_ARG_ENABLE(fwmark,
|
|
Packit |
c22fc9 |
[AS_HELP_STRING([--disable-fwmark], [compile without SO_MARK support])])
|
|
Packit |
c22fc9 |
AC_ARG_ENABLE(snmp,
|
|
Packit |
c22fc9 |
[AS_HELP_STRING([--enable-snmp], [compile with SNMP support])])
|
|
Packit |
c22fc9 |
AC_ARG_ENABLE(snmp-vrrp,
|
|
Packit |
c22fc9 |
[AS_HELP_STRING([--enable-snmp-vrrp], [compile with SNMP vrrp support])])
|
|
Packit |
c22fc9 |
AC_ARG_ENABLE(snmp-keepalived,
|
|
Packit |
c22fc9 |
[AS_HELP_STRING([--enable-snmp-keepalived], [obsolete - use --enable-snmp-vrrp])])
|
|
Packit |
c22fc9 |
AC_ARG_ENABLE(snmp-checker,
|
|
Packit |
c22fc9 |
[AS_HELP_STRING([--enable-snmp-checker], [compile with SNMP checker support])])
|
|
Packit |
c22fc9 |
AC_ARG_ENABLE(snmp-rfc,
|
|
Packit |
c22fc9 |
[AS_HELP_STRING([--enable-snmp-rfc], [compile with SNMP RFC2787 (VRRPv2) and SNMP RFC6527 (VRRPv3) support])])
|
|
Packit |
c22fc9 |
AC_ARG_ENABLE(snmp-rfcv2,
|
|
Packit |
c22fc9 |
[AS_HELP_STRING([--enable-snmp-rfcv2], [compile with SNMP RFC2787 (VRRPv2) support])])
|
|
Packit |
c22fc9 |
AC_ARG_ENABLE(snmp-rfcv3,
|
|
Packit |
c22fc9 |
[AS_HELP_STRING([--enable-snmp-rfcv3], [compile with SNMP RFC6257 (VRRPv3) support])])
|
|
Packit |
c22fc9 |
AC_ARG_ENABLE(snmp-reply-v3-for-v2,
|
|
Packit |
c22fc9 |
[AS_HELP_STRING([--disable-snmp-reply-v3-for-v2], [disable RFC6257 responses for VRRPv2 instances])])
|
|
Packit |
c22fc9 |
AC_ARG_ENABLE(dbus,
|
|
Packit |
c22fc9 |
[AS_HELP_STRING([--enable-dbus], [compile with dbus support])])
|
|
Packit |
c22fc9 |
AC_ARG_ENABLE(dbus-create-instance,
|
|
Packit |
c22fc9 |
[AS_HELP_STRING([--enable-dbus-create-instance], [compile with dbus support for creating instances])])
|
|
Packit |
c22fc9 |
AC_ARG_ENABLE(sha1,
|
|
Packit |
c22fc9 |
[AS_HELP_STRING([--enable-sha1], [compile with SHA1 support])])
|
|
Packit |
c22fc9 |
AC_ARG_ENABLE(regex,
|
|
Packit |
c22fc9 |
[AS_HELP_STRING([--enable-regex], [build with HTTP_GET regex checking])])
|
|
Packit |
c22fc9 |
AC_ARG_ENABLE(regex-timers,
|
|
Packit |
c22fc9 |
[AS_HELP_STRING([--enable-regex-timers], [build with HTTP_GET regex timers])])
|
|
Packit |
c22fc9 |
AC_ARG_ENABLE(json,
|
|
Packit |
c22fc9 |
[AS_HELP_STRING([--enable-json], [compile with signal to dump configuration and stats as json])])
|
|
Packit |
c22fc9 |
AC_ARG_WITH(init,
|
|
Packit |
c22fc9 |
[AS_HELP_STRING([--with-init=(upstart|systemd|SYSV|SUSE|openrc)], [specify init type])],
|
|
Packit |
c22fc9 |
[init_type="$withval"], [init_type=""])
|
|
Packit |
c22fc9 |
AC_ARG_ENABLE(vrrp-auth,
|
|
Packit |
c22fc9 |
[AS_HELP_STRING([--disable-vrrp-auth], [compile without VRRP authentication])])
|
|
Packit |
c22fc9 |
AC_ARG_ENABLE(checksum_compat,
|
|
Packit |
c22fc9 |
[AS_HELP_STRING([--disable-checksum-compat], [compile without v1.3.6 and earlier VRRPv3 unicast checksum compatibility])])
|
|
Packit |
c22fc9 |
AC_ARG_ENABLE(routes,
|
|
Packit |
c22fc9 |
[AS_HELP_STRING([--disable-routes], [compile without ip rules/routes])])
|
|
Packit |
c22fc9 |
AC_ARG_ENABLE(gnu-std-paths,
|
|
Packit |
c22fc9 |
[AS_HELP_STRING([--enable-gnu-std-paths], [use GNU standard paths for pid files etc])])
|
|
Packit |
c22fc9 |
AC_ARG_ENABLE(dynamic-linking,
|
|
Packit |
c22fc9 |
[AS_HELP_STRING([--enable-dynamic-linking], [compile with/without dynamically linked libiptc/libipset])])
|
|
Packit |
c22fc9 |
AC_ARG_ENABLE(libiptc-dynamic,
|
|
Packit |
c22fc9 |
[AS_HELP_STRING([--enable-libiptc-dynamic], [compile with libiptc dynamically linked])])
|
|
Packit |
c22fc9 |
AC_ARG_ENABLE(libipset-dynamic,
|
|
Packit |
c22fc9 |
[AS_HELP_STRING([--disable-libipset-dynamic], [compile with libipset statically linked])])
|
|
Packit |
c22fc9 |
AC_ARG_ENABLE(libxtables-dynamic,
|
|
Packit |
c22fc9 |
[AS_HELP_STRING([--enable-libxtables-dynamic], [compile with libxtables dynamically linked])])
|
|
Packit |
c22fc9 |
AC_ARG_ENABLE(libnl-dynamic,
|
|
Packit |
c22fc9 |
[AS_HELP_STRING([--enable-libnl-dynamic], [compile with libnl dynamically linked])])
|
|
Packit |
c22fc9 |
AC_ARG_ENABLE(libiptc,
|
|
Packit |
c22fc9 |
[AS_HELP_STRING([--disable-libiptc], [compile without libiptc])])
|
|
Packit |
c22fc9 |
AC_ARG_ENABLE(libipset,
|
|
Packit |
c22fc9 |
[AS_HELP_STRING([--disable-libipset], [compile without libipset])])
|
|
Packit |
c22fc9 |
AC_ARG_ENABLE(libnl,
|
|
Packit |
c22fc9 |
[AS_HELP_STRING([--disable-libnl], [compile without libnl])])
|
|
Packit |
c22fc9 |
AC_ARG_ENABLE(strict-config-checks,
|
|
Packit |
c22fc9 |
[AS_HELP_STRING([--enable-strict-config-checks], [build with strict configuration checking])])
|
|
Packit |
c22fc9 |
AC_ARG_ENABLE(hardening,
|
|
Packit |
c22fc9 |
[AS_HELP_STRING([--disable-hardening], [do not build with security hardening])])
|
|
Packit |
c22fc9 |
AC_ARG_ENABLE(optimise,
|
|
Packit |
c22fc9 |
[AS_HELP_STRING([--optimise], [compiler optimisation level])], [], [enable_optimise=not-specified])
|
|
Packit |
c22fc9 |
AC_ARG_ENABLE(mem-check,
|
|
Packit |
c22fc9 |
[AS_HELP_STRING([--enable-mem-check], [compile with memory alloc checking])])
|
|
Packit |
c22fc9 |
AC_ARG_ENABLE(mem-check-log,
|
|
Packit |
c22fc9 |
[AS_HELP_STRING([--enable-mem-check-log], [compile with memory alloc checking writing to syslog])])
|
|
Packit |
c22fc9 |
AC_ARG_ENABLE(timer-check,
|
|
Packit |
c22fc9 |
[AS_HELP_STRING([--enable-timer-check], [compile with set time logging])])
|
|
Packit |
c22fc9 |
AC_ARG_ENABLE(debug,
|
|
Packit |
c22fc9 |
[AS_HELP_STRING([--enable-debug], [compile with debugging flags])])
|
|
Packit |
c22fc9 |
AC_ARG_ENABLE(netlink-timers,
|
|
Packit |
c22fc9 |
[AS_HELP_STRING([--enable-netlink-timers], [compile with netlink command timers])])
|
|
Packit |
c22fc9 |
AC_ARG_ENABLE(smtp-alert-debug,
|
|
Packit |
c22fc9 |
[AS_HELP_STRING([--enable-smtp-alert-debug], [compile with smtp-alert debugging])])
|
|
Packit |
c22fc9 |
AC_ARG_ENABLE(stacktrace,
|
|
Packit |
c22fc9 |
[AS_HELP_STRING([--enable-stacktrace], [compile with stacktrace support])])
|
|
Packit |
c22fc9 |
AC_ARG_ENABLE(perf,
|
|
Packit |
c22fc9 |
[AS_HELP_STRING([--enable-perf], [compile with perf performance data recording support for vrrp process])])
|
|
Packit |
c22fc9 |
AC_ARG_ENABLE(log-file,
|
|
Packit |
c22fc9 |
[AS_HELP_STRING([--enable-log-file], [enable logging to file (-g)])])
|
|
Packit |
c22fc9 |
AC_ARG_ENABLE(dump-threads,
|
|
Packit |
c22fc9 |
[ --enable-dump-threads compile with thread dumping support])
|
|
Packit |
c22fc9 |
AC_ARG_ENABLE(epoll-debug,
|
|
Packit |
c22fc9 |
[ --enable-epoll-debug compile with epoll_wait() debugging support])
|
|
Packit |
c22fc9 |
AC_ARG_ENABLE(epoll-thread-dump,
|
|
Packit |
c22fc9 |
[ --enable-epoll-thread-dump compile with epoll thread dumping support])
|
|
Packit |
c22fc9 |
AC_ARG_ENABLE(regex-debug,
|
|
Packit |
c22fc9 |
[ --enable-regex-debug compile with regex debugging support])
|
|
Packit |
c22fc9 |
AC_ARG_ENABLE(tsm-debug,
|
|
Packit |
c22fc9 |
[ --enable-tsm-debug compile with TSM debugging support])
|
|
Packit |
c22fc9 |
AC_ARG_ENABLE(vrrp-fd-debug,
|
|
Packit |
c22fc9 |
[ --enable-vrrp-fd-debug compile with vrrp fd debugging support])
|
|
Packit |
c22fc9 |
AC_ARG_WITH(fixed-if-type,
|
|
Packit |
c22fc9 |
[ --with-fixed-if-type=TYPE treat interface type TYPE as unchangeable])
|
|
Packit |
c22fc9 |
AC_ARG_WITH(default-config-file,
|
|
Packit |
c22fc9 |
AS_HELP_STRING([--with-default-config-file=FILE], [Default configuration file]),
|
|
Packit |
c22fc9 |
[default_config_file="$withval"], [default_config_file=""])
|
|
Packit |
c22fc9 |
AC_ARG_ENABLE(profile,
|
|
Packit |
c22fc9 |
[AS_HELP_STRING([--enable-profile], [compile with profiling flags])])
|
|
Packit |
c22fc9 |
AC_ARG_ENABLE(conversion-checks,
|
|
Packit |
c22fc9 |
[AS_HELP_STRING([--enable-conversion-checks], [compile with conversion warnings if sensible])])
|
|
Packit |
c22fc9 |
AC_ARG_ENABLE(force-conversion-checks,
|
|
Packit |
c22fc9 |
[AS_HELP_STRING([--enable-force-conversion-checks], [compile with conversion warnings])])
|
|
Packit |
c22fc9 |
AC_ARG_ENABLE(Werror,
|
|
Packit |
c22fc9 |
[AS_HELP_STRING([--enable-Werror], [compile with warnings being errors])])
|
|
Packit |
c22fc9 |
|
|
Packit |
c22fc9 |
AC_ARG_WITH([systemdsystemunitdir],
|
|
Packit |
c22fc9 |
AS_HELP_STRING([--with-systemdsystemunitdir=DIR], [Directory for systemd service files]),
|
|
Packit |
c22fc9 |
[], [with_systemdsystemunitdir=$($PKG_CONFIG --variable=systemdsystemunitdir systemd)])
|
|
Packit |
c22fc9 |
|
|
Packit |
c22fc9 |
# Set the kernel headers path
|
|
Packit |
c22fc9 |
if test -n "$kernel_src_path"; then
|
|
Packit |
c22fc9 |
kernelinc="-I$kernel_src_path/include"
|
|
Packit |
c22fc9 |
elif test ! -d /usr/include/linux -a \
|
|
Packit |
c22fc9 |
-d /usr/src/linux/include; then
|
|
Packit |
c22fc9 |
kernelinc="-I/usr/src/linux/include"
|
|
Packit |
c22fc9 |
else
|
|
Packit |
c22fc9 |
kernelinc=
|
|
Packit |
c22fc9 |
fi
|
|
Packit |
c22fc9 |
|
|
Packit |
c22fc9 |
CPPFLAGS="$kernelinc $CPPFLAGS"
|
|
Packit |
c22fc9 |
|
|
Packit |
c22fc9 |
# Checks for programs.
|
|
Packit |
c22fc9 |
AC_PROG_CC
|
|
Packit |
c22fc9 |
AC_PROG_MAKE_SET
|
|
Packit |
c22fc9 |
AC_PROG_INSTALL
|
|
Packit |
c22fc9 |
AC_PROG_RANLIB
|
|
Packit |
c22fc9 |
AC_PROG_GREP
|
|
Packit |
c22fc9 |
AC_PROG_LN_S
|
|
Packit |
c22fc9 |
AC_PROG_SED
|
|
Packit |
c22fc9 |
AC_CHECK_TOOL(STRIP,strip)
|
|
Packit |
c22fc9 |
AC_CHECK_TOOL(LDD,ldd)
|
|
Packit |
c22fc9 |
|
|
Packit |
c22fc9 |
m4_ifdef([AM_PROG_AR], [AM_PROG_AR])
|
|
Packit |
c22fc9 |
ARFLAGS=cr
|
|
Packit |
c22fc9 |
AC_SUBST(ARFLAGS)
|
|
Packit |
c22fc9 |
|
|
Packit |
c22fc9 |
# Default settings
|
|
Packit |
c22fc9 |
ENABLE_LOG_FILE_APPEND=No
|
|
Packit |
c22fc9 |
|
|
Packit |
c22fc9 |
# AC_PROG_LIBTOOL
|
|
Packit |
c22fc9 |
|
|
Packit |
c22fc9 |
#
|
|
Packit |
c22fc9 |
# save the configure arguments
|
|
Packit |
c22fc9 |
#
|
|
Packit |
c22fc9 |
args=`echo $ac_configure_args | $SED -e "s/'//g"`
|
|
Packit |
c22fc9 |
AC_DEFINE_UNQUOTED(KEEPALIVED_CONFIGURE_OPTIONS,"$args", [configure options specified])
|
|
Packit |
c22fc9 |
|
|
Packit |
c22fc9 |
KA_CPPFLAGS="$kernelinc"
|
|
Packit |
c22fc9 |
KA_CFLAGS="-Wall -Wunused -Wstrict-prototypes -Wextra -Winit-self -g -D_GNU_SOURCE"
|
|
Packit |
c22fc9 |
KA_LDFLAGS=
|
|
Packit |
c22fc9 |
KA_LIBS=
|
|
Packit |
c22fc9 |
NEED_LIBDL=No
|
|
Packit |
c22fc9 |
#KA_LIBTOOLFLAGS =
|
|
Packit |
c22fc9 |
|
|
Packit |
c22fc9 |
# We want _GNU_SOURCE defined always
|
|
Packit |
c22fc9 |
add_to_var([CFLAGS], [-D_GNU_SOURCE])
|
|
Packit |
c22fc9 |
|
|
Packit |
c22fc9 |
# Some sanity checks on configure options
|
|
Packit |
c22fc9 |
AS_IF([test .$enable_vrrp = .no],
|
|
Packit |
c22fc9 |
[
|
|
Packit |
c22fc9 |
AS_IF([test .$enable_perf = .yes], [AC_MSG_ERROR([enable-perf requires vrrp])])
|
|
Packit |
c22fc9 |
AS_IF([test .$enable_libiptc_dynamic = .yes], [AC_MSG_ERROR([enable-libiptc-dynamic requires vrrp])])
|
|
Packit |
c22fc9 |
AS_IF([test .$enable_libxtables_dynamic = .yes], [AC_MSG_ERROR([enable-libxtables-dynamic requires vrrp])])
|
|
Packit |
c22fc9 |
AS_IF([test .$enable_libiptc = .no], [AC_MSG_ERROR([disable-libiptc requires vrrp])])
|
|
Packit |
c22fc9 |
AS_IF([test .$enable_libipset = .no], [AC_MSG_ERROR([disable-libipset requires vrrp])])
|
|
Packit |
c22fc9 |
AS_IF([test $with_fixed_if_type], [AC_MSG_ERROR([with-fixed-if-type requires vrrp])])
|
|
Packit |
c22fc9 |
AS_IF([test .$enable_vrrp_fd_debug = .yes], [AC_MSG_ERROR([enable-vrrp-fd-debug requires vrrp])])
|
|
Packit |
c22fc9 |
AS_IF([test .$enable_tsm_debug = .yes], [AC_MSG_ERROR([enable-tsm-debug requires vrrp])])
|
|
Packit |
c22fc9 |
AS_IF([test .$enable_json = .yes], [AC_MSG_ERROR([enable-json requires vrrp])])
|
|
Packit |
c22fc9 |
AS_IF([test .$enable_snmp_vrrp = .yes], [AC_MSG_ERROR([enable-snmp-vrrp requires vrrp])])
|
|
Packit |
c22fc9 |
AS_IF([test .$enable_snmp_keepalived = .yes], [AC_MSG_ERROR([enable-snmp-keepalived requires vrrp])])
|
|
Packit |
c22fc9 |
AS_IF([test .$enable_snmp_rfc = .yes], [AC_MSG_ERROR([enable-snmp-rfc requires vrrp])])
|
|
Packit |
c22fc9 |
AS_IF([test .$enable_snmp_rfcv2 = .yes], [AC_MSG_ERROR([enable-snmp-rfcv2 requires vrrp])])
|
|
Packit |
c22fc9 |
AS_IF([test .$enable_snmp_rfcv3 = .yes], [AC_MSG_ERROR([enable-snmp-rfcv3 requires vrrp])])
|
|
Packit |
c22fc9 |
AS_IF([test .$enable_dbus = .yes], [AC_MSG_ERROR([enable-dbus requires vrrp])])
|
|
Packit |
c22fc9 |
AS_IF([test .$enable_vrrp_auth = .no], [AC_MSG_ERROR([disable-vrrp-auth requires vrrp])])
|
|
Packit |
c22fc9 |
AS_IF([test .$enable_checksum_compat = .no], [AC_MSG_ERROR([disable-checksum-compat requires vrrp])])
|
|
Packit |
c22fc9 |
AS_IF([test .$enable_routes = .no], [AC_MSG_ERROR([disable-routes requires vrrp])])
|
|
Packit |
c22fc9 |
AS_IF([test .$enable_bfd = yes], [AC_MSG_ERROR([enable-bfd requires vrrp])])
|
|
Packit |
c22fc9 |
])
|
|
Packit |
c22fc9 |
AS_IF([test .$enable_snmp_rfc != .yes -a .$enable_snmp_rfcv3 != yes],
|
|
Packit |
c22fc9 |
[
|
|
Packit |
c22fc9 |
AS_IF([test .$enable_snmp_reply_v3_for_v2 = .yes], [AC_MSG_ERROR([enable-snmp-reply-v3-for-v2 requires enable-snmp-rfcv3 or enable-snmp-rfc])])
|
|
Packit |
c22fc9 |
])
|
|
Packit |
c22fc9 |
AS_IF([test .$enable_dbus != .yes],
|
|
Packit |
c22fc9 |
[
|
|
Packit |
c22fc9 |
AS_IF([test .$enable_dbus_create_instance = .yes], [AC_MSG_ERROR([enable-dbus-create-instance requires enable-dbus])])
|
|
Packit |
c22fc9 |
])
|
|
Packit |
c22fc9 |
AS_IF([test .$enable_lvs = .no],
|
|
Packit |
c22fc9 |
AS_IF([test .$enable_regex = .yes], [AC_MSG_ERROR([enable-regex requires lvs])])
|
|
Packit |
c22fc9 |
AS_IF([test .$enable_libnl_dynamic = .yes], [AC_MSG_ERROR([enable-libnl-dynamic requires lvs])])
|
|
Packit |
c22fc9 |
AS_IF([test .$enable_libnl = .no], [AC_MSG_ERROR([disable-libnl requires lvs])])
|
|
Packit |
c22fc9 |
AS_IF([test .$enable_lvs_syncd = .no], [AC_MSG_ERROR([disable-lvs-syncd requires lvs])])
|
|
Packit |
c22fc9 |
AS_IF([test .$enable_lvs_64bit_stats = .no], [AC_MSG_ERROR([disable-lvs-64bit-stats requires lvs])])
|
|
Packit |
c22fc9 |
AS_IF([test .$enable_fwmark = .yes], [AC_MSG_ERROR([enable-fwmark requires lvs])])
|
|
Packit |
c22fc9 |
])
|
|
Packit |
c22fc9 |
AS_IF([test .$enable_regex != .yes],
|
|
Packit |
c22fc9 |
AS_IF([test .$enable_regex_timers = .yes], [AC_MSG_ERROR([enable-regex-timers requires enable-regex])])
|
|
Packit |
c22fc9 |
AS_IF([test .$enable_regex_debug = .yes], [AC_MSG_ERROR([enable-regex-debug requires enable-regex])])
|
|
Packit |
c22fc9 |
])
|
|
Packit |
c22fc9 |
|
|
Packit |
c22fc9 |
if test "$enable_conversion_checks" = yes; then
|
|
Packit |
c22fc9 |
# Check if we can sensibly enable -Wconversion
|
|
Packit |
c22fc9 |
AC_MSG_CHECKING([for usable -Wconversion])
|
|
Packit |
c22fc9 |
SAV_CFLAGS="$CFLAGS"
|
|
Packit |
c22fc9 |
CFLAGS="-Wconversion -O2 -Wp,-D_FORTIFY_SOURCE=2 -Werror"
|
|
Packit |
c22fc9 |
AC_COMPILE_IFELSE([AC_LANG_SOURCE([[
|
|
Packit |
c22fc9 |
#include <sys/types.h>
|
|
Packit |
c22fc9 |
#include <sys/select.h>
|
|
Packit |
c22fc9 |
#include <stdint.h>
|
|
Packit |
c22fc9 |
#include <stdbool.h>
|
|
Packit |
c22fc9 |
#include <sys/socket.h>
|
|
Packit |
c22fc9 |
#include <linux/rtnetlink.h>
|
|
Packit |
c22fc9 |
|
|
Packit |
c22fc9 |
#define VAL 255
|
|
Packit |
c22fc9 |
|
|
Packit |
c22fc9 |
static void
|
|
Packit |
c22fc9 |
fun(uint8_t val)
|
|
Packit |
c22fc9 |
{
|
|
Packit |
c22fc9 |
}
|
|
Packit |
c22fc9 |
|
|
Packit |
c22fc9 |
int main(int argc, char**argv)
|
|
Packit |
c22fc9 |
{
|
|
Packit |
c22fc9 |
fd_set set;
|
|
Packit |
c22fc9 |
uint8_t val = 42;
|
|
Packit |
c22fc9 |
unsigned u;
|
|
Packit |
c22fc9 |
bool b;
|
|
Packit |
c22fc9 |
size_t size = 17;
|
|
Packit |
c22fc9 |
char c[2];
|
|
Packit |
c22fc9 |
char *c_ptr = c;
|
|
Packit |
c22fc9 |
struct rtattr rta;
|
|
Packit |
c22fc9 |
struct rtattr *rta_p = &rta;
|
|
Packit |
c22fc9 |
|
|
Packit |
c22fc9 |
FD_SET(argc+1, &set);
|
|
Packit |
c22fc9 |
|
|
Packit |
c22fc9 |
fun(argc == VAL ? VAL : val);
|
|
Packit |
c22fc9 |
|
|
Packit |
c22fc9 |
// vrrp->lower_prio_no_advert = vrrp->strict_mode ? true : global_data->vrrp_lower_prio_no_advert;
|
|
Packit |
c22fc9 |
u = u ? true : b;
|
|
Packit |
c22fc9 |
|
|
Packit |
c22fc9 |
size = RTA_LENGTH(size);
|
|
Packit |
c22fc9 |
c_ptr = RTA_DATA(c_ptr);
|
|
Packit |
c22fc9 |
rta_p = RTA_NEXT(rta_p, size);
|
|
Packit |
c22fc9 |
|
|
Packit |
c22fc9 |
val = (u < 256 ) ? u & 0xff : 0;
|
|
Packit |
c22fc9 |
}
|
|
Packit |
c22fc9 |
]])],
|
|
Packit |
c22fc9 |
[
|
|
Packit |
c22fc9 |
AC_MSG_RESULT([yes])
|
|
Packit |
c22fc9 |
add_to_var([KA_CFLAGS], [-Wconversion])
|
|
Packit |
c22fc9 |
],
|
|
Packit |
c22fc9 |
[
|
|
Packit |
c22fc9 |
AC_MSG_RESULT([no])
|
|
Packit |
c22fc9 |
AC_MSG_WARN([-Wconversion is not sensible with this compiler. Use --enable-force-conversion-checks to override.])
|
|
Packit |
c22fc9 |
])
|
|
Packit |
c22fc9 |
CFLAGS="$SAV_CFLAGS"
|
|
Packit |
c22fc9 |
elif test "$enable_force_conversion_checks" = yes; then
|
|
Packit |
c22fc9 |
add_to_var([KA_CFLAGS], [-Wconversion])
|
|
Packit |
c22fc9 |
fi
|
|
Packit |
c22fc9 |
|
|
Packit |
c22fc9 |
if test "$enable_Werror" = yes; then
|
|
Packit |
c22fc9 |
add_to_var([KA_CFLAGS], [-Werror])
|
|
Packit |
c22fc9 |
fi
|
|
Packit |
c22fc9 |
|
|
Packit |
c22fc9 |
AC_MSG_CHECKING([for -Wimplicit-fallthrough])
|
|
Packit |
c22fc9 |
SAV_CFLAGS="$CFLAGS"
|
|
Packit |
c22fc9 |
CFLAGS="-Wimplicit-fallthrough=3"
|
|
Packit |
c22fc9 |
AC_COMPILE_IFELSE([AC_LANG_SOURCE([[
|
|
Packit |
c22fc9 |
int main(int argc, char**argv)
|
|
Packit |
c22fc9 |
{
|
|
Packit |
c22fc9 |
}
|
|
Packit |
c22fc9 |
]])],
|
|
Packit |
c22fc9 |
[
|
|
Packit |
c22fc9 |
AC_MSG_RESULT([yes])
|
|
Packit |
c22fc9 |
add_to_var([KA_CFLAGS], [-Wimplicit-fallthrough=3])
|
|
Packit |
c22fc9 |
],
|
|
Packit |
c22fc9 |
[
|
|
Packit |
c22fc9 |
AC_MSG_RESULT([no])
|
|
Packit |
c22fc9 |
])
|
|
Packit |
c22fc9 |
CFLAGS="$SAV_CFLAGS"
|
|
Packit |
c22fc9 |
|
|
Packit |
c22fc9 |
dnl ---- [ Do we want stricter configuration checking? ] ----
|
|
Packit |
c22fc9 |
STRICT_CONFIG=No
|
|
Packit |
c22fc9 |
if test "$enable_strict_config_checks" = yes; then
|
|
Packit |
c22fc9 |
AC_DEFINE([_STRICT_CONFIG_], [ 1 ], [Define to 1 if want stricter configuration checking])
|
|
Packit |
c22fc9 |
STRICT_CONFIG=Yes
|
|
Packit |
c22fc9 |
add_config_opt([STRICT_CONFIG])
|
|
Packit |
c22fc9 |
fi
|
|
Packit |
c22fc9 |
|
|
Packit |
c22fc9 |
if test "$enable_hardening" != no; then
|
|
Packit |
c22fc9 |
AC_MSG_CHECKING([for PIE support])
|
|
Packit |
c22fc9 |
SAV_CFLAGS="$CFLAGS"
|
|
Packit |
c22fc9 |
SAV_LDFLAGS="$LDFLAGS"
|
|
Packit |
c22fc9 |
CFLAGS="$CFLAGS -fPIE"
|
|
Packit |
c22fc9 |
LDFLAGS="$LDFLAGS -pie"
|
|
Packit |
c22fc9 |
AC_LINK_IFELSE([AC_LANG_SOURCE([[
|
|
Packit |
c22fc9 |
int main(int argc, char **argv)
|
|
Packit |
c22fc9 |
{
|
|
Packit |
c22fc9 |
int i = 0;
|
|
Packit |
c22fc9 |
}
|
|
Packit |
c22fc9 |
]])],
|
|
Packit |
c22fc9 |
AC_MSG_RESULT([yes])
|
|
Packit |
c22fc9 |
add_to_var([KA_CFLAGS], [-fPIE])
|
|
Packit |
c22fc9 |
add_to_var([KA_LDFLAGS], [-pie]),
|
|
Packit |
c22fc9 |
AC_MSG_RESULT([no]))
|
|
Packit |
c22fc9 |
CFLAGS=$SAV_CFLAGS
|
|
Packit |
c22fc9 |
LDFLAGS=$SAV_LDFLAGS
|
|
Packit |
c22fc9 |
|
|
Packit |
c22fc9 |
for FLAG in \
|
|
Packit |
c22fc9 |
"-Wformat -Werror=format-security" \
|
|
Packit |
c22fc9 |
"-Wp,-D_FORTIFY_SOURCE=2" \
|
|
Packit |
c22fc9 |
"-fexceptions" \
|
|
Packit |
c22fc9 |
"-fstack-protector-strong" \
|
|
Packit |
c22fc9 |
"--param=ssp-buffer-size=4" \
|
|
Packit |
c22fc9 |
"-grecord-gcc-switches"
|
|
Packit |
c22fc9 |
do
|
|
Packit |
c22fc9 |
AC_MSG_CHECKING([for $FLAG support])
|
|
Packit |
c22fc9 |
CFLAGS="$CFLAGS $FLAG"
|
|
Packit |
c22fc9 |
AC_COMPILE_IFELSE(
|
|
Packit |
c22fc9 |
[AC_LANG_SOURCE([[ ]])],
|
|
Packit |
c22fc9 |
[AC_MSG_RESULT([yes])]
|
|
Packit |
c22fc9 |
add_to_var([KA_CFLAGS], [$FLAG]),
|
|
Packit |
c22fc9 |
[AC_MSG_RESULT([no])])
|
|
Packit |
c22fc9 |
CFLAGS=$SAV_CFLAGS
|
|
Packit |
c22fc9 |
done
|
|
Packit |
c22fc9 |
|
|
Packit |
c22fc9 |
WL_FLAGS=
|
|
Packit |
c22fc9 |
for FLAG in \
|
|
Packit |
c22fc9 |
"-z,relro" \
|
|
Packit |
c22fc9 |
"-z,now"
|
|
Packit |
c22fc9 |
do
|
|
Packit |
c22fc9 |
AC_MSG_CHECKING([for -Wl,$FLAG support])
|
|
Packit |
c22fc9 |
LDFLAGS="$LDFLAGS -Wl,$FLAG"
|
|
Packit |
c22fc9 |
AC_LINK_IFELSE(
|
|
Packit |
c22fc9 |
[AC_LANG_SOURCE([[
|
|
Packit |
c22fc9 |
int main(int argc, char **argv)
|
|
Packit |
c22fc9 |
{
|
|
Packit |
c22fc9 |
int i = 0;
|
|
Packit |
c22fc9 |
}
|
|
Packit |
c22fc9 |
]])],
|
|
Packit |
c22fc9 |
(
|
|
Packit |
c22fc9 |
AC_MSG_RESULT([yes])
|
|
Packit |
c22fc9 |
[WL_FLAGS="$WL_FLAGS,$FLAG"]
|
|
Packit |
c22fc9 |
),
|
|
Packit |
c22fc9 |
(
|
|
Packit |
c22fc9 |
[AC_MSG_RESULT([no])]
|
|
Packit |
c22fc9 |
)
|
|
Packit |
c22fc9 |
)
|
|
Packit |
c22fc9 |
CFLAGS=$SAV_CFLAGS
|
|
Packit |
c22fc9 |
done
|
|
Packit |
c22fc9 |
if test -n "$WL_FLAGS"; then
|
|
Packit |
c22fc9 |
add_to_var([KA_LDFLAGS], [-Wl$WL_FLAGS])
|
|
Packit |
c22fc9 |
fi
|
|
Packit |
c22fc9 |
fi
|
|
Packit |
c22fc9 |
|
|
Packit |
c22fc9 |
# enable-optimise
|
|
Packit |
c22fc9 |
AS_IF([test "$enable_optimise" = yes -o "$enable_optimise" = not-specified], [optimise_level=2], [optimise_level=$enable_optimise])
|
|
Packit |
c22fc9 |
AS_IF([test "$enable_optimise" = no], [optimise_level=0])
|
|
Packit |
c22fc9 |
AS_IF([test "$optimise_level" -eq 0],
|
|
Packit |
c22fc9 |
[
|
|
Packit |
c22fc9 |
echo $KA_CFLAGS | $GREP -q -- "-D_FORTIFY_SOURCE=[[^0]]"
|
|
Packit |
c22fc9 |
AS_IF([test $ret -eq 0], [AC_MSG_WARN([--disable-optimise requires --disable-hardening])])
|
|
Packit |
c22fc9 |
])
|
|
Packit |
c22fc9 |
FLAG="-O$optimise_level"
|
|
Packit |
c22fc9 |
AC_MSG_CHECKING([for $FLAG support])
|
|
Packit |
c22fc9 |
SAV_CFLAGS=$CFLAGS
|
|
Packit |
c22fc9 |
CFLAGS="$CFLAGS $FLAG"
|
|
Packit |
c22fc9 |
AC_COMPILE_IFELSE(
|
|
Packit |
c22fc9 |
[AC_LANG_SOURCE([[ ]])],
|
|
Packit |
c22fc9 |
[AC_MSG_RESULT([yes])]
|
|
Packit |
c22fc9 |
add_to_var([KA_CFLAGS], [$FLAG]),
|
|
Packit |
c22fc9 |
[
|
|
Packit |
c22fc9 |
AC_MSG_RESULT([no])
|
|
Packit |
c22fc9 |
AS_IF([test "$enable_optimise" != not-specified], [AC_MSG_ERROR([Invalid optimisation level specified])])
|
|
Packit |
c22fc9 |
])
|
|
Packit |
c22fc9 |
CFLAGS=$SAV_CFLAGS
|
|
Packit |
c22fc9 |
|
|
Packit |
c22fc9 |
AC_SUBST(KA_CPPFLAGS)
|
|
Packit |
c22fc9 |
AC_SUBST(KA_CFLAGS)
|
|
Packit |
c22fc9 |
AC_SUBST(KA_LDFLAGS)
|
|
Packit |
c22fc9 |
AC_SUBST(KA_LIBS)
|
|
Packit |
c22fc9 |
# AC_SUBST(KA_LIBTOOLFLAGS)
|
|
Packit |
c22fc9 |
|
|
Packit |
c22fc9 |
# Checks for libraries.
|
|
Packit |
c22fc9 |
dnl clock_gettime() required -lt before glibc 2.17
|
|
Packit |
c22fc9 |
AC_MSG_CHECKING([for clock_gettime() requires -lrt])
|
|
Packit |
c22fc9 |
AC_LINK_IFELSE([AC_LANG_SOURCE([[
|
|
Packit |
c22fc9 |
#include <time.h>
|
|
Packit |
c22fc9 |
int main(int argc, char **argv)
|
|
Packit |
c22fc9 |
{
|
|
Packit |
c22fc9 |
int i;
|
|
Packit |
c22fc9 |
struct timespec ts;
|
|
Packit |
c22fc9 |
|
|
Packit |
c22fc9 |
i = clock_gettime(CLOCK_MONOTONIC, &ts);
|
|
Packit |
c22fc9 |
}
|
|
Packit |
c22fc9 |
]])],
|
|
Packit |
c22fc9 |
[AC_MSG_RESULT([no])],
|
|
Packit |
c22fc9 |
[
|
|
Packit |
c22fc9 |
SAV_LDFLAGS="$LDFLAGS"
|
|
Packit |
c22fc9 |
LDFLAGS="$LDFLAGS -lrt"
|
|
Packit |
c22fc9 |
AC_LINK_IFELSE([AC_LANG_SOURCE([[
|
|
Packit |
c22fc9 |
#include <time.h>
|
|
Packit |
c22fc9 |
int main(int argc, char **argv)
|
|
Packit |
c22fc9 |
{
|
|
Packit |
c22fc9 |
int i;
|
|
Packit |
c22fc9 |
struct timespec ts;
|
|
Packit |
c22fc9 |
|
|
Packit |
c22fc9 |
i = clock_gettime(CLOCK_MONOTONIC, &ts);
|
|
Packit |
c22fc9 |
}
|
|
Packit |
c22fc9 |
]])],
|
|
Packit |
c22fc9 |
[AC_MSG_RESULT([yes])]
|
|
Packit |
c22fc9 |
add_to_var([KA_LIBS], [-lrt]),
|
|
Packit |
c22fc9 |
[AC_MSG_ERROR([clock_gettime() not supported])])
|
|
Packit |
c22fc9 |
LDFLAGS=$SAV_LDFLAGS
|
|
Packit |
c22fc9 |
])
|
|
Packit |
c22fc9 |
|
|
Packit |
c22fc9 |
# Checks for header files.
|
|
Packit |
c22fc9 |
AC_CHECK_HEADERS([arpa/inet.h fcntl.h limits.h netdb.h netinet/in.h stdint.h stdlib.h string.h sys/ioctl.h sys/param.h sys/prctl.h sys/socket.h sys/time.h syslog.h unistd.h],
|
|
Packit |
c22fc9 |
[], [AC_MSG_ERROR([Missing/unusable system header file <$ac_header>])])
|
|
Packit |
c22fc9 |
|
|
Packit |
c22fc9 |
# check for kernel headers
|
|
Packit |
c22fc9 |
SAV_CPPFLAGS="$CPPFLAGS"
|
|
Packit |
c22fc9 |
CPPFLAGS="$CPPFLAGS $kernelinc"
|
|
Packit |
c22fc9 |
dnl -- <linux/netlink.h> needed <sys/socket.h> until Linux 3.1
|
|
Packit |
c22fc9 |
dnl -- using AC_CHECK_HEADER causes a horrible error message for the user
|
|
Packit |
c22fc9 |
NETLINK_EXTRA_INCLUDE=
|
|
Packit |
c22fc9 |
AC_COMPILE_IFELSE([AC_LANG_SOURCE([[
|
|
Packit |
c22fc9 |
#include <linux/netlink.h>
|
|
Packit |
c22fc9 |
]])], [],
|
|
Packit |
c22fc9 |
[AC_CHECK_HEADER([linux/netlink.h],
|
|
Packit |
c22fc9 |
[
|
|
Packit |
c22fc9 |
AC_DEFINE([NETLINK_H_NEEDS_SYS_SOCKET_H], [ 1 ], [Define to 1 if <linux/netlink.h> needs <sys/socket.h>])
|
|
Packit |
c22fc9 |
NETLINK_EXTRA_INCLUDE="#include <sys/socket.h>"
|
|
Packit |
c22fc9 |
], [AC_MSG_ERROR([Missing/unusable kernel header file <linux/netlink.h>])],
|
|
Packit |
c22fc9 |
[[#include <sys/socket.h>]])])
|
|
Packit |
c22fc9 |
|
|
Packit |
c22fc9 |
dnl -- <linux/rtnetlink.h> needed <sys/socket.h> until ? Linux 3.1
|
|
Packit |
c22fc9 |
dnl -- using AC_CHECK_HEADER causes a horrible error message for the user
|
|
Packit |
c22fc9 |
RTNETLINK_EXTRA_INCLUDE=
|
|
Packit |
c22fc9 |
AC_COMPILE_IFELSE([AC_LANG_SOURCE([[
|
|
Packit |
c22fc9 |
#include <linux/rtnetlink.h>
|
|
Packit |
c22fc9 |
]])], [],
|
|
Packit |
c22fc9 |
[AC_CHECK_HEADER([linux/rtnetlink.h],
|
|
Packit |
c22fc9 |
[
|
|
Packit |
c22fc9 |
AC_DEFINE([RTNETLINK_H_NEEDS_SYS_SOCKET_H], [ 1 ], [Define to 1 if <linux/rtnetlink.h> needs <sys/socket.h>])
|
|
Packit |
c22fc9 |
RTNETLINK_EXTRA_INCLUDE="#include <sys/socket.h>"
|
|
Packit |
c22fc9 |
], [AC_MSG_ERROR([Missing/unusable kernel header file <linux/rtnetlink.h>])],
|
|
Packit |
c22fc9 |
[[#include <sys/socket.h>]])])
|
|
Packit |
c22fc9 |
|
|
Packit |
c22fc9 |
AC_CHECK_HEADERS([asm/types.h linux/ethtool.h linux/icmpv6.h linux/if_ether.h linux/if_packet.h linux/ip.h linux/sockios.h linux/types.h],
|
|
Packit |
c22fc9 |
[], [AC_MSG_ERROR([Missing/unusable kernel header file <$ac_header>])])
|
|
Packit |
c22fc9 |
AC_CHECK_HEADERS([linux/fib_rules.h linux/if_addr.h linux/if_link.h],
|
|
Packit |
c22fc9 |
[], [AC_MSG_ERROR([Missing/unusable kernel header file <$ac_header>])],
|
|
Packit |
c22fc9 |
[[$NETLINK_EXTRA_INCLUDE]])
|
|
Packit |
c22fc9 |
AC_CHECK_HEADERS([linux/if_arp.h],
|
|
Packit |
c22fc9 |
[], [AC_MSG_ERROR([Missing/unusable <$ac_header>])],
|
|
Packit |
c22fc9 |
[[#include <sys/socket.h>]])
|
|
Packit |
c22fc9 |
CPPFLAGS="$SAV_CPPFLAGS"
|
|
Packit |
c22fc9 |
|
|
Packit |
c22fc9 |
# Checks for typedefs, structures, and compiler characteristics.
|
|
Packit |
c22fc9 |
AC_HEADER_STDBOOL
|
|
Packit |
c22fc9 |
AC_C_INLINE
|
|
Packit |
c22fc9 |
AC_TYPE_INT64_T
|
|
Packit |
c22fc9 |
AC_TYPE_PID_T
|
|
Packit |
c22fc9 |
AC_TYPE_SIZE_T
|
|
Packit |
c22fc9 |
AC_TYPE_UINT16_T
|
|
Packit |
c22fc9 |
AC_TYPE_UINT32_T
|
|
Packit |
c22fc9 |
AC_TYPE_UINT64_T
|
|
Packit |
c22fc9 |
AC_TYPE_UINT8_T
|
|
Packit |
c22fc9 |
AC_C_CONST
|
|
Packit |
c22fc9 |
|
|
Packit |
c22fc9 |
# Checks for library functions.
|
|
Packit |
c22fc9 |
AC_FUNC_FORK
|
|
Packit |
c22fc9 |
AC_FUNC_MALLOC
|
|
Packit |
c22fc9 |
AC_FUNC_REALLOC
|
|
Packit |
c22fc9 |
AC_CHECK_FUNCS([dup2 getcwd gettimeofday memmove memset select setenv socket strcasecmp strchr strdup strerror strpbrk strstr strtol strtoul uname])
|
|
Packit |
c22fc9 |
dnl - pipe2() since Linux 2.6.27 and glibc 2.9.
|
|
Packit |
c22fc9 |
AC_CHECK_FUNCS([pipe2], [add_system_opt([PIPE2])])
|
|
Packit |
c22fc9 |
dnl - signalfd() since Linux 2.6.22 and glibc 2.8
|
|
Packit |
c22fc9 |
AC_CHECK_FUNCS([signalfd], [add_system_opt([SIGNALFD])])
|
|
Packit |
c22fc9 |
dnl - inotify_init1() since Linux 2.6.27
|
|
Packit |
c22fc9 |
AC_CHECK_FUNCS([inotify_init1], [add_system_opt([INOTIFY_INIT1])])
|
|
Packit |
c22fc9 |
dnl - vsyslog() Not defined by Posix, but available in glibc and musl
|
|
Packit |
c22fc9 |
AC_CHECK_FUNCS([vsyslog], [add_system_opt([VSYSLOG])])
|
|
Packit |
c22fc9 |
dnl - epoll_create1() since Linux 2.6.27 and glibc 2.9
|
|
Packit |
c22fc9 |
AC_CHECK_FUNCS([epoll_create1], [add_system_opt([EPOLL_CREATE1])])
|
|
Packit |
c22fc9 |
|
|
Packit |
c22fc9 |
# glibc uses unsigned int as 3rd parameter to __assert_fail(), musl uses int.
|
|
Packit |
c22fc9 |
AC_COMPILE_IFELSE([AC_LANG_SOURCE([[
|
|
Packit |
c22fc9 |
#include <assert.h>
|
|
Packit |
c22fc9 |
#include <stdlib.h>
|
|
Packit |
c22fc9 |
|
|
Packit |
c22fc9 |
void __assert_fail(const char * a, const char *b, unsigned int l, const char *c)
|
|
Packit |
c22fc9 |
{
|
|
Packit |
c22fc9 |
exit(a[0] + b[0] + c[0] + l == 0);
|
|
Packit |
c22fc9 |
}
|
|
Packit |
c22fc9 |
]])],
|
|
Packit |
c22fc9 |
[LINE_type="unsigned int"], [LINE_type="int"])
|
|
Packit |
c22fc9 |
AC_DEFINE_UNQUOTED([LINE_type], [ $LINE_type ], [The type of parameter __line passed to __assert_fail()])
|
|
Packit |
c22fc9 |
|
|
Packit |
c22fc9 |
dnl Check if libc supports __always_inline
|
|
Packit |
c22fc9 |
dnl See glibc sys/cdefs.h definition of __always_inline and comment
|
|
Packit |
c22fc9 |
SAV_CFLAGS="$CFLAGS"
|
|
Packit |
c22fc9 |
CFLAGS="$CFLAGS -Wattributes -Werror"
|
|
Packit |
c22fc9 |
AC_COMPILE_IFELSE([AC_LANG_SOURCE([[
|
|
Packit |
c22fc9 |
#include <stdlib.h>
|
|
Packit |
c22fc9 |
static __always_inline int
|
|
Packit |
c22fc9 |
test_func(int val)
|
|
Packit |
c22fc9 |
{
|
|
Packit |
c22fc9 |
return val;
|
|
Packit |
c22fc9 |
}
|
|
Packit |
c22fc9 |
|
|
Packit |
c22fc9 |
int
|
|
Packit |
c22fc9 |
main(int argc, char **argv)
|
|
Packit |
c22fc9 |
{
|
|
Packit |
c22fc9 |
int val = test_func(3);
|
|
Packit |
c22fc9 |
}
|
|
Packit |
c22fc9 |
]])],
|
|
Packit |
c22fc9 |
[],
|
|
Packit |
c22fc9 |
[AC_COMPILE_IFELSE([AC_LANG_SOURCE([[
|
|
Packit |
c22fc9 |
static __inline __attribute__ ((__always_inline__)) int
|
|
Packit |
c22fc9 |
test_func(int val)
|
|
Packit |
c22fc9 |
{
|
|
Packit |
c22fc9 |
return val;
|
|
Packit |
c22fc9 |
}
|
|
Packit |
c22fc9 |
|
|
Packit |
c22fc9 |
int
|
|
Packit |
c22fc9 |
main(int argc, char **argv)
|
|
Packit |
c22fc9 |
{
|
|
Packit |
c22fc9 |
int val = test_func(3);
|
|
Packit |
c22fc9 |
}
|
|
Packit |
c22fc9 |
]])],
|
|
Packit |
c22fc9 |
[AC_DEFINE([__always_inline], [__inline __attribute__ ((__always_inline__))], [Define __always_inline if libc does not define it])],
|
|
Packit |
c22fc9 |
[AC_DEFINE([__always_inline], [inline], [Define __always_inline if libc does not define it])]
|
|
Packit |
c22fc9 |
)])
|
|
Packit |
c22fc9 |
CFLAGS="$SAV_CFLAGS"
|
|
Packit |
c22fc9 |
|
|
Packit |
c22fc9 |
dnl - Check type of rlim_t for printf()
|
|
Packit |
c22fc9 |
SAV_CFLAGS="$CFLAGS"
|
|
Packit |
c22fc9 |
CFLAGS="$CFLAGS -Wformat -Werror"
|
|
Packit |
c22fc9 |
AC_COMPILE_IFELSE([AC_LANG_SOURCE([[
|
|
Packit |
c22fc9 |
#include <stdio.h>
|
|
Packit |
c22fc9 |
#include <sys/resource.h>
|
|
Packit |
c22fc9 |
int
|
|
Packit |
c22fc9 |
main(int argc, char **argv)
|
|
Packit |
c22fc9 |
{
|
|
Packit |
c22fc9 |
rlim_t val = 23U;
|
|
Packit |
c22fc9 |
printf("%llu", val);
|
|
Packit |
c22fc9 |
}
|
|
Packit |
c22fc9 |
]])],
|
|
Packit |
c22fc9 |
[AC_DEFINE([PRI_rlim_t], ["llu"], [Define printf format specifier for rlim_t])],
|
|
Packit |
c22fc9 |
[AC_DEFINE([PRI_rlim_t], ["lu"], [Define printf format specifier for rlim_t])],
|
|
Packit |
c22fc9 |
)
|
|
Packit |
c22fc9 |
CFLAGS="$SAV_CFLAGS"
|
|
Packit |
c22fc9 |
|
|
Packit |
c22fc9 |
dnl - Do we want to override dynamic/static linking?
|
|
Packit |
c22fc9 |
AS_IF([test "$enable_dynamic_linking"],
|
|
Packit |
c22fc9 |
[
|
|
Packit |
c22fc9 |
AS_IF([test .$enable_vrrp != .no],
|
|
Packit |
c22fc9 |
[
|
|
Packit |
c22fc9 |
enable_libiptc_dynamic=$enable_dynamic_linking
|
|
Packit |
c22fc9 |
enable_libipset_dynamic=$enable_dynamic_linking
|
|
Packit |
c22fc9 |
enable_libxtables_dynamic=$enable_dynamic_linking
|
|
Packit |
c22fc9 |
])
|
|
Packit |
c22fc9 |
AS_IF([test .$enable_vrrp != .no],
|
|
Packit |
c22fc9 |
[
|
|
Packit |
c22fc9 |
enable_libnl_dynamic=$enable_dynamic_linking
|
|
Packit |
c22fc9 |
])
|
|
Packit |
c22fc9 |
])
|
|
Packit |
c22fc9 |
|
|
Packit |
c22fc9 |
# check for missing definition - added in glibc 2.8
|
|
Packit |
c22fc9 |
AC_CHECK_DECLS([ETHERTYPE_IPV6], [],
|
|
Packit |
c22fc9 |
[
|
|
Packit |
c22fc9 |
AC_DEFINE([ETHERTYPE_IPV6], [0x86dd], [Defined here if not found in <net/ethernet.h>.])
|
|
Packit |
c22fc9 |
],
|
|
Packit |
c22fc9 |
[[#include <net/ethernet.h>]])
|
|
Packit |
c22fc9 |
|
|
Packit |
c22fc9 |
BUILD_GENHASH=Yes
|
|
Packit |
c22fc9 |
dnl ----[ Checks for openssl ]----
|
|
Packit |
c22fc9 |
# check for openssl headers
|
|
Packit |
c22fc9 |
NEED_MD5=no
|
|
Packit |
c22fc9 |
NEED_SSL=no
|
|
Packit |
c22fc9 |
if test "$enable_vrrp" != no -a \
|
|
Packit |
c22fc9 |
"$enable_vrrp_auth" != no; then
|
|
Packit |
c22fc9 |
NEED_MD5=yes
|
|
Packit |
c22fc9 |
fi
|
|
Packit |
c22fc9 |
if test "$enable_lvs" != no; then
|
|
Packit |
c22fc9 |
NEED_MD5=yes
|
|
Packit |
c22fc9 |
NEED_SSL=yes
|
|
Packit |
c22fc9 |
fi
|
|
Packit |
c22fc9 |
AC_CHECK_HEADERS([openssl/ssl.h openssl/err.h], [],
|
|
Packit |
c22fc9 |
[
|
|
Packit |
c22fc9 |
if test $NEED_SSL = yes; then
|
|
Packit |
c22fc9 |
AC_MSG_ERROR([
|
|
Packit |
c22fc9 |
!!! OpenSSL is not properly installed on your system. !!!
|
|
Packit |
c22fc9 |
!!! Can not include OpenSSL headers files. !!!])
|
|
Packit |
c22fc9 |
fi
|
|
Packit |
c22fc9 |
BUILD_GENHASH=No
|
|
Packit |
c22fc9 |
NEED_SSL=no
|
|
Packit |
c22fc9 |
break
|
|
Packit |
c22fc9 |
])
|
|
Packit |
c22fc9 |
AC_CHECK_HEADERS([openssl/md5.h], [],
|
|
Packit |
c22fc9 |
[
|
|
Packit |
c22fc9 |
if test $NEED_MD5 = yes; then
|
|
Packit |
c22fc9 |
AC_MSG_ERROR([
|
|
Packit |
c22fc9 |
!!! OpenSSL is not properly installed on your system. !!!
|
|
Packit |
c22fc9 |
!!! Can not include OpenSSL MD5 headers files. !!!])
|
|
Packit |
c22fc9 |
fi
|
|
Packit |
c22fc9 |
BUILD_GENHASH=No
|
|
Packit |
c22fc9 |
NEED_MD5=no
|
|
Packit |
c22fc9 |
break
|
|
Packit |
c22fc9 |
])
|
|
Packit |
c22fc9 |
unset LIBS
|
|
Packit |
c22fc9 |
|
|
Packit |
c22fc9 |
$PKG_CONFIG --exists openssl
|
|
Packit |
c22fc9 |
if test $? -eq 0; then
|
|
Packit |
c22fc9 |
add_pkg_config([openssl], [OPENSSL])
|
|
Packit |
c22fc9 |
else
|
|
Packit |
c22fc9 |
OPENSSL_LIBS="-lssl -lcrypto"
|
|
Packit |
c22fc9 |
fi
|
|
Packit |
c22fc9 |
|
|
Packit |
c22fc9 |
EXTRA_LIBS=`echo $OPENSSL_LIBS | sed -e "s/-lcrypto//"`
|
|
Packit |
c22fc9 |
AC_CHECK_LIB(crypto, MD5_Init, [],
|
|
Packit |
c22fc9 |
[
|
|
Packit |
c22fc9 |
if test $NEED_MD5 = yes; then
|
|
Packit |
c22fc9 |
AC_MSG_ERROR([OpenSSL MD5 libraries are required])
|
|
Packit |
c22fc9 |
fi
|
|
Packit |
c22fc9 |
BUILD_GENHASH=No
|
|
Packit |
c22fc9 |
], [$EXTRA_LIBS])
|
|
Packit |
c22fc9 |
if test $NEED_MD5 = yes; then
|
|
Packit |
c22fc9 |
add_to_var([KA_LIBS], [$LIBS])
|
|
Packit |
c22fc9 |
fi
|
|
Packit |
c22fc9 |
add_to_var([GENHASH_LIBS], [$LIBS])
|
|
Packit |
c22fc9 |
unset LIBS
|
|
Packit |
c22fc9 |
|
|
Packit |
c22fc9 |
EXTRA_LIBS=`echo $OPENSSL_LIBS | sed -e "s/-lssl//"`
|
|
Packit |
c22fc9 |
AC_CHECK_LIB(ssl, SSL_CTX_new, [],
|
|
Packit |
c22fc9 |
[
|
|
Packit |
c22fc9 |
if test $NEED_SSL = yes; then
|
|
Packit |
c22fc9 |
AC_MSG_ERROR([OpenSSL libraries are required])
|
|
Packit |
c22fc9 |
fi
|
|
Packit |
c22fc9 |
BUILD_GENHASH=No
|
|
Packit |
c22fc9 |
], [$EXTRA_LIBS])
|
|
Packit |
c22fc9 |
if test $NEED_SSL = yes; then
|
|
Packit |
c22fc9 |
add_to_var([KA_LIBS], [$LIBS])
|
|
Packit |
c22fc9 |
fi
|
|
Packit |
c22fc9 |
add_to_var([GENHASH_LIBS], [$LIBS])
|
|
Packit |
c22fc9 |
|
|
Packit |
c22fc9 |
# Introduced in OpenSSL ver 0.9.9
|
|
Packit |
c22fc9 |
LIBS=$OPENSSL_LIBS
|
|
Packit |
c22fc9 |
AC_MSG_CHECKING([SSL_set_tlsext_host_name() - may be a definition])
|
|
Packit |
c22fc9 |
AC_COMPILE_IFELSE([AC_LANG_SOURCE([[
|
|
Packit |
c22fc9 |
#include <openssl/ssl.h>
|
|
Packit |
c22fc9 |
int main(void)
|
|
Packit |
c22fc9 |
{
|
|
Packit |
c22fc9 |
request_t req;
|
|
Packit |
c22fc9 |
SSL_set_tlsext_host_name(req.ssl, "SSL");
|
|
Packit |
c22fc9 |
}
|
|
Packit |
c22fc9 |
]])], [
|
|
Packit |
c22fc9 |
AC_MSG_RESULT([no])
|
|
Packit |
c22fc9 |
], [
|
|
Packit |
c22fc9 |
AC_MSG_RESULT([yes])
|
|
Packit |
c22fc9 |
AC_DEFINE([_HAVE_SSL_SET_TLSEXT_HOST_NAME_], [ 1 ], [Define to 1 if have SSL_set_tlsext_host_name()])
|
|
Packit |
c22fc9 |
])
|
|
Packit |
c22fc9 |
|
|
Packit |
c22fc9 |
# SSL_CTX_set_verify_depth() introduced OpenSSL v0.9.5a
|
|
Packit |
c22fc9 |
AC_CHECK_FUNCS([SSL_CTX_set_verify_depth])
|
|
Packit |
c22fc9 |
|
|
Packit Service |
8fc997 |
# SSL_set0_rbio(), SSL_set0_wbio() and OPENSSL_init_crypto() introduced OpenSSL v1.1.0
|
|
Packit Service |
8fc997 |
AC_CHECK_FUNCS([SSL_set0_rbio OPENSSL_init_crypto])
|
|
Packit Service |
8fc997 |
|
|
Packit Service |
8fc997 |
# TLS_method() introduced OpenSSL v1.1.0
|
|
Packit Service |
8fc997 |
AC_CHECK_FUNCS([TLS_method])
|
|
Packit |
c22fc9 |
|
|
Packit |
c22fc9 |
unset LIBS
|
|
Packit |
c22fc9 |
|
|
Packit |
c22fc9 |
if test $BUILD_GENHASH = No; then
|
|
Packit |
c22fc9 |
AC_MSG_NOTICE([Unable to build genhash due to missing openssl headers/libraries])
|
|
Packit |
c22fc9 |
GENHASH_LIBS=
|
|
Packit |
c22fc9 |
fi
|
|
Packit |
c22fc9 |
AC_SUBST([GENHASH_LIBS])
|
|
Packit |
c22fc9 |
AM_CONDITIONAL([BUILD_GENHASH], [test $BUILD_GENHASH = Yes])
|
|
Packit |
c22fc9 |
|
|
Packit |
c22fc9 |
dnl ----[ Check for IPv4 devconf netlink support ]----
|
|
Packit |
c22fc9 |
IPV4_DEVCONF=No
|
|
Packit |
c22fc9 |
if test .$enable_vrrp != .no; then
|
|
Packit |
c22fc9 |
dnl ----[Check have IPV4_DEVCONF defines - since Linux 3.11]----
|
|
Packit |
c22fc9 |
SAV_CPPFLAGS="$CPPFLAGS"
|
|
Packit |
c22fc9 |
CPPFLAGS="$CPP_FLAGS $kernelinc"
|
|
Packit |
c22fc9 |
IPV4_DEVCONF=Yes
|
|
Packit |
c22fc9 |
AC_CHECK_DECLS([
|
|
Packit |
c22fc9 |
IPV4_DEVCONF_ARP_IGNORE,
|
|
Packit |
c22fc9 |
IPV4_DEVCONF_ACCEPT_LOCAL,
|
|
Packit |
c22fc9 |
IPV4_DEVCONF_RP_FILTER,
|
|
Packit |
c22fc9 |
IPV4_DEVCONF_ARPFILTER],
|
|
Packit |
c22fc9 |
[],
|
|
Packit |
c22fc9 |
[
|
|
Packit |
c22fc9 |
IPV4_DEVCONF=No
|
|
Packit |
c22fc9 |
break
|
|
Packit |
c22fc9 |
],
|
|
Packit |
c22fc9 |
[[#include <linux/ip.h>]])
|
|
Packit |
c22fc9 |
if test $IPV4_DEVCONF = Yes; then
|
|
Packit |
c22fc9 |
AC_DEFINE([_HAVE_IPV4_DEVCONF_], [ 1 ], [Define to 1 if have IPv4 netlink device configuration])
|
|
Packit |
c22fc9 |
add_system_opt([IPV4_DEVCONF])
|
|
Packit |
c22fc9 |
fi
|
|
Packit |
c22fc9 |
AC_CHECK_HEADERS([linux/rtnetlink.h], [], [AC_MSG_ERROR([Unusable linux/rtnetlink.h])], [$RTNETLINK_EXTRA_INCLUDE])
|
|
Packit |
c22fc9 |
CPPFLAGS="$SAV_CPPFLAGS"
|
|
Packit |
c22fc9 |
fi
|
|
Packit |
c22fc9 |
|
|
Packit |
c22fc9 |
dnl ----[ Checks for libraries ]----
|
|
Packit |
c22fc9 |
NETLINK_VER=0
|
|
Packit |
c22fc9 |
IPVS_USE_NL=No
|
|
Packit |
c22fc9 |
if test .$enable_lvs != .no -a .${enable_libnl} != .no; then
|
|
Packit |
c22fc9 |
$PKG_CONFIG --exists libnl-3.0
|
|
Packit |
c22fc9 |
if test $? -eq 0; then
|
|
Packit |
c22fc9 |
add_pkg_config([libnl-3.0], [NL3], [remove-requires])
|
|
Packit |
c22fc9 |
AC_CHECK_LIB($NL3_LIB_NAMES, nl_socket_alloc,
|
|
Packit |
c22fc9 |
[
|
|
Packit |
c22fc9 |
NETLINK_VER=3
|
|
Packit |
c22fc9 |
NEED_NL3=No
|
|
Packit |
c22fc9 |
|
|
Packit |
c22fc9 |
add_pkg_config([libnl-genl-3.0], [GENL], [remove-requires])
|
|
Packit |
c22fc9 |
AC_CHECK_LIB($GENL_LIB_NAMES, genl_connect, [],
|
|
Packit |
c22fc9 |
[AC_MSG_ERROR([libnl-3 is installed but not libnl-gen-3. Please, install libnl-gen-3/libnl-genl-3.])])
|
|
Packit |
c22fc9 |
IPVS_USE_NL=Yes
|
|
Packit |
c22fc9 |
if test .$enable_libnl_dynamic = .yes; then
|
|
Packit |
c22fc9 |
add_pkg_config_without_libs([libnl-genl-3.0])
|
|
Packit |
c22fc9 |
get_lib_name([$GENL_LIB_NAMES], [genl_connect])
|
|
Packit |
c22fc9 |
AC_DEFINE_UNQUOTED([NL3_GENL_LIB_NAME], [ "$LIB_NAME" ], [Define the nl-genl-3.0 library name])
|
|
Packit |
c22fc9 |
else
|
|
Packit |
c22fc9 |
add_pkg_config([libnl-genl-3.0])
|
|
Packit |
c22fc9 |
fi
|
|
Packit |
c22fc9 |
NEED_NL3=Yes
|
|
Packit |
c22fc9 |
|
|
Packit |
c22fc9 |
if test $NEED_NL3 = Yes; then
|
|
Packit |
c22fc9 |
AC_DEFINE([_HAVE_LIBNL3_], [ 1 ], [Define to 1 if using libnl-3])
|
|
Packit |
c22fc9 |
add_system_opt([LIBNL3])
|
|
Packit |
c22fc9 |
if test .$enable_libnl_dynamic = .yes; then
|
|
Packit |
c22fc9 |
add_system_opt([LIBNL_DYNAMIC])
|
|
Packit |
c22fc9 |
add_pkg_config_without_libs([libnl-3.0])
|
|
Packit |
c22fc9 |
AC_DEFINE([_LIBNL_DYNAMIC_], [ 1 ], [Define to 1 if building with libnl dynamic linking])
|
|
Packit |
c22fc9 |
NEED_LIBDL=Yes
|
|
Packit |
c22fc9 |
get_lib_name([$NL3_LIB_NAMES], [nl_socket_alloc])
|
|
Packit |
c22fc9 |
AC_DEFINE_UNQUOTED([NL3_LIB_NAME], [ "$LIB_NAME" ], [Define the nl-3 library name])
|
|
Packit |
c22fc9 |
else
|
|
Packit |
c22fc9 |
add_pkg_config([libnl-3.0])
|
|
Packit |
c22fc9 |
fi
|
|
Packit |
c22fc9 |
fi
|
|
Packit |
c22fc9 |
], [])
|
|
Packit |
c22fc9 |
fi
|
|
Packit |
c22fc9 |
|
|
Packit |
c22fc9 |
if test $NETLINK_VER -eq 0; then
|
|
Packit |
c22fc9 |
AC_CHECK_LIB(nl, nl_socket_modify_cb,
|
|
Packit |
c22fc9 |
[
|
|
Packit |
c22fc9 |
IPVS_USE_NL=Yes
|
|
Packit |
c22fc9 |
NETLINK_VER=1
|
|
Packit |
c22fc9 |
AC_DEFINE([_HAVE_LIBNL1_], [ 1 ], [Define to 1 if using libnl-1])
|
|
Packit |
c22fc9 |
add_system_opt([LIBNL1])
|
|
Packit |
c22fc9 |
if test .$enable_libnl_dynamic = .yes; then
|
|
Packit |
c22fc9 |
add_pkg_config_without_libs([libnl-1])
|
|
Packit |
c22fc9 |
add_config_opt([LIBNL_DYNAMIC])
|
|
Packit |
c22fc9 |
AC_DEFINE([_LIBNL_DYNAMIC_], [ 1 ], [Define to 1 if building with libnl dynamic linking])
|
|
Packit |
c22fc9 |
NEED_LIBDL=Yes
|
|
Packit |
c22fc9 |
get_lib_name([nl], [nl_socket_modify_cb])
|
|
Packit |
c22fc9 |
AC_DEFINE_UNQUOTED([NL_LIB_NAME], [ "$LIB_NAME" ], [Define the nl library name])
|
|
Packit |
c22fc9 |
else
|
|
Packit |
c22fc9 |
add_pkg_config([libnl-1])
|
|
Packit |
c22fc9 |
fi
|
|
Packit |
c22fc9 |
],
|
|
Packit |
c22fc9 |
[AC_MSG_WARN([keepalived will be built without libnl support.])
|
|
Packit |
c22fc9 |
])
|
|
Packit |
c22fc9 |
fi
|
|
Packit |
c22fc9 |
|
|
Packit |
c22fc9 |
if test $NETLINK_VER -ne 0; then
|
|
Packit |
c22fc9 |
SAV_CPPFLAGS="$CPPFLAGS"
|
|
Packit |
c22fc9 |
CPPFLAGS="$SAV_CPPFLAGS $NL3_CPPFLAGS"
|
|
Packit |
c22fc9 |
AC_CHECK_HEADERS([netlink/netlink.h], [], [AC_MSG_ERROR([netlink headers missing])])
|
|
Packit |
c22fc9 |
AC_CHECK_HEADERS([netlink/genl/ctrl.h netlink/genl/genl.h], [], [AC_MSG_ERROR([netlink genl headers missing])])
|
|
Packit |
c22fc9 |
CPPFLAGS="$SAV_CPPFLAGS"
|
|
Packit |
c22fc9 |
fi
|
|
Packit |
c22fc9 |
fi
|
|
Packit |
c22fc9 |
AM_CONDITIONAL([LIBNL1], [test $NETLINK_VER -eq 1])
|
|
Packit |
c22fc9 |
AM_CONDITIONAL([LIBNL3], [test $NETLINK_VER -eq 3])
|
|
Packit |
c22fc9 |
AM_CONDITIONAL([LIBNL_DYNAMIC], [test .$enable_lvs != .no -a .$enable_libnl_dynamic = .yes -a $NETLINK_VER -ne 0])
|
|
Packit |
c22fc9 |
|
|
Packit |
c22fc9 |
AC_CHECK_LIB(magic, magic_open,
|
|
Packit |
c22fc9 |
[
|
|
Packit |
c22fc9 |
AC_DEFINE([_HAVE_LIBMAGIC_], [ 1 ], [Define to 1 if have magic library])
|
|
Packit |
c22fc9 |
add_to_var([KA_LIBS], [-lmagic])
|
|
Packit |
c22fc9 |
])
|
|
Packit |
c22fc9 |
unset LIBS
|
|
Packit |
c22fc9 |
|
|
Packit |
c22fc9 |
dnl -- Check for the following variables introduced at various times into Linux
|
|
Packit |
c22fc9 |
dnl --FRA_OIFNAME dnl -- Linux 2.6.33
|
|
Packit |
c22fc9 |
dnl --RTAX_QUICKACK dnl -- Linux 3.11
|
|
Packit |
c22fc9 |
dnl --FRA_SUPPRESS_PREFIXLEN dnl -- Linux 3.12
|
|
Packit |
c22fc9 |
dnl --FRA_SUPPRESS_IFGROUP dnl -- Linux 3.12
|
|
Packit |
c22fc9 |
dnl --RTAX_CC_ALGO dnl -- Linux 4.0
|
|
Packit |
c22fc9 |
dnl --RTA_VIA dnl -- Linux 4.1
|
|
Packit |
c22fc9 |
dnl --RTA_NEWDST dnl -- Linux 4.1
|
|
Packit |
c22fc9 |
dnl --RTA_PREF dnl -- Linux 4.1
|
|
Packit |
c22fc9 |
dnl --FRA_TUN_ID dnl -- Linux 4.3
|
|
Packit |
c22fc9 |
dnl --RTA_ENCAP dnl -- Linux 4.3
|
|
Packit |
c22fc9 |
dnl --RTEXT_FILTER_SKIP_STATS dnl -- Linux 4.4
|
|
Packit |
c22fc9 |
dnl --RTA_EXPIRES dnl -- Linux 4.5
|
|
Packit |
c22fc9 |
dnl --FRA_L3MDEV dnl -- Linux 4.8
|
|
Packit |
c22fc9 |
dnl --FRA_UID_RANGE dnl -- Linux 4.10
|
|
Packit |
c22fc9 |
dnl --RTAX_FASTOPEN_NO_COOKIE dnl -- Linux 4.15
|
|
Packit |
c22fc9 |
dnl --FRA_PROTOCOL dnl -- Linux 4.17
|
|
Packit |
c22fc9 |
dnl --FRA_IP_PROTO dnl -- Linux 4.17
|
|
Packit |
c22fc9 |
dnl --FRA_SPORT_RANGE dnl -- Linux 4.17
|
|
Packit |
c22fc9 |
dnl --FRA_DPORT_RANGE dnl -- Linux 4.17
|
|
Packit |
c22fc9 |
dnl --RTA_TTL_PROPAGATE dnl -- Linux 4.12
|
|
Packit |
c22fc9 |
AC_CHECK_DECLS([RTA_ENCAP, RTA_EXPIRES, RTA_NEWDST, RTA_PREF, FRA_SUPPRESS_PREFIXLEN, FRA_SUPPRESS_IFGROUP, FRA_TUN_ID, RTAX_CC_ALGO, RTAX_QUICKACK, RTEXT_FILTER_SKIP_STATS, FRA_L3MDEV, FRA_UID_RANGE, RTAX_FASTOPEN_NO_COOKIE, RTA_VIA, FRA_OIFNAME, FRA_PROTOCOL, FRA_IP_PROTO, FRA_SPORT_RANGE, FRA_DPORT_RANGE, RTA_TTL_PROPAGATE], [], [],
|
|
Packit |
c22fc9 |
[[$RTNETLINK_EXTRA_INCLUDES
|
|
Packit |
c22fc9 |
#include <linux/rtnetlink.h>
|
|
Packit |
c22fc9 |
#include <sys/socket.h>
|
|
Packit |
c22fc9 |
#include <linux/fib_rules.h>]])
|
|
Packit |
c22fc9 |
for flag in RTA_ENCAP RTA_EXPIRES RTA_NEWDST RTA_PREF FRA_SUPPRESS_PREFIXLEN FRA_SUPPRESS_IFGROUP FRA_TUN_ID RTAX_CC_ALGO RTAX_QUICKACK RTEXT_FILTER_SKIP_STATS FRA_L3MDEV FRA_UID_RANGE RTAX_FASTOPEN_NO_COOKIE RTA_VIA FRA_OIFNAME FRA_PROTOCOL FRA_IP_PROTO FRA_SPORT_RANGE FRA_DPORT_RANGE RTA_TTL_PROPAGATE; do
|
|
Packit |
c22fc9 |
AS_VAR_COPY([decl_var], [ac_cv_have_decl_$flag])
|
|
Packit |
c22fc9 |
if test ${decl_var} = yes; then
|
|
Packit |
c22fc9 |
add_system_opt[${flag}]
|
|
Packit |
c22fc9 |
fi
|
|
Packit |
c22fc9 |
done
|
|
Packit |
c22fc9 |
|
|
Packit |
c22fc9 |
dnl - Introduced in Linux 3.14
|
|
Packit |
c22fc9 |
AC_CHECK_DECLS([IFA_FLAGS], [], [], [[#include <linux/if_addr.h>]])
|
|
Packit |
c22fc9 |
for flag in IFA_FLAGS; do
|
|
Packit |
c22fc9 |
AS_VAR_COPY([decl_var], [ac_cv_have_decl_$flag])
|
|
Packit |
c22fc9 |
if test ${decl_var} = yes; then
|
|
Packit |
c22fc9 |
add_system_opt[${flag}]
|
|
Packit |
c22fc9 |
fi
|
|
Packit |
c22fc9 |
done
|
|
Packit |
c22fc9 |
|
|
Packit |
c22fc9 |
dnl - Introduced in Linux 2.6.31, but not until glibc 2.17
|
|
Packit |
c22fc9 |
AC_CHECK_DECLS([IP_MULTICAST_ALL],
|
|
Packit |
c22fc9 |
[
|
|
Packit |
c22fc9 |
add_system_opt[IP_MULTICAST_ALL]
|
|
Packit |
c22fc9 |
# Check if definition is in netinet/in.h, since we can't include linux/in.h
|
|
Packit |
c22fc9 |
# due to conflicting definitions
|
|
Packit |
c22fc9 |
AC_LINK_IFELSE(
|
|
Packit |
c22fc9 |
[
|
|
Packit |
c22fc9 |
AC_LANG_SOURCE(
|
|
Packit |
c22fc9 |
[[
|
|
Packit |
c22fc9 |
#include <netinet/in.h>
|
|
Packit |
c22fc9 |
int main(int argc, char **argv)
|
|
Packit |
c22fc9 |
{
|
|
Packit |
c22fc9 |
int i = IP_MULTICAST_ALL;
|
|
Packit |
c22fc9 |
}
|
|
Packit |
c22fc9 |
]])
|
|
Packit |
c22fc9 |
],
|
|
Packit |
c22fc9 |
[],
|
|
Packit |
c22fc9 |
[
|
|
Packit |
c22fc9 |
# No - netinet/in.h doesn't have IP_MULTICAST_ALL
|
|
Packit |
c22fc9 |
# Build a program that will output the value of the kernel's IP_MULTICAST_ALL
|
|
Packit |
c22fc9 |
AC_LINK_IFELSE(
|
|
Packit |
c22fc9 |
[
|
|
Packit |
c22fc9 |
AC_LANG_SOURCE(
|
|
Packit |
c22fc9 |
[[
|
|
Packit |
c22fc9 |
#include <sys/socket.h>
|
|
Packit |
c22fc9 |
#include <linux/in.h>
|
|
Packit |
c22fc9 |
#include <stdio.h>
|
|
Packit |
c22fc9 |
int main(int argc, char **argv)
|
|
Packit |
c22fc9 |
{
|
|
Packit |
c22fc9 |
printf("%d\n", IP_MULTICAST_ALL);
|
|
Packit |
c22fc9 |
}
|
|
Packit |
c22fc9 |
]])
|
|
Packit |
c22fc9 |
],
|
|
Packit |
c22fc9 |
[
|
|
Packit |
c22fc9 |
# Create local definition of IP_MULTICAST_ALL
|
|
Packit |
c22fc9 |
IMA=$(./conftest$EXEEXT)
|
|
Packit |
c22fc9 |
AC_DEFINE_UNQUOTED([IP_MULTICAST_ALL], [ $IMA ], [Defined to value in <linux/in.h> if not in <netinet/in.h>])
|
|
Packit |
c22fc9 |
])
|
|
Packit |
c22fc9 |
]
|
|
Packit |
c22fc9 |
)
|
|
Packit |
c22fc9 |
],
|
|
Packit |
c22fc9 |
[],
|
|
Packit |
c22fc9 |
[[
|
|
Packit |
c22fc9 |
#include <sys/socket.h>
|
|
Packit |
c22fc9 |
#include <linux/in.h>
|
|
Packit |
c22fc9 |
]])
|
|
Packit |
c22fc9 |
|
|
Packit |
c22fc9 |
dnl -- RedHat backported ENCAP_IP and ENCAP_IP6 without MPLS and ILA
|
|
Packit |
c22fc9 |
AC_CHECK_DECLS([LWTUNNEL_ENCAP_MPLS, LWTUNNEL_ENCAP_ILA], [], [],
|
|
Packit |
c22fc9 |
[[#include <linux/lwtunnel.h>]])
|
|
Packit |
c22fc9 |
if test ${ac_cv_have_decl_RTA_ENCAP}; then
|
|
Packit |
c22fc9 |
for flag in LWTUNNEL_ENCAP_MPLS LWTUNNEL_ENCAP_ILA; do
|
|
Packit |
c22fc9 |
AS_VAR_COPY([decl_var], [ac_cv_have_decl_$flag])
|
|
Packit |
c22fc9 |
if test ${decl_var} = yes; then
|
|
Packit |
c22fc9 |
add_system_opt[${flag}]
|
|
Packit |
c22fc9 |
fi
|
|
Packit |
c22fc9 |
done
|
|
Packit |
c22fc9 |
fi
|
|
Packit |
c22fc9 |
|
|
Packit |
c22fc9 |
dnl ----[Check for iptables libraries]----
|
|
Packit |
c22fc9 |
USE_LIBIPTC=No
|
|
Packit |
c22fc9 |
USE_LIBIPSET=No
|
|
Packit |
c22fc9 |
if test .${enable_libiptc} != .no -a .$enable_vrrp != .no; then
|
|
Packit |
c22fc9 |
USE_LIBIPTC=Yes
|
|
Packit |
c22fc9 |
dnl -- linux/netfilter/x_tables.h since Linux 2.6.16
|
|
Packit |
c22fc9 |
SAV_CPPFLAGS="$CPPFLAGS"
|
|
Packit |
c22fc9 |
CPPFLAGS="$CPPFLAGS $kernelinc"
|
|
Packit |
c22fc9 |
AC_CHECK_HEADERS([linux/netfilter/x_tables.h xtables.h libiptc/libip6tc.h libiptc/libiptc.h libiptc/libxtc.h], [],
|
|
Packit |
c22fc9 |
[
|
|
Packit |
c22fc9 |
USE_LIBIPTC=No
|
|
Packit |
c22fc9 |
break
|
|
Packit |
c22fc9 |
])
|
|
Packit |
c22fc9 |
CPPFLAGS="$SAV_CPPFLAGS"
|
|
Packit |
c22fc9 |
|
|
Packit |
c22fc9 |
if test $USE_LIBIPTC = Yes; then
|
|
Packit |
c22fc9 |
add_pkg_config([--static libiptc], [IPTC])
|
|
Packit |
c22fc9 |
LIBS="$IPTC_LIBS"
|
|
Packit |
c22fc9 |
SAV_CPPFLAGS="$CPPFLAGS"
|
|
Packit |
c22fc9 |
CPPFLAGS="$CPPFLAGS $kernelinc"
|
|
Packit |
c22fc9 |
AC_CHECK_LIB(iptc, iptc_init,
|
|
Packit |
c22fc9 |
[
|
|
Packit |
c22fc9 |
AC_DEFINE([_HAVE_LIBIPTC_], [ 1 ], [Define to 1 if have iptables libraries])
|
|
Packit |
c22fc9 |
add_system_opt([LIBIPTC])
|
|
Packit |
c22fc9 |
if test .${enable_libiptc_dynamic} != .yes; then
|
|
Packit |
c22fc9 |
add_pkg_config([--static libiptc])
|
|
Packit |
c22fc9 |
dnl - Older versions of libiptc produced a requirement for -liptc, but we don't need it
|
|
Packit |
c22fc9 |
KA_LIBS=`echo $KA_LIBS | sed -e "s/ -liptc//"`
|
|
Packit |
c22fc9 |
dnl - Even older versions of libiptc don't produce any requirement other than -liptc
|
|
Packit |
c22fc9 |
IPTC_LIBS=`echo $IPTC_LIBS | sed -e "s/ *-L[[^ ]]* */ /" -e "s/ *-liptc */ /" -e "s/^ *$//"`
|
|
Packit |
c22fc9 |
if test ".$IPTC_LIBS" = .; then
|
|
Packit |
c22fc9 |
KA_LIBS=`echo $KA_LIBS -lip4tc -lip6tc`
|
|
Packit |
c22fc9 |
fi
|
|
Packit |
c22fc9 |
else
|
|
Packit |
c22fc9 |
add_pkg_config_without_libs([libiptc])
|
|
Packit |
c22fc9 |
add_config_opt([LIBIPTC_DYNAMIC])
|
|
Packit |
c22fc9 |
AC_DEFINE([_LIBIPTC_DYNAMIC_], [ 1 ], [Define to 1 if building with libiptc dynamic linking])
|
|
Packit |
c22fc9 |
NEED_LIBDL=Yes
|
|
Packit |
c22fc9 |
get_lib_name([ip4tc], [iptc_init])
|
|
Packit |
c22fc9 |
AC_DEFINE_UNQUOTED([IP4TC_LIB_NAME], [ "$LIB_NAME" ], [Define the ip4tc library name])
|
|
Packit |
c22fc9 |
get_lib_name([ip6tc], [ip6tc_init])
|
|
Packit |
c22fc9 |
AC_DEFINE_UNQUOTED([IP6TC_LIB_NAME], [ "$LIB_NAME" ], [Define the ip6tc library name])
|
|
Packit |
c22fc9 |
fi
|
|
Packit |
c22fc9 |
],
|
|
Packit |
c22fc9 |
[USE_LIBIPTC=No])
|
|
Packit |
c22fc9 |
CPPFLAGS="$SAV_CPPFLAGS"
|
|
Packit |
c22fc9 |
fi
|
|
Packit |
c22fc9 |
|
|
Packit |
c22fc9 |
if test $USE_LIBIPTC = Yes; then
|
|
Packit |
c22fc9 |
if test .$enable_libxtables_dynamic != .yes; then
|
|
Packit |
c22fc9 |
add_pkg_config([xtables])
|
|
Packit |
c22fc9 |
else
|
|
Packit |
c22fc9 |
add_pkg_config_without_libs([xtables])
|
|
Packit |
c22fc9 |
AC_DEFINE([_LIBXTABLES_DYNAMIC_], [ 1 ], [Define to 1 if building with libxtables dynamic linking])
|
|
Packit |
c22fc9 |
add_config_opt([XTABLES_DYNAMIC])
|
|
Packit |
c22fc9 |
NEED_LIBDL=Yes
|
|
Packit |
c22fc9 |
get_lib_name([xtables], [xtables_insmod])
|
|
Packit |
c22fc9 |
AC_DEFINE_UNQUOTED([XTABLES_LIB_NAME], [ "$LIB_NAME" ], [Define the xtables library name])
|
|
Packit |
c22fc9 |
fi
|
|
Packit |
c22fc9 |
|
|
Packit |
c22fc9 |
dnl ----[Check for ipset libraries]----
|
|
Packit |
c22fc9 |
SAV_CPPFLAGS="$CPPFLAGS"
|
|
Packit |
c22fc9 |
CPPFLAGS="$CPPFLAGS $kernelinc"
|
|
Packit |
c22fc9 |
if test "${enable_libipset}" != no; then
|
|
Packit |
c22fc9 |
$PKG_CONFIG --exists libipset
|
|
Packit |
c22fc9 |
if test $? -eq 0; then
|
|
Packit |
c22fc9 |
add_pkg_config([libipset], [IPSET])
|
|
Packit |
c22fc9 |
else
|
|
Packit |
c22fc9 |
IPSET_LIBS="-lipset"
|
|
Packit |
c22fc9 |
fi
|
|
Packit |
c22fc9 |
SAV_LIBS=$LIBS
|
|
Packit |
c22fc9 |
LIBS="$IPTC_LIBS $IPSET_LIBS"
|
|
Packit |
c22fc9 |
|
|
Packit |
c22fc9 |
AC_CHECK_LIB(ipset, ipset_session_init,
|
|
Packit |
c22fc9 |
[
|
|
Packit |
c22fc9 |
USE_LIBIPSET=Yes
|
|
Packit |
c22fc9 |
AC_CHECK_HEADERS([libipset/data.h libipset/linux_ip_set.h libipset/session.h libipset/types.h], [],
|
|
Packit |
c22fc9 |
[
|
|
Packit |
c22fc9 |
USE_LIBIPSET=No
|
|
Packit |
c22fc9 |
break
|
|
Packit |
c22fc9 |
])
|
|
Packit |
c22fc9 |
|
|
Packit |
c22fc9 |
if test $USE_LIBIPSET = Yes; then
|
|
Packit |
c22fc9 |
AC_CHECK_LIB(xtables, xtables_insmod, [], [USE_LIBIPSET=No])
|
|
Packit |
c22fc9 |
fi
|
|
Packit |
c22fc9 |
|
|
Packit |
c22fc9 |
if test $USE_LIBIPSET = Yes; then
|
|
Packit |
c22fc9 |
dnl -- Need to use <libipset/linux_ip_set.h> for <linux/netfilter/xt_set.h> prior to Linux 3.4
|
|
Packit |
c22fc9 |
EXTRA_INCLUDE=
|
|
Packit |
c22fc9 |
AC_COMPILE_IFELSE([AC_LANG_SOURCE([[
|
|
Packit |
c22fc9 |
#include <linux/netfilter/xt_set.h>
|
|
Packit |
c22fc9 |
]])],
|
|
Packit |
c22fc9 |
[AC_CHECK_HEADERS([linux/netfilter/xt_set.h], [], [USE_LIBIPSET=No], [])],
|
|
Packit |
c22fc9 |
[AC_CHECK_HEADER([linux/netfilter/xt_set.h],
|
|
Packit |
c22fc9 |
[
|
|
Packit |
c22fc9 |
AC_DEFINE([USE_LIBIPSET_LINUX_IP_SET_H], [ 1 ], [Define to 1 if <linux/netfilter/xt_set.h> needs <libipset/linux_ip_set.h>])
|
|
Packit |
c22fc9 |
EXTRA_INCLUDE="#include <libipset/linux_ip_set.h>"
|
|
Packit |
c22fc9 |
], [USE_LIBIPSET=No],
|
|
Packit |
c22fc9 |
[[#include <libipset/linux_ip_set.h>]])
|
|
Packit |
c22fc9 |
]
|
|
Packit |
c22fc9 |
)
|
|
Packit |
c22fc9 |
fi
|
|
Packit |
c22fc9 |
|
|
Packit |
c22fc9 |
if test $USE_LIBIPSET = Yes; then
|
|
Packit |
c22fc9 |
AC_DEFINE([_HAVE_LIBIPSET_], [ 1 ], [Define to 1 if have ipset library])
|
|
Packit |
c22fc9 |
$PKG_CONFIG --exists libipset
|
|
Packit |
c22fc9 |
if test $? -eq 0; then
|
|
Packit |
c22fc9 |
if test .${enable_libipset_dynamic} = .no; then
|
|
Packit |
c22fc9 |
add_pkg_config([libipset])
|
|
Packit |
c22fc9 |
else
|
|
Packit |
c22fc9 |
add_pkg_config_without_libs([libipset])
|
|
Packit |
c22fc9 |
fi
|
|
Packit |
c22fc9 |
elif test .${enable_libipset_dynamic} = .no; then
|
|
Packit |
c22fc9 |
add_to_var([KA_LIBS], [-lipset])
|
|
Packit |
c22fc9 |
fi
|
|
Packit |
c22fc9 |
if test .${enable_libipset_dynamic} != .no; then
|
|
Packit |
c22fc9 |
AC_DEFINE([_LIBIPSET_DYNAMIC_], [ 1 ], [Define to 1 if building with libipset dynamic linking])
|
|
Packit |
c22fc9 |
add_config_opt([LIBIPSET_DYNAMIC])
|
|
Packit |
c22fc9 |
NEED_LIBDL=Yes
|
|
Packit |
c22fc9 |
get_lib_name([ipset], [ipset_session_init])
|
|
Packit |
c22fc9 |
AC_DEFINE_UNQUOTED([IPSET_LIB_NAME], [ "$LIB_NAME" ], [Define the ipset library name])
|
|
Packit |
c22fc9 |
else
|
|
Packit |
c22fc9 |
add_config_opt([LIBIPSET])
|
|
Packit |
c22fc9 |
fi
|
|
Packit |
c22fc9 |
|
|
Packit |
c22fc9 |
dnl -- xt_set_info_match first introduced in Linux 2.6.39 (initial implementation of ipsets)
|
|
Packit |
c22fc9 |
dnl -- xt_set_info_match_v1 declared since Linux 3.1
|
|
Packit |
c22fc9 |
AC_CHECK_MEMBER([struct xt_set_info_match_v1.match_set.index], [AC_DEFINE([HAVE_XT_SET_INFO_MATCH_V1], [ 1 ], [Define to 1 if have struct xt_set_info_match_v1])], [],
|
|
Packit |
c22fc9 |
[
|
|
Packit |
c22fc9 |
$EXTRA_INCLUDE
|
|
Packit |
c22fc9 |
#include <linux/netfilter/xt_set.h>
|
|
Packit |
c22fc9 |
])
|
|
Packit |
c22fc9 |
dnl -- xt_set_info_match_v3 declared since Linux 3.10
|
|
Packit |
c22fc9 |
AC_CHECK_MEMBER([struct xt_set_info_match_v3.match_set.index], [AC_DEFINE([HAVE_XT_SET_INFO_MATCH_V3], [ 1 ], [Define to 1 if have struct xt_set_info_match_v3])], [],
|
|
Packit |
c22fc9 |
[
|
|
Packit |
c22fc9 |
$EXTRA_INCLUDE
|
|
Packit |
c22fc9 |
#include <linux/netfilter/xt_set.h>
|
|
Packit |
c22fc9 |
])
|
|
Packit |
c22fc9 |
dnl -- xt_set_info_match_v4 declared since Linux 3.19
|
|
Packit |
c22fc9 |
AC_CHECK_MEMBER([struct xt_set_info_match_v4.match_set.index], [AC_DEFINE([HAVE_XT_SET_INFO_MATCH_V4], [ 1 ], [Define to 1 if have struct xt_set_info_match_v4])], [],
|
|
Packit |
c22fc9 |
[
|
|
Packit |
c22fc9 |
$EXTRA_INCLUDE
|
|
Packit |
c22fc9 |
#include <linux/netfilter/xt_set.h>
|
|
Packit |
c22fc9 |
])
|
|
Packit |
c22fc9 |
|
|
Packit |
c22fc9 |
dnl - ipset type iface introduced in Linux 3.1
|
|
Packit |
c22fc9 |
AC_COMPILE_IFELSE([AC_LANG_SOURCE([[
|
|
Packit |
c22fc9 |
#include <linux/netfilter/ipset/ip_set.h>
|
|
Packit |
c22fc9 |
int main(void) { int var = IPSET_ATTR_IFACE; }
|
|
Packit |
c22fc9 |
]])],
|
|
Packit |
c22fc9 |
[AC_DEFINE([HAVE_IPSET_ATTR_IFACE], [ 1 ], [Define to 1 if ipset supports iface type])])
|
|
Packit |
c22fc9 |
|
|
Packit |
c22fc9 |
dnl - The include guard for <linux/netfilter/ipset/ip_set.h> has the leading _UAPI remove when
|
|
Packit |
c22fc9 |
dnl - the source code is processed to produce the actual header files.
|
|
Packit |
c22fc9 |
dnl - Unfortunately libipset provides a copy of the kernel headers, as <libipset/linux_ip_set*.h>,
|
|
Packit |
c22fc9 |
dnl - but it doesn't remove the _UAPI from the header files when installing them.
|
|
Packit |
c22fc9 |
dnl - Unfortunately we need to include some libipset header files, which include the
|
|
Packit |
c22fc9 |
dnl - libipset version, and also <linux/netfilter/xt_set.h> which includes the kernel version.
|
|
Packit |
c22fc9 |
dnl - To get around this problem, after include one of these we need to define the header guard
|
|
Packit |
c22fc9 |
dnl - for the other, to stop it being included as well.
|
|
Packit |
c22fc9 |
dnl - This is reported as a bug against ipset at https://bugzilla.netfilter.org/show_bug.cgi?id=1139
|
|
Packit |
c22fc9 |
dnl - We will take the kernel version if there is an inclusion collision.
|
|
Packit |
c22fc9 |
AC_COMPILE_IFELSE([AC_LANG_SOURCE([[
|
|
Packit |
c22fc9 |
#include <linux/netfilter/ipset/ip_set.h>
|
|
Packit |
c22fc9 |
#include <libipset/linux_ip_set.h>
|
|
Packit |
c22fc9 |
int main(void) {}
|
|
Packit |
c22fc9 |
]])], [],
|
|
Packit |
c22fc9 |
[AC_COMPILE_IFELSE([AC_LANG_SOURCE([[
|
|
Packit |
c22fc9 |
#include <linux/netfilter/ipset/ip_set.h>
|
|
Packit |
c22fc9 |
#ifdef _UAPI_IP_SET_H
|
|
Packit |
c22fc9 |
#error _UAPI_IP_SET_H defined
|
|
Packit |
c22fc9 |
#endif
|
|
Packit |
c22fc9 |
int main(void) {}
|
|
Packit |
c22fc9 |
]])],
|
|
Packit |
c22fc9 |
[AC_DEFINE([LIBIPSET_H_ADD_UAPI_IP_SET_H_GUARD], [1], [Define to add guard _UAPI_IP_SET_H before including <libipset/linux_ip_set.h>])],
|
|
Packit |
c22fc9 |
[AC_DEFINE([LIBIPSET_H_ADD_IP_SET_H_GUARD], [1], [Define to add guard _IP_SET_H before including <libipset/linux_ip_set.h>])])
|
|
Packit |
c22fc9 |
])
|
|
Packit |
c22fc9 |
fi
|
|
Packit |
c22fc9 |
|
|
Packit |
c22fc9 |
if test $USE_LIBIPSET = Yes; then
|
|
Packit |
c22fc9 |
AC_MSG_CHECKING([for libipset version 7 or later])
|
|
Packit |
c22fc9 |
AC_COMPILE_IFELSE([AC_LANG_SOURCE(
|
|
Packit |
c22fc9 |
[[
|
|
Packit |
c22fc9 |
#include <libipset/session.h>
|
|
Packit |
c22fc9 |
|
|
Packit |
c22fc9 |
void test_func(void)
|
|
Packit |
c22fc9 |
{
|
|
Packit |
c22fc9 |
ipset_session_init(NULL, NULL);
|
|
Packit |
c22fc9 |
}
|
|
Packit |
c22fc9 |
]])],
|
|
Packit |
c22fc9 |
[
|
|
Packit |
c22fc9 |
AC_MSG_RESULT([yes])
|
|
Packit |
c22fc9 |
],
|
|
Packit |
c22fc9 |
[
|
|
Packit |
c22fc9 |
AC_MSG_RESULT([no])
|
|
Packit |
c22fc9 |
AC_DEFINE([LIBIPSET_PRE_V7_COMPAT], [ 1 ], [Define to 1 if libipset library version prior to v7])
|
|
Packit |
c22fc9 |
add_system_opt[LIBIPSET_PRE_V7]
|
|
Packit |
c22fc9 |
])
|
|
Packit |
c22fc9 |
fi
|
|
Packit |
c22fc9 |
])
|
|
Packit |
c22fc9 |
LIBS="$SAV_LIBS"
|
|
Packit |
c22fc9 |
fi
|
|
Packit |
c22fc9 |
|
|
Packit |
c22fc9 |
dnl -- XT_EXTENSION_MAXNAMELEN not defined until Linux 2.6.35
|
|
Packit |
c22fc9 |
AC_CHECK_DECL([XT_EXTENSION_MAXNAMELEN], [],
|
|
Packit |
c22fc9 |
[AC_DEFINE([XT_EXTENSION_MAXNAMELEN], [ (XT_FUNCTION_MAXNAMELEN - 1) ], [Define if <linux/netfilter/x_tables.h> doesnt define it])],
|
|
Packit |
c22fc9 |
[#include <linux/netfilter/x_tables.h>])
|
|
Packit |
c22fc9 |
|
|
Packit |
c22fc9 |
CPPFLAGS="$SAV_CPPFLAGS"
|
|
Packit |
c22fc9 |
fi
|
|
Packit |
c22fc9 |
fi
|
|
Packit |
c22fc9 |
AM_CONDITIONAL([LIBIPTC], [test $USE_LIBIPTC = Yes])
|
|
Packit |
c22fc9 |
AM_CONDITIONAL([LIBIPSET], [test $USE_LIBIPSET = Yes])
|
|
Packit |
c22fc9 |
unset LIBS
|
|
Packit |
c22fc9 |
|
|
Packit |
c22fc9 |
dnl ----[Check if have linux/if.h and net/if.h namespace collision]----
|
|
Packit |
c22fc9 |
# Including <linux/if.h> and <net/if.h> can cause a namespace collision.
|
|
Packit |
c22fc9 |
# Later versions of the headers are OK if linux/if.h is included second
|
|
Packit |
c22fc9 |
AC_MSG_CHECKING([for linux/if.h and net/if.h namespace collision])
|
|
Packit |
c22fc9 |
SAV_CPPFLAGS="$CPPFLAGS"
|
|
Packit |
c22fc9 |
CPPFLAGS="$CPPFLAGS $kernelinc"
|
|
Packit |
c22fc9 |
AC_COMPILE_IFELSE([AC_LANG_SOURCE([[
|
|
Packit |
c22fc9 |
#include <net/if.h>
|
|
Packit |
c22fc9 |
#include <linux/if.h>
|
|
Packit |
c22fc9 |
]])],
|
|
Packit |
c22fc9 |
[
|
|
Packit |
c22fc9 |
AC_MSG_RESULT([no])
|
|
Packit |
c22fc9 |
],
|
|
Packit |
c22fc9 |
[
|
|
Packit |
c22fc9 |
AC_MSG_RESULT([yes])
|
|
Packit |
c22fc9 |
AC_DEFINE([_HAVE_NET_LINUX_IF_H_COLLISION_], [ 1 ], [Define to 1 if have linux/if.h followed by net/if.h namespace collision])
|
|
Packit |
c22fc9 |
add_system_opt([NET_LINUX_IF_H_COLLISION])
|
|
Packit |
c22fc9 |
])
|
|
Packit |
c22fc9 |
CPPFLAGS="$SAV_CPPFLAGS"
|
|
Packit |
c22fc9 |
|
|
Packit |
c22fc9 |
dnl ----[Check if have linux/if_ether.h and netinet/if_ether.h namespace collision]----
|
|
Packit |
c22fc9 |
# Including <linux/if_ether.h> and <netinet/if_ether.h> causes a namespace collision
|
|
Packit |
c22fc9 |
# with musl libc, but the collision only occurs if linux/ip_ether.h is included
|
|
Packit |
c22fc9 |
# before netinet/if_ether.h. The problem is that we want to include them in that
|
|
Packit |
c22fc9 |
# order.
|
|
Packit |
c22fc9 |
AC_MSG_CHECKING([for linux/if_ether.h then netinet/if_ether.h namespace collision])
|
|
Packit |
c22fc9 |
SAV_CPPFLAGS="$CPPFLAGS"
|
|
Packit |
c22fc9 |
CPPFLAGS="$CPPFLAGS $kernelinc"
|
|
Packit |
c22fc9 |
AC_COMPILE_IFELSE([AC_LANG_SOURCE([[
|
|
Packit |
c22fc9 |
#include <linux/if_ether.h>
|
|
Packit |
c22fc9 |
#include <netinet/if_ether.h>
|
|
Packit |
c22fc9 |
]])],
|
|
Packit |
c22fc9 |
[
|
|
Packit |
c22fc9 |
AC_MSG_RESULT([no])
|
|
Packit |
c22fc9 |
],
|
|
Packit |
c22fc9 |
[
|
|
Packit |
c22fc9 |
AC_MSG_RESULT([yes])
|
|
Packit |
c22fc9 |
AC_DEFINE([_HAVE_NETINET_LINUX_IF_ETHER_H_COLLISION_], [ 1 ], [Define to 1 if have linux/if_ether.h then netinet/if_ether.h namespace collision])
|
|
Packit |
c22fc9 |
add_system_opt([NETINET_LINUX_IF_ETHER_H_COLLISION])
|
|
Packit |
c22fc9 |
])
|
|
Packit |
c22fc9 |
CPPFLAGS="$SAV_CPPFLAGS"
|
|
Packit |
c22fc9 |
|
|
Packit |
c22fc9 |
# Linux 4.5 to 4.5.4 has <libiptc/libiptc.h> indirectly including <net/if.h>
|
|
Packit |
c22fc9 |
# and <linux/if.h> which causes a namespace collision.
|
|
Packit |
c22fc9 |
AC_MSG_CHECKING([for libiptc/libiptc.h linux/if.h and net/if.h namespace collision])
|
|
Packit |
c22fc9 |
SAV_CPPFLAGS="$CPPFLAGS"
|
|
Packit |
c22fc9 |
CPPFLAGS="$CPPFLAGS $kernelinc"
|
|
Packit |
c22fc9 |
AC_COMPILE_IFELSE([AC_LANG_SOURCE([[
|
|
Packit |
c22fc9 |
#include <libiptc/libiptc.h>
|
|
Packit |
c22fc9 |
]])],
|
|
Packit |
c22fc9 |
[
|
|
Packit |
c22fc9 |
AC_MSG_RESULT([no])
|
|
Packit |
c22fc9 |
],
|
|
Packit |
c22fc9 |
[
|
|
Packit |
c22fc9 |
AC_MSG_RESULT([yes])
|
|
Packit |
c22fc9 |
AC_DEFINE([_HAVE_LIBIPTC_LINUX_NET_IF_H_COLLISION_], [ 1 ], [Define to 1 if have libiptc/libiptc.h linux/if.h and net/if.h namespace collision])
|
|
Packit |
c22fc9 |
add_system_opt([LIBIPTC_LINUX_NET_IF_H_COLLISION])
|
|
Packit |
c22fc9 |
])
|
|
Packit |
c22fc9 |
CPPFLAGS="$SAV_CPPFLAGS"
|
|
Packit |
c22fc9 |
|
|
Packit |
c22fc9 |
dnl ----[ Checks for LVS, VRRP and BFD support ]----
|
|
Packit |
c22fc9 |
IPVS_SYNCD_ATTRIBUTES=No
|
|
Packit |
c22fc9 |
IPVS_64BIT_STATS=No
|
|
Packit |
c22fc9 |
WITH_REGEX=No
|
|
Packit |
c22fc9 |
ENABLE_REGEX_DEBUG=No
|
|
Packit |
c22fc9 |
if test "$enable_lvs" != no; then
|
|
Packit |
c22fc9 |
IPVS_SUPPORT=Yes
|
|
Packit |
c22fc9 |
add_config_opt([LVS])
|
|
Packit |
c22fc9 |
AC_DEFINE([_WITH_LVS_], [ 1 ], [Define to 1 if have IPVS support])
|
|
Packit |
c22fc9 |
|
|
Packit |
c22fc9 |
dnl -- <linux/ip_vs.h> exists from Linux 2.6.27; prior to that <net/ip_vs.h> is used
|
|
Packit |
c22fc9 |
AC_CHECK_HEADERS([linux/ip_vs.h],
|
|
Packit |
c22fc9 |
[
|
|
Packit |
c22fc9 |
dnl -- From Linux 2.6.35 (but CentOS has it in 2.6.32)
|
|
Packit |
c22fc9 |
AC_CHECK_DECLS([IP_VS_SVC_F_ONEPACKET], [], [],
|
|
Packit |
c22fc9 |
[[#include <linux/ip_vs.h>]])
|
|
Packit |
c22fc9 |
])
|
|
Packit |
c22fc9 |
|
|
Packit |
c22fc9 |
if test $IPVS_USE_NL = Yes; then
|
|
Packit |
c22fc9 |
AC_DEFINE([LIBIPVS_USE_NL], [ 1 ], [Define to 1 if libipvs can use netlink])
|
|
Packit |
c22fc9 |
add_system_opt([LIBIPVS_NETLINK])
|
|
Packit |
c22fc9 |
fi
|
|
Packit |
c22fc9 |
|
|
Packit |
c22fc9 |
dnl ----[ IPVS syncd options ]---
|
|
Packit |
c22fc9 |
SAV_CPPFLAGS="$CPPFLAGS"
|
|
Packit |
c22fc9 |
CPPFLAGS="$CPPFLAGS $kernelinc"
|
|
Packit |
c22fc9 |
|
|
Packit |
c22fc9 |
dnl -- Since Linux 3.18
|
|
Packit |
c22fc9 |
AC_CHECK_DECLS([IPVS_DEST_ATTR_ADDR_FAMILY], [add_system_opt([IPVS_DEST_ATTR_ADDR_FAMILY])], [], [#include <linux/ip_vs.h>])
|
|
Packit |
c22fc9 |
|
|
Packit |
c22fc9 |
dnl -- Since Linux ?.?.?
|
|
Packit |
c22fc9 |
IPVS_SYNCD_ATTRIBUTES=Yes
|
|
Packit |
c22fc9 |
AC_CHECK_DECLS([
|
|
Packit |
c22fc9 |
IPVS_DAEMON_ATTR_SYNC_MAXLEN,
|
|
Packit |
c22fc9 |
IPVS_DAEMON_ATTR_MCAST_GROUP,
|
|
Packit |
c22fc9 |
IPVS_DAEMON_ATTR_MCAST_GROUP6,
|
|
Packit |
c22fc9 |
IPVS_DAEMON_ATTR_MCAST_PORT,
|
|
Packit |
c22fc9 |
IPVS_DAEMON_ATTR_MCAST_TTL], [],
|
|
Packit |
c22fc9 |
[
|
|
Packit |
c22fc9 |
IPVS_SYNCD_ATTRIBUTES=No
|
|
Packit |
c22fc9 |
break
|
|
Packit |
c22fc9 |
],
|
|
Packit |
c22fc9 |
[[#include <linux/ip_vs.h>]])
|
|
Packit |
c22fc9 |
|
|
Packit |
c22fc9 |
dnl -- Since Linux 4.3
|
|
Packit |
c22fc9 |
if test $IPVS_SYNCD_ATTRIBUTES = Yes; then
|
|
Packit |
c22fc9 |
AC_DEFINE([_HAVE_IPVS_SYNCD_ATTRIBUTES_], [ 1 ], [Define to 1 if have IPVS syncd attributes])
|
|
Packit |
c22fc9 |
add_system_opt([IPVS_SYNCD_ATTRIBUTES])
|
|
Packit |
c22fc9 |
fi
|
|
Packit |
c22fc9 |
|
|
Packit |
c22fc9 |
dnl ----[ IPVS 64-bit stats ]----
|
|
Packit |
c22fc9 |
dnl -- Since Linux 4.1
|
|
Packit |
c22fc9 |
if test "$enable_lvs_64bit_stats" != "no"; then
|
|
Packit |
c22fc9 |
IPVS_64BIT_STATS=Yes
|
|
Packit |
c22fc9 |
AC_CHECK_DECLS([
|
|
Packit |
c22fc9 |
IPVS_SVC_ATTR_STATS64,
|
|
Packit |
c22fc9 |
IPVS_DEST_ATTR_STATS64], [],
|
|
Packit |
c22fc9 |
[
|
|
Packit |
c22fc9 |
IPVS_64BIT_STATS=No
|
|
Packit |
c22fc9 |
break
|
|
Packit |
c22fc9 |
],
|
|
Packit |
c22fc9 |
[[#include <linux/ip_vs.h>]])
|
|
Packit |
c22fc9 |
if test $IPVS_64BIT_STATS = Yes; then
|
|
Packit |
c22fc9 |
AC_DEFINE([_WITH_LVS_64BIT_STATS_], [ 1 ], [Define to 1 if have IPVS 64 bit stats])
|
|
Packit |
c22fc9 |
add_system_opt([IPVS_64BIT_STATS])
|
|
Packit |
c22fc9 |
fi
|
|
Packit |
c22fc9 |
fi
|
|
Packit |
c22fc9 |
CPPFLAGS="$SAV_CPPFLAGS"
|
|
Packit |
c22fc9 |
|
|
Packit |
c22fc9 |
dnl ----[ Is HTTP_GET regex checking wanted? ]----
|
|
Packit |
c22fc9 |
AS_IF([test "$enable_regex" = yes],
|
|
Packit |
c22fc9 |
[
|
|
Packit |
c22fc9 |
$PKG_CONFIG --exists libpcre2-8
|
|
Packit |
c22fc9 |
HAVE_PCRE2=$?
|
|
Packit |
c22fc9 |
AS_IF([test $HAVE_PCRE2 -ne 0], [AC_MSG_ERROR([cannot find pcre library])])
|
|
Packit |
c22fc9 |
AC_MSG_CHECKING([for pcre.h])
|
|
Packit |
c22fc9 |
AC_COMPILE_IFELSE([AC_LANG_SOURCE([[
|
|
Packit |
c22fc9 |
#define PCRE2_CODE_UNIT_WIDTH 8
|
|
Packit |
c22fc9 |
#include <pcre2.h>
|
|
Packit |
c22fc9 |
]])],
|
|
Packit |
c22fc9 |
[
|
|
Packit |
c22fc9 |
AC_MSG_RESULT([yes])
|
|
Packit |
c22fc9 |
WITH_REGEX=Yes
|
|
Packit |
c22fc9 |
add_pkg_config([libpcre2-8])
|
|
Packit |
c22fc9 |
AC_DEFINE([_WITH_REGEX_CHECK_], [ 1 ], [Define to 1 to build with HTTP_GET regex checking])
|
|
Packit |
c22fc9 |
add_config_opt([REGEX])
|
|
Packit |
c22fc9 |
],
|
|
Packit |
c22fc9 |
[
|
|
Packit |
c22fc9 |
AC_MSG_RESULT([no])
|
|
Packit |
c22fc9 |
AC_MSG_ERROR([pcre2.h is missing])
|
|
Packit |
c22fc9 |
])
|
|
Packit |
c22fc9 |
if test "$enable_regex_timers" = yes; then
|
|
Packit |
c22fc9 |
AC_DEFINE([_WITH_REGEX_TIMERS_], [ 1 ], [Define to 1 to include regex timers])
|
|
Packit |
c22fc9 |
fi
|
|
Packit |
c22fc9 |
|
|
Packit |
c22fc9 |
if test "${enable_regex_debug}" = yes; then
|
|
Packit |
c22fc9 |
AC_DEFINE([_REGEX_DEBUG_], [ 1 ], [Define to 1 to build with regex debugging support])
|
|
Packit |
c22fc9 |
ENABLE_REGEX_DEBUG=Yes
|
|
Packit |
c22fc9 |
add_config_opt([REGEX_DEBUG])
|
|
Packit |
c22fc9 |
fi
|
|
Packit |
c22fc9 |
])
|
|
Packit |
c22fc9 |
else
|
|
Packit |
c22fc9 |
IPVS_SUPPORT=No
|
|
Packit |
c22fc9 |
fi
|
|
Packit |
c22fc9 |
AM_CONDITIONAL([WITH_IPVS], [test $IPVS_SUPPORT = Yes])
|
|
Packit |
c22fc9 |
AM_CONDITIONAL([WITH_REGEX], [test $WITH_REGEX = Yes])
|
|
Packit |
c22fc9 |
|
|
Packit |
c22fc9 |
dnl ----[ Checks for kernel netlink support ]----
|
|
Packit |
c22fc9 |
VRRP_SUPPORT=No
|
|
Packit |
c22fc9 |
VRRP_AUTH_SUPPORT=No
|
|
Packit |
c22fc9 |
MACVLAN_SUPPORT=No
|
|
Packit |
c22fc9 |
ENABLE_JSON=No
|
|
Packit |
c22fc9 |
BFD_SUPPORT=No
|
|
Packit |
c22fc9 |
if test "$enable_vrrp" != no; then
|
|
Packit |
c22fc9 |
VRRP_SUPPORT=Yes
|
|
Packit |
c22fc9 |
AC_DEFINE([_WITH_VRRP_], [ 1 ], [Define to 1 if have VRRP support])
|
|
Packit |
c22fc9 |
add_config_opt([VRRP])
|
|
Packit |
c22fc9 |
|
|
Packit |
c22fc9 |
dnl ----[ check for VRRP authentication support ]----
|
|
Packit |
c22fc9 |
if test "${enable_vrrp_auth}" != no; then
|
|
Packit |
c22fc9 |
VRRP_AUTH_SUPPORT=Yes
|
|
Packit |
c22fc9 |
AC_DEFINE([_WITH_VRRP_AUTH_], [ 1 ], [Define to 1 if want ARRP authentication support])
|
|
Packit |
c22fc9 |
add_config_opt([VRRP_AUTH])
|
|
Packit |
c22fc9 |
fi
|
|
Packit |
c22fc9 |
|
|
Packit |
c22fc9 |
dnl ----[ Checks for kernel VMAC support ]----
|
|
Packit |
c22fc9 |
SAV_CPPFLAGS="$CPPFLAGS"
|
|
Packit |
c22fc9 |
CPPFLAGS="$CPPFLAGS $kernelinc"
|
|
Packit |
c22fc9 |
MACVLAN_SUPPORT=Yes
|
|
Packit |
c22fc9 |
dnl -- Since Linux 2.6.33
|
|
Packit |
c22fc9 |
AC_CHECK_DECLS([
|
|
Packit |
c22fc9 |
IFLA_MACVLAN_MODE,
|
|
Packit |
c22fc9 |
MACVLAN_MODE_PRIVATE], [],
|
|
Packit |
c22fc9 |
[
|
|
Packit |
c22fc9 |
MACVLAN_SUPPORT=No
|
|
Packit |
c22fc9 |
break
|
|
Packit |
c22fc9 |
], [[
|
|
Packit |
c22fc9 |
#include <sys/socket.h>
|
|
Packit |
c22fc9 |
#include <linux/if_link.h>
|
|
Packit |
c22fc9 |
]])
|
|
Packit |
c22fc9 |
if test $MACVLAN_SUPPORT = Yes; then
|
|
Packit |
c22fc9 |
AC_DEFINE([_HAVE_VRRP_VMAC_], [ 1 ], [Define to 1 if have MAC VLAN support])
|
|
Packit |
c22fc9 |
add_system_opt([VRRP_VMAC])
|
|
Packit |
c22fc9 |
fi
|
|
Packit |
c22fc9 |
CPPFLAGS="$SAV_CPPFLAGS"
|
|
Packit |
c22fc9 |
|
|
Packit |
c22fc9 |
dnl ----[ Json output or not ? ]----
|
|
Packit |
c22fc9 |
if test "${enable_json}" = yes; then
|
|
Packit |
c22fc9 |
JSON_HEADERS=$($PKG_CONFIG --cflags-only-I json-c)
|
|
Packit |
c22fc9 |
SAV_CPPFLAGS="$CPPFLAGS"
|
|
Packit |
c22fc9 |
CPPFLAGS="$CPPFLAGS $JSON_HEADERS"
|
|
Packit |
c22fc9 |
AC_CHECK_HEADERS(json.h,,AC_MSG_ERROR([unable to find json.h]))
|
|
Packit |
c22fc9 |
CPPFLAGS="$SAV_CPPFLAGS"
|
|
Packit |
c22fc9 |
AC_DEFINE([_WITH_JSON_], [ 1 ], [Define to 1 to build with json output support])
|
|
Packit |
c22fc9 |
add_pkg_config([json-c])
|
|
Packit |
c22fc9 |
ENABLE_JSON=Yes
|
|
Packit |
c22fc9 |
add_config_opt([JSON])
|
|
Packit |
c22fc9 |
fi
|
|
Packit |
c22fc9 |
|
|
Packit |
c22fc9 |
dnl ----[ BFD support ? ]----
|
|
Packit |
c22fc9 |
if test "${enable_bfd}" = yes; then
|
|
Packit |
c22fc9 |
BFD_SUPPORT=Yes
|
|
Packit |
c22fc9 |
AC_DEFINE([_WITH_BFD_], [ 1 ], [Define to 1 if have BFD support])
|
|
Packit |
c22fc9 |
add_config_opt([BFD])
|
|
Packit |
c22fc9 |
fi
|
|
Packit |
c22fc9 |
fi
|
|
Packit |
c22fc9 |
AM_CONDITIONAL([WITH_VRRP], [test $VRRP_SUPPORT = Yes])
|
|
Packit |
c22fc9 |
AM_CONDITIONAL([VRRP_AUTH], [test $VRRP_AUTH_SUPPORT = Yes])
|
|
Packit |
c22fc9 |
AM_CONDITIONAL([VMAC], [test $MACVLAN_SUPPORT = Yes])
|
|
Packit |
c22fc9 |
AM_CONDITIONAL([WITH_JSON], [test $ENABLE_JSON = Yes])
|
|
Packit |
c22fc9 |
AM_CONDITIONAL([WITH_BFD], [test $BFD_SUPPORT = Yes])
|
|
Packit |
c22fc9 |
|
|
Packit |
c22fc9 |
if test ${IPVS_SUPPORT} = No -a ${VRRP_SUPPORT} = No; then
|
|
Packit |
c22fc9 |
AC_MSG_ERROR([keepalived MUST be compiled with at least one of LVS or VRRP framework])
|
|
Packit |
c22fc9 |
fi
|
|
Packit |
c22fc9 |
|
|
Packit |
c22fc9 |
dnl ----[ Checks for glibc SOCK_NONBLOCK support ]----
|
|
Packit |
c22fc9 |
# Introduced in Linux 2.6.27 and glibc 2.9
|
|
Packit |
c22fc9 |
AC_CHECK_DECLS([SOCK_NONBLOCK], [add_system_opt([SOCK_NONBLOCK])], [],[[#include <sys/socket.h>]])
|
|
Packit |
c22fc9 |
AM_CONDITIONAL([SOCK_NONBLOCK], [test $ac_cv_have_decl_SOCK_NONBLOCK = yes])
|
|
Packit |
c22fc9 |
|
|
Packit |
c22fc9 |
dnl ----[ Checks for glibc SOCK_CLOEXEC support ]----
|
|
Packit |
c22fc9 |
# Introduced in Linux 2.6.27 and glibc 2.9
|
|
Packit |
c22fc9 |
AC_CHECK_DECLS([SOCK_CLOEXEC], [add_system_opt([SOCK_CLOEXEC])], [],[[#include <sys/socket.h>]])
|
|
Packit |
c22fc9 |
|
|
Packit |
c22fc9 |
dnl ----[ Checks for pe support ]----
|
|
Packit |
c22fc9 |
# Introduced in Linux 2.6.37
|
|
Packit |
c22fc9 |
AC_CHECK_DECL([IPVS_SVC_ATTR_PE_NAME],
|
|
Packit |
c22fc9 |
[
|
|
Packit |
c22fc9 |
AC_DEFINE([_HAVE_PE_NAME_], [ 1 ], [Define to 1 if have pe selection support])
|
|
Packit |
c22fc9 |
],
|
|
Packit |
c22fc9 |
[], [[#include <linux/ip_vs.h>]])
|
|
Packit |
c22fc9 |
|
|
Packit |
c22fc9 |
dnl ----[ Checks for O_PATH support ]----
|
|
Packit |
c22fc9 |
# Introduced in Linux 2.6.39
|
|
Packit |
c22fc9 |
SAV_CFLAGS="$CFLAGS"
|
|
Packit |
c22fc9 |
CFLAGS="$CFLAGS -D_GNU_SOURCE"
|
|
Packit |
c22fc9 |
AC_CHECK_DECLS([O_PATH],
|
|
Packit |
c22fc9 |
[
|
|
Packit |
c22fc9 |
add_system_opt([O_PATH])
|
|
Packit |
c22fc9 |
], [],[[#include <fcntl.h>]])
|
|
Packit |
c22fc9 |
CFLAGS="$SAV_CFLAGS"
|
|
Packit |
c22fc9 |
|
|
Packit |
c22fc9 |
dnl ----[ Check for GLOB_BRACE support ]----
|
|
Packit |
c22fc9 |
AC_CHECK_DECLS([GLOB_BRACE], [add_system_opt([GLOB_BRACE])], [], [[#include <glob.h>]])
|
|
Packit |
c22fc9 |
|
|
Packit |
c22fc9 |
dnl ----[ Do we want v1.3.6 and earlier VRRPv3 unicast checksum compatibility support ]----
|
|
Packit |
c22fc9 |
UNICAST_CHKSUM_COMPAT_SUPPORT=No
|
|
Packit |
c22fc9 |
if test .$enable_checksum_compat != .no; then
|
|
Packit |
c22fc9 |
UNICAST_CHKSUM_COMPAT_SUPPORT=Yes
|
|
Packit |
c22fc9 |
AC_DEFINE([_WITH_UNICAST_CHKSUM_COMPAT_], [ 1 ], [Define to 1 to enable v1.3.6 and earlier VRRPv3 unicast checksum compatibility])
|
|
Packit |
c22fc9 |
add_config_opt([OLD_CHKSUM_COMPAT])
|
|
Packit |
c22fc9 |
fi
|
|
Packit |
c22fc9 |
|
|
Packit |
c22fc9 |
dnl ----[ Checks for FIB routing support ]----
|
|
Packit |
c22fc9 |
FIB_ROUTING_SUPPORT=No
|
|
Packit |
c22fc9 |
if test .$enable_vrrp != .no -a .$enable_routes != .no; then
|
|
Packit |
c22fc9 |
# Introduced in Linux 2.6.19
|
|
Packit |
c22fc9 |
SAV_CPPFLAGS="$CPPFLAGS"
|
|
Packit |
c22fc9 |
CPPFLAGS="$CPPFLAGS $kernelinc"
|
|
Packit |
c22fc9 |
AC_CHECK_DECL([FRA_SRC],
|
|
Packit |
c22fc9 |
[
|
|
Packit |
c22fc9 |
FIB_ROUTING_SUPPORT=Yes
|
|
Packit |
c22fc9 |
AC_DEFINE([_HAVE_FIB_ROUTING_], [ 1 ], [Define to 1 if have FIB routing support])
|
|
Packit |
c22fc9 |
add_config_opt([FIB_ROUTING])
|
|
Packit |
c22fc9 |
], [],
|
|
Packit |
c22fc9 |
[[#include <sys/socket.h>
|
|
Packit |
c22fc9 |
#include <linux/fib_rules.h>]])
|
|
Packit |
c22fc9 |
CPPFLAGS="$SAV_CPPFLAGS"
|
|
Packit |
c22fc9 |
fi
|
|
Packit |
c22fc9 |
AM_CONDITIONAL([FIB_ROUTING], [test $FIB_ROUTING_SUPPORT = Yes])
|
|
Packit |
c22fc9 |
|
|
Packit |
c22fc9 |
dnl ----[ Checks for kernel IFLA_INET6_ADDR_GEN_MODE support ]----
|
|
Packit |
c22fc9 |
SAV_CPPFLAGS="$CPPFLAGS"
|
|
Packit |
c22fc9 |
CPPFLAGS="$CPPFLAGS $kernelinc"
|
|
Packit |
c22fc9 |
if test ${MACVLAN_SUPPORT} = Yes; then
|
|
Packit |
c22fc9 |
# Introduced in Linux 3.17
|
|
Packit |
c22fc9 |
AC_CHECK_DECLS([IFLA_INET6_ADDR_GEN_MODE],
|
|
Packit |
c22fc9 |
[
|
|
Packit |
c22fc9 |
add_system_opt([INET6_ADDR_GEN_MODE])
|
|
Packit |
c22fc9 |
], [], [[
|
|
Packit |
c22fc9 |
#include <linux/if_link.h>
|
|
Packit |
c22fc9 |
]])
|
|
Packit |
c22fc9 |
fi
|
|
Packit |
c22fc9 |
CPPFLAGS="$SAV_CPPFLAGS"
|
|
Packit |
c22fc9 |
|
|
Packit |
c22fc9 |
dnl ----[ Checks for kernel IFLA_VRF_... support ]----
|
|
Packit |
c22fc9 |
SAV_CPPFLAGS="$CPPFLAGS"
|
|
Packit |
c22fc9 |
CPPFLAGS="$CPPFLAGS $kernelinc"
|
|
Packit |
c22fc9 |
if test ${MACVLAN_SUPPORT} = Yes; then
|
|
Packit |
c22fc9 |
# Introduced in Linux 4.3
|
|
Packit |
c22fc9 |
AC_CHECK_DECLS([IFLA_VRF_MAX],
|
|
Packit |
c22fc9 |
[
|
|
Packit |
c22fc9 |
add_system_opt([VRF])
|
|
Packit |
c22fc9 |
AC_DEFINE([_HAVE_VRF_], [ 1 ], [Define to 1 if have kernel VRF support])
|
|
Packit |
c22fc9 |
], [], [[
|
|
Packit |
c22fc9 |
#include <linux/if_link.h>
|
|
Packit |
c22fc9 |
]])
|
|
Packit |
c22fc9 |
fi
|
|
Packit |
c22fc9 |
CPPFLAGS="$SAV_CPPFLAGS"
|
|
Packit |
c22fc9 |
|
|
Packit |
c22fc9 |
dnl ----[ Checks for SNMP support ]----
|
|
Packit |
c22fc9 |
SNMP_SUPPORT=No
|
|
Packit |
c22fc9 |
SNMP_KEEPALIVED_SUPPORT=No
|
|
Packit |
c22fc9 |
SNMP_VRRP_SUPPORT=No
|
|
Packit |
c22fc9 |
SNMP_RFC_SUPPORT=No
|
|
Packit |
c22fc9 |
SNMP_RFCV2_SUPPORT=No
|
|
Packit |
c22fc9 |
SNMP_RFCV3_SUPPORT=No
|
|
Packit |
c22fc9 |
SNMP_CHECKER_SUPPORT=No
|
|
Packit |
c22fc9 |
SNMP_V3_FOR_V2=No
|
|
Packit |
c22fc9 |
if test "$enable_snmp_keepalived" = yes; then
|
|
Packit |
c22fc9 |
AC_MSG_WARN([--enable-snmp-keepalived is obsolete. Use --enable-snmp-vrrp.])
|
|
Packit |
c22fc9 |
enable_snmp_vrrp=$enable_snmp_keepalived
|
|
Packit |
c22fc9 |
fi
|
|
Packit |
c22fc9 |
if test "$enable_snmp" = yes -o \
|
|
Packit |
c22fc9 |
"$enable_snmp_vrrp" = yes -o \
|
|
Packit |
c22fc9 |
"$enable_snmp_checker" = yes -o \
|
|
Packit |
c22fc9 |
"$enable_snmp_rfc" = yes -o \
|
|
Packit |
c22fc9 |
"$enable_snmp_rfcv2" = yes -o \
|
|
Packit |
c22fc9 |
"$enable_snmp_rfcv3" = yes; then
|
|
Packit |
c22fc9 |
AC_PATH_TOOL([NETSNMP_CONFIG], [net-snmp-config], [no])
|
|
Packit |
c22fc9 |
if test "$NETSNMP_CONFIG" = no; then
|
|
Packit |
c22fc9 |
AC_MSG_ERROR([*** unable to find net-snmp-config])
|
|
Packit |
c22fc9 |
fi
|
|
Packit |
c22fc9 |
NETSNMP_LIBS_AGENT=`${NETSNMP_CONFIG} --netsnmp-agent-libs`
|
|
Packit |
c22fc9 |
NETSNMP_LIBS_EXT=`${NETSNMP_CONFIG} --external-libs`
|
|
Packit |
c22fc9 |
NETSNMP_LIBS="$NETSNMP_LIBS_AGENT $NETSNMP_LIBS_EXT"
|
|
Packit |
c22fc9 |
NETSNMP_CFLAGS="`${NETSNMP_CONFIG} --base-cflags` -DNETSNMP_NO_INLINE"
|
|
Packit |
c22fc9 |
|
|
Packit |
c22fc9 |
# net-snmp-config adds compiler and linker options that were set at the time
|
|
Packit |
c22fc9 |
# net-snmp was built, and this can include spec files that may not exist
|
|
Packit |
c22fc9 |
# on the system building keepalived. We need to check if any spec files
|
|
Packit |
c22fc9 |
# are specified, and if they do not exist on this system, then remove them
|
|
Packit |
c22fc9 |
# from NETSNMP_LIBS or NETSNMP_CFLAGS.
|
|
Packit |
c22fc9 |
# For further information, see https://bugzilla.redhat.com/show_bug.cgi?id=1544527
|
|
Packit |
c22fc9 |
# and the other bugs referred to in it.
|
|
Packit |
c22fc9 |
for spec in `echo $NETSNMP_LIBS | sed -e "s? ?\n?g" | grep "^-specs="`; do
|
|
Packit |
c22fc9 |
SPEC_FILE=`echo $spec | sed -e "s?^-spaces=??"`
|
|
Packit |
c22fc9 |
if test ! -f $SPEC_FILE; then
|
|
Packit |
c22fc9 |
NETSNMP_LIBS=`echo $NETSNMP_LIBS | sed -e "s? *$spec *? ?"`
|
|
Packit |
c22fc9 |
AC_MSG_WARN([Removing $spec from NETSNMP_LIBS since spec file not installed])
|
|
Packit |
c22fc9 |
fi
|
|
Packit |
c22fc9 |
done
|
|
Packit |
c22fc9 |
for spec in `echo $NETSNMP_CFLAGS | sed -e "s? ?\n?g" | grep "^-specs="`; do
|
|
Packit |
c22fc9 |
SPEC_FILE=`echo $spec | sed -e "s?^-spaces=??"`
|
|
Packit |
c22fc9 |
if test ! -f $SPEC_FILE; then
|
|
Packit |
c22fc9 |
NETSNMP_CFLAGS=`echo $NETSNMP_CFLAGS | sed -e "s? *$spec *? ?"`
|
|
Packit |
c22fc9 |
AC_MSG_WARN([Removing $spec from NETSNMP_CFLAGS since spec file not installed])
|
|
Packit |
c22fc9 |
fi
|
|
Packit |
c22fc9 |
done
|
|
Packit |
c22fc9 |
|
|
Packit |
c22fc9 |
SAV_CFLAGS="$CFLAGS"
|
|
Packit |
c22fc9 |
CFLAGS="$CFLAGS ${NETSNMP_CFLAGS}"
|
|
Packit |
c22fc9 |
SAV_LIBS="$LIBS"
|
|
Packit |
c22fc9 |
LIBS="$LIBS ${NETSNMP_LIBS}"
|
|
Packit |
c22fc9 |
AC_MSG_CHECKING([whether C compiler supports flag "${NETSNMP_CFLAGS} ${NETSNMP_LIBS}" from Net-SNMP])
|
|
Packit |
c22fc9 |
AC_LINK_IFELSE([AC_LANG_SOURCE([[
|
|
Packit |
c22fc9 |
int main(void)
|
|
Packit |
c22fc9 |
{
|
|
Packit |
c22fc9 |
return 0;
|
|
Packit |
c22fc9 |
}
|
|
Packit |
c22fc9 |
]])], [
|
|
Packit |
c22fc9 |
AC_MSG_RESULT(yes)
|
|
Packit |
c22fc9 |
],[
|
|
Packit |
c22fc9 |
AC_MSG_RESULT(no)
|
|
Packit |
c22fc9 |
AC_MSG_ERROR([*** incorrect CFLAGS from net-snmp-config])
|
|
Packit |
c22fc9 |
])
|
|
Packit |
c22fc9 |
|
|
Packit |
c22fc9 |
# Do we have subagent support?
|
|
Packit |
c22fc9 |
AC_CHECK_FUNCS([netsnmp_enable_subagent], [],
|
|
Packit |
c22fc9 |
[AC_MSG_ERROR([*** no subagent support in net-snmp])])
|
|
Packit |
c22fc9 |
|
|
Packit |
c22fc9 |
# check for net-snmp headers
|
|
Packit |
c22fc9 |
# Some ancient distributions may miss <net-snmp/agent/util_funcs.h> header
|
|
Packit |
c22fc9 |
SAV_CPPFLAGS="$CPPFLAGS"
|
|
Packit |
c22fc9 |
CPPFLAGS="$CPPFLAGS $NETSNMP_CFLAGS"
|
|
Packit |
c22fc9 |
AC_CHECK_HEADERS(net-snmp/agent/agent_sysORTable.h net-snmp/agent/snmp_vars.h net-snmp/agent/util_funcs.h,[],
|
|
Packit |
c22fc9 |
[AC_MSG_ERROR([missing net-snmp headers])],[[
|
|
Packit |
c22fc9 |
#include <net-snmp/net-snmp-config.h>
|
|
Packit |
c22fc9 |
#include <net-snmp/net-snmp-includes.h>
|
|
Packit |
c22fc9 |
#include <net-snmp/agent/net-snmp-agent-includes.h>
|
|
Packit |
c22fc9 |
]])
|
|
Packit |
c22fc9 |
|
|
Packit |
c22fc9 |
SNMP_SUPPORT=Yes
|
|
Packit |
c22fc9 |
add_to_var([KA_CFLAGS], [$NETSNMP_CFLAGS])
|
|
Packit |
c22fc9 |
add_to_var([KA_LIBS], [$NETSNMP_LIBS])
|
|
Packit |
c22fc9 |
if test "$enable_snmp_rfc" = yes; then
|
|
Packit |
c22fc9 |
SNMP_RFCV2_SUPPORT=Yes
|
|
Packit |
c22fc9 |
SNMP_RFCV3_SUPPORT=Yes
|
|
Packit |
c22fc9 |
else
|
|
Packit |
c22fc9 |
if test "$enable_snmp_rfcv2" = yes; then
|
|
Packit |
c22fc9 |
SNMP_RFCV2_SUPPORT=Yes
|
|
Packit |
c22fc9 |
fi
|
|
Packit |
c22fc9 |
if test "$enable_snmp_rfcv3" = yes; then
|
|
Packit |
c22fc9 |
SNMP_RFCV3_SUPPORT=Yes
|
|
Packit |
c22fc9 |
fi
|
|
Packit |
c22fc9 |
fi
|
|
Packit |
c22fc9 |
if test ${SNMP_RFCV2_SUPPORT} = Yes -o \
|
|
Packit |
c22fc9 |
${SNMP_RFCV3_SUPPORT} = Yes; then
|
|
Packit |
c22fc9 |
if test ${VRRP_SUPPORT} != Yes; then
|
|
Packit |
c22fc9 |
AC_MSG_ERROR([RFC SNMP support requires VRRP])
|
|
Packit |
c22fc9 |
fi
|
|
Packit |
c22fc9 |
SNMP_RFC_SUPPORT=Yes
|
|
Packit |
c22fc9 |
fi
|
|
Packit |
c22fc9 |
if test ${SNMP_RFCV3_SUPPORT} = Yes -a \
|
|
Packit |
c22fc9 |
"$enable_snmp_reply_v3_for_v2" != no; then
|
|
Packit |
c22fc9 |
AC_DEFINE([_SNMP_REPLY_V3_FOR_V2_], [ 1 ], [Define to 1 to have keepalived send RFC6257 SNMP responses for VRRPv2 instances])
|
|
Packit |
c22fc9 |
SNMP_V3_FOR_V2=Yes
|
|
Packit |
c22fc9 |
add_config_opt([SNMP_V3_FOR_V2])
|
|
Packit |
c22fc9 |
fi
|
|
Packit |
c22fc9 |
|
|
Packit |
c22fc9 |
if test "$enable_snmp" = yes; then
|
|
Packit |
c22fc9 |
SNMP_VRRP_SUPPORT=Yes
|
|
Packit |
c22fc9 |
SNMP_CHECKER_SUPPORT=Yes
|
|
Packit |
c22fc9 |
else
|
|
Packit |
c22fc9 |
if test "$enable_snmp_vrrp" = yes; then
|
|
Packit |
c22fc9 |
SNMP_VRRP_SUPPORT=Yes
|
|
Packit |
c22fc9 |
fi
|
|
Packit |
c22fc9 |
if test "$enable_snmp_checker" = yes; then
|
|
Packit |
c22fc9 |
SNMP_CHECKER_SUPPORT=Yes
|
|
Packit |
c22fc9 |
fi
|
|
Packit |
c22fc9 |
fi
|
|
Packit |
c22fc9 |
if test ${VRRP_SUPPORT} != Yes -a \
|
|
Packit |
c22fc9 |
${SNMP_VRRP_SUPPORT} = Yes; then
|
|
Packit |
c22fc9 |
AC_MSG_ERROR([VRRP SNMP support requires VRRP])
|
|
Packit |
c22fc9 |
fi
|
|
Packit |
c22fc9 |
if test ${IPVS_SUPPORT} = No -a \
|
|
Packit |
c22fc9 |
${SNMP_CHECKER_SUPPORT} = Yes; then
|
|
Packit |
c22fc9 |
AC_MSG_ERROR([CHECKER SNMP support requires checker])
|
|
Packit |
c22fc9 |
fi
|
|
Packit |
c22fc9 |
|
|
Packit |
c22fc9 |
if test ${SNMP_VRRP_SUPPORT} = Yes -o \
|
|
Packit |
c22fc9 |
${SNMP_CHECKER_SUPPORT} = Yes; then
|
|
Packit |
c22fc9 |
SNMP_KEEPALIVED_SUPPORT=Yes
|
|
Packit |
c22fc9 |
fi
|
|
Packit |
c22fc9 |
|
|
Packit |
c22fc9 |
CPPFLAGS="$SAV_CPPFLAGS"
|
|
Packit |
c22fc9 |
CPPFLAGS="$SAV_CPPFLAGS"
|
|
Packit |
c22fc9 |
CFLAGS="$SAV_CFLAGS"
|
|
Packit |
c22fc9 |
LIBS="$SAV_LIBS"
|
|
Packit |
c22fc9 |
fi
|
|
Packit |
c22fc9 |
|
|
Packit |
c22fc9 |
dnl ----[What SNMP support is required]----
|
|
Packit |
c22fc9 |
if test $SNMP_SUPPORT = Yes; then
|
|
Packit |
c22fc9 |
AC_DEFINE([_WITH_SNMP_], [ 1 ], [Define to 1 to have SNMP support])
|
|
Packit |
c22fc9 |
fi
|
|
Packit |
c22fc9 |
if test $SNMP_KEEPALIVED_SUPPORT = Yes; then
|
|
Packit |
c22fc9 |
AC_DEFINE([_WITH_SNMP_KEEPALIVED_], [ 1 ], [Define to 1 to have keepalived SNMP support])
|
|
Packit |
c22fc9 |
fi
|
|
Packit |
c22fc9 |
if test $SNMP_VRRP_SUPPORT = Yes; then
|
|
Packit |
c22fc9 |
AC_DEFINE([_WITH_SNMP_VRRP_], [ 1 ], [Define to 1 to have keepalived SNMP VRRP support])
|
|
Packit |
c22fc9 |
add_config_opt([SNMP_VRRP])
|
|
Packit |
c22fc9 |
fi
|
|
Packit |
c22fc9 |
if test $SNMP_CHECKER_SUPPORT = Yes; then
|
|
Packit |
c22fc9 |
AC_DEFINE([_WITH_SNMP_CHECKER_], [ 1 ], [Define to 1 to have keepalived SNMP checker support])
|
|
Packit |
c22fc9 |
add_config_opt([SNMP_CHECKER])
|
|
Packit |
c22fc9 |
fi
|
|
Packit |
c22fc9 |
if test $SNMP_RFC_SUPPORT = Yes; then
|
|
Packit |
c22fc9 |
AC_DEFINE([_WITH_SNMP_RFC_], [ 1 ], [Define to 1 to have RFC SNMP support])
|
|
Packit |
c22fc9 |
fi
|
|
Packit |
c22fc9 |
if test $SNMP_RFCV2_SUPPORT = Yes; then
|
|
Packit |
c22fc9 |
AC_DEFINE([_WITH_SNMP_RFCV2_], [ 1 ], [Define to 1 to have RFCv2 SNMP support])
|
|
Packit |
c22fc9 |
add_config_opt([SNMP_RFCV2])
|
|
Packit |
c22fc9 |
fi
|
|
Packit |
c22fc9 |
if test $SNMP_RFCV3_SUPPORT = Yes; then
|
|
Packit |
c22fc9 |
AC_DEFINE([_WITH_SNMP_RFCV3_], [ 1 ], [Define to 1 to have RFCv3 SNMP support])
|
|
Packit |
c22fc9 |
add_config_opt([SNMP_RFCV3])
|
|
Packit |
c22fc9 |
fi
|
|
Packit |
c22fc9 |
AM_CONDITIONAL([SNMP], [test $SNMP_SUPPORT = Yes])
|
|
Packit |
c22fc9 |
AM_CONDITIONAL([SNMP_KEEPALIVED], [test $SNMP_KEEPALIVED_SUPPORT = Yes])
|
|
Packit |
c22fc9 |
AM_CONDITIONAL([SNMP_VRRP], [test $SNMP_VRRP_SUPPORT = Yes -o $SNMP_RFC_SUPPORT = Yes])
|
|
Packit |
c22fc9 |
AM_CONDITIONAL([SNMP_CHECKER], [test $SNMP_CHECKER_SUPPORT = Yes])
|
|
Packit |
c22fc9 |
AM_CONDITIONAL([SNMP_RFC], [test $SNMP_RFCV2_SUPPORT = Yes -o $SNMP_RFCV3_SUPPORT = Yes])
|
|
Packit |
c22fc9 |
AM_CONDITIONAL([SNMP_RFCV2], [test $SNMP_RFCV2_SUPPORT = Yes])
|
|
Packit |
c22fc9 |
AM_CONDITIONAL([SNMP_RFCV3], [test $SNMP_RFCV3_SUPPORT = Yes])
|
|
Packit |
c22fc9 |
AM_CONDITIONAL([SNMP_REPLY_V3_FOR_V2], [test $SNMP_V3_FOR_V2 = Yes])
|
|
Packit |
c22fc9 |
|
|
Packit |
c22fc9 |
dnl ----[ Check for Dbus support ]----
|
|
Packit |
c22fc9 |
DBUS_SUPPORT=No
|
|
Packit |
c22fc9 |
DBUS_CREATE_INSTANCE=No
|
|
Packit |
c22fc9 |
if test "$enable_dbus" = yes; then
|
|
Packit |
c22fc9 |
AC_CHECK_LIB(gio-2.0, g_bus_own_name,
|
|
Packit |
c22fc9 |
[
|
|
Packit |
c22fc9 |
add_pkg_config([gio-2.0])
|
|
Packit |
c22fc9 |
DBUS_SUPPORT=Yes
|
|
Packit |
c22fc9 |
AC_DEFINE([_WITH_DBUS_], [ 1 ], [Define to 1 to have DBUS support])
|
|
Packit |
c22fc9 |
add_config_opt([DBUS])
|
|
Packit |
c22fc9 |
|
|
Packit |
c22fc9 |
dnl -- g_type_init() not needed and deprecated since glib 2.36
|
|
Packit |
c22fc9 |
CFLAGS="$($PKG_CONFIG --cflags gio-2.0)"
|
|
Packit |
c22fc9 |
LIBS="$($PKG_CONFIG --libs gio-2.0)"
|
|
Packit |
c22fc9 |
AC_RUN_IFELSE(
|
|
Packit |
c22fc9 |
[
|
|
Packit |
c22fc9 |
AC_LANG_PROGRAM(
|
|
Packit |
c22fc9 |
[[#include <gio/gio.h>]],
|
|
Packit |
c22fc9 |
[[return !g_thread_functions_for_glib_use.mutex_lock;]])],
|
|
Packit |
c22fc9 |
[need_g_type_init=0],
|
|
Packit |
c22fc9 |
[need_g_type_init=1],
|
|
Packit |
c22fc9 |
[
|
|
Packit |
c22fc9 |
AC_MSG_WARN([Cannot determine if need to call g_type_init(). Assuming yes for safety.])
|
|
Packit |
c22fc9 |
need_g_type_init=1
|
|
Packit |
c22fc9 |
])
|
|
Packit |
c22fc9 |
if test $need_g_type_init -eq 1; then
|
|
Packit |
c22fc9 |
AC_DEFINE([DBUS_NEED_G_TYPE_INIT], [ 1 ], [Define to 1 if need to call g_type_init()])
|
|
Packit |
c22fc9 |
fi
|
|
Packit |
c22fc9 |
LIBS=
|
|
Packit |
c22fc9 |
CFLAGS=
|
|
Packit |
c22fc9 |
if test "$enable_dbus_create_instance" = yes; then
|
|
Packit |
c22fc9 |
AC_DEFINE([_WITH_DBUS_CREATE_INSTANCE_], [ 1 ], [Define to 1 to have DBus create instance support])
|
|
Packit |
c22fc9 |
DBUS_CREATE_INSTANCE=Yes
|
|
Packit |
c22fc9 |
add_config_opt([DBUS_CREATE_INSTANCE])
|
|
Packit |
c22fc9 |
AC_MSG_WARN([DBus create instance functionality is dangerous - why do you want it?])
|
|
Packit |
c22fc9 |
fi
|
|
Packit |
c22fc9 |
],
|
|
Packit |
c22fc9 |
[AC_MSG_ERROR([DBUS support requested but libgio-2.0 not found.])])
|
|
Packit |
c22fc9 |
fi
|
|
Packit |
c22fc9 |
AM_CONDITIONAL([WITH_DBUS], [test $DBUS_SUPPORT = Yes])
|
|
Packit |
c22fc9 |
AM_CONDITIONAL([DBUS_CREATE_INSTANCE], [test $DBUS_CREATE_INSTANCE = Yes])
|
|
Packit |
c22fc9 |
|
|
Packit |
c22fc9 |
dnl ----[ SHA1 or not ? ]----
|
|
Packit |
c22fc9 |
SHA1_SUPPORT=No
|
|
Packit |
c22fc9 |
if test "${enable_sha1}" = yes; then
|
|
Packit |
c22fc9 |
AC_CHECK_HEADERS(openssl/sha.h,,AC_MSG_ERROR([unable to find openssl/sha.h]))
|
|
Packit |
c22fc9 |
AC_CHECK_LIB(crypto, SHA1_Init,,
|
|
Packit |
c22fc9 |
[
|
|
Packit |
c22fc9 |
dnl libcrypto can require -fpic
|
|
Packit |
c22fc9 |
AS_UNSET([ac_cv_lib_crypto_SHA1_Init])
|
|
Packit |
c22fc9 |
SAV_CFLAGS=$CFLAGS
|
|
Packit |
c22fc9 |
CFLAGS=-fpic
|
|
Packit |
c22fc9 |
AC_CHECK_LIB(crypto, SHA1_Init,,AC_MSG_ERROR([SHA1 in OpenSSL required]))
|
|
Packit |
c22fc9 |
CFLAGS=$SAV_CFLAGS
|
|
Packit |
c22fc9 |
add_to_var([KA_CFLAGS],[-fpic])
|
|
Packit |
c22fc9 |
])
|
|
Packit |
c22fc9 |
SHA1_SUPPORT=Yes
|
|
Packit |
c22fc9 |
AC_DEFINE([_WITH_SHA1_], [ 1 ], [Define to 1 to have SHA1 support])
|
|
Packit |
c22fc9 |
fi
|
|
Packit |
c22fc9 |
AM_CONDITIONAL([WITH_SHA1], [test $SHA1_SUPPORT = Yes])
|
|
Packit |
c22fc9 |
|
|
Packit |
c22fc9 |
dnl ----[ check for SO_MARK support ]----
|
|
Packit |
c22fc9 |
SO_MARK_SUPPORT=No
|
|
Packit |
c22fc9 |
if test "${enable_fwmark}" != no; then
|
|
Packit |
c22fc9 |
AC_CHECK_DECLS([SO_MARK],
|
|
Packit |
c22fc9 |
[
|
|
Packit |
c22fc9 |
SO_MARK_SUPPORT=Yes
|
|
Packit |
c22fc9 |
AC_DEFINE([_WITH_SO_MARK_], [ 1 ], [Define to 1 if have SO_MARK])
|
|
Packit |
c22fc9 |
add_system_opt([SO_MARK])
|
|
Packit |
c22fc9 |
], [],
|
|
Packit |
c22fc9 |
[[#include <sys/socket.h>]])
|
|
Packit |
c22fc9 |
fi
|
|
Packit |
c22fc9 |
|
|
Packit |
c22fc9 |
dnl ---[ check for setns() ]----
|
|
Packit |
c22fc9 |
dnl -- CLONE_NEWNET defined from Linux 3.0
|
|
Packit |
c22fc9 |
SAV_CFLAGS="$CFLAGS"
|
|
Packit |
c22fc9 |
CFLAGS="$CFLAGS -D_GNU_SOURCE"
|
|
Packit |
c22fc9 |
AC_CHECK_DECLS([CLONE_NEWNET], [], [], [[#include <sched.h>]])
|
|
Packit |
c22fc9 |
dnl -- From glibc 2.14. Otherwise use setns syscall, since Linux 2.4.x
|
|
Packit |
c22fc9 |
AC_CHECK_FUNCS([setns])
|
|
Packit |
c22fc9 |
CFLAGS="$SAV_CFLAGS"
|
|
Packit |
c22fc9 |
AM_CONDITIONAL([WITH_NAMESPACES], [test $ac_cv_have_decl_CLONE_NEWNET = yes])
|
|
Packit |
c22fc9 |
|
|
Packit |
c22fc9 |
dnl ----[ check for realtime scheduling support ]----
|
|
Packit |
c22fc9 |
SAV_CFLAGS="$CFLAGS"
|
|
Packit |
c22fc9 |
CFLAGS="$CFLAGS -D_GNU_SOURCE"
|
|
Packit |
c22fc9 |
dnl -- from Linux ?.?.?
|
|
Packit |
c22fc9 |
AC_CHECK_DECLS([SCHED_RR],
|
|
Packit |
c22fc9 |
[
|
|
Packit |
c22fc9 |
SCHED_RT_SUPPORT=Yes
|
|
Packit |
c22fc9 |
AC_DEFINE([_HAVE_SCHED_RT_], [ 1 ], [Define to 1 if have SCHED_RR])
|
|
Packit |
c22fc9 |
add_system_opt([SCHED_RT])
|
|
Packit |
c22fc9 |
|
|
Packit |
c22fc9 |
dnl -- RLIMIT_RTTIME since Linux 2.6.25 - not supported wwith musl libc
|
|
Packit |
c22fc9 |
AC_CHECK_DECLS([RLIMIT_RTTIME], [], [], [[#include <sys/resource.h>]])
|
|
Packit |
c22fc9 |
|
|
Packit |
c22fc9 |
dnl -- SCHED_RESET_ON_FORK since Linux 2.6.32
|
|
Packit |
c22fc9 |
AC_CHECK_DECLS([SCHED_RESET_ON_FORK],
|
|
Packit |
c22fc9 |
[add_system_opt([SCHED_RESET_ON_FORK])],
|
|
Packit |
c22fc9 |
[AC_DEFINE([SCHED_RESET_ON_FORK], [ 0 ], [Dummy definition if not defined in system headers])],
|
|
Packit |
c22fc9 |
[[#include <sched.h>]])
|
|
Packit |
c22fc9 |
],
|
|
Packit |
c22fc9 |
[
|
|
Packit |
c22fc9 |
SCHED_RT_SUPPORT=No
|
|
Packit |
c22fc9 |
], [[#include <sched.h>]])
|
|
Packit |
c22fc9 |
CFLAGS="$SAV_CFLAGS"
|
|
Packit |
c22fc9 |
|
|
Packit |
c22fc9 |
dnl -- Do we want GNU standard paths (moves .pid files)
|
|
Packit |
c22fc9 |
GNU_STD_PATHS=No
|
|
Packit |
c22fc9 |
if test "${enable_gnu_std_paths}" = "yes"; then
|
|
Packit |
c22fc9 |
AC_DEFINE([GNU_STD_PATHS], [ 1 ], [set to enforce GNU standard paths, for .pid files etc])
|
|
Packit |
c22fc9 |
PID_DIR=$localstatedir
|
|
Packit |
c22fc9 |
else
|
|
Packit |
c22fc9 |
PID_DIR=/var
|
|
Packit |
c22fc9 |
fi
|
|
Packit |
c22fc9 |
AC_SUBST([PID_DIR])
|
|
Packit |
c22fc9 |
|
|
Packit |
c22fc9 |
dnl ---[ check for sphinx-build executable ]----
|
|
Packit |
c22fc9 |
if test -z "$SPHINXBUILD"; then
|
|
Packit |
c22fc9 |
SPHINXBUILDNAME=sphinx-build
|
|
Packit |
c22fc9 |
else
|
|
Packit |
c22fc9 |
SPHINXBUILDNAME=${SPHINXBUILD}
|
|
Packit |
c22fc9 |
fi
|
|
Packit |
c22fc9 |
AC_SUBST(SPHINXBUILDNAME)
|
|
Packit |
c22fc9 |
AC_CHECK_PROG([HAVE_SPHINX_BUILD], [$SPHINXBUILDNAME], [Yes], [No])
|
|
Packit |
c22fc9 |
AM_CONDITIONAL([BUILD_DOCS], [test $HAVE_SPHINX_BUILD = Yes])
|
|
Packit |
c22fc9 |
|
|
Packit |
c22fc9 |
dnl ----[ Memory alloc check or not ? ]----
|
|
Packit |
c22fc9 |
MEM_CHECK=No
|
|
Packit |
c22fc9 |
MEM_CHECK_LOG=No
|
|
Packit |
c22fc9 |
if test "${enable_mem_check}" = "yes"; then
|
|
Packit |
c22fc9 |
MEM_CHECK=Yes
|
|
Packit |
c22fc9 |
AC_DEFINE([_MEM_CHECK_], [ 1 ], [Define to 1 to build with malloc/free checks])
|
|
Packit |
c22fc9 |
add_config_opt([MEM_CHECK])
|
|
Packit |
c22fc9 |
if test "${enable_mem_check_log}" = "yes"; then
|
|
Packit |
c22fc9 |
MEM_CHECK_LOG=Yes
|
|
Packit |
c22fc9 |
AC_DEFINE([_MEM_CHECK_LOG_], [ 1 ], [Define to 1 to log malloc/free checks to syslog])
|
|
Packit |
c22fc9 |
add_config_opt([MEM_CHECK_LOG])
|
|
Packit |
c22fc9 |
fi
|
|
Packit |
c22fc9 |
fi
|
|
Packit |
c22fc9 |
|
|
Packit |
c22fc9 |
dnl ----[ Memory alloc check or not ? ]----
|
|
Packit |
c22fc9 |
TIMER_CHECK=No
|
|
Packit |
c22fc9 |
if test "${enable_timer_check}" = "yes"; then
|
|
Packit |
c22fc9 |
TIMER_CHECK=Yes
|
|
Packit |
c22fc9 |
AC_DEFINE([_TIMER_CHECK_], [ 1 ], [Define to 1 to build with set time logging])
|
|
Packit |
c22fc9 |
add_config_opt([TIMER_CHECK])
|
|
Packit |
c22fc9 |
fi
|
|
Packit |
c22fc9 |
|
|
Packit |
c22fc9 |
dnl ----[ Debug or not ? ]----
|
|
Packit |
c22fc9 |
if test "${enable_debug}" = yes; then
|
|
Packit |
c22fc9 |
AC_DEFINE([_DEBUG_], [ 1 ], [Define to 1 to build with debugging support])
|
|
Packit |
c22fc9 |
ENABLE_DEBUG=Yes
|
|
Packit |
c22fc9 |
add_config_opt([DEBUG])
|
|
Packit |
c22fc9 |
else
|
|
Packit |
c22fc9 |
ENABLE_DEBUG=No
|
|
Packit |
c22fc9 |
fi
|
|
Packit |
c22fc9 |
AM_CONDITIONAL([DEBUG], [test $ENABLE_DEBUG = Yes])
|
|
Packit |
c22fc9 |
|
|
Packit |
c22fc9 |
dnl ----[ Netlink command timers or not ? ]----
|
|
Packit |
c22fc9 |
if test "${enable_netlink_timers}" = yes; then
|
|
Packit |
c22fc9 |
AC_DEFINE([_NETLINK_TIMERS_], [ 1 ], [Define to 1 to build with netlink command timers support])
|
|
Packit |
c22fc9 |
ENABLE_NETLINK_TIMERS=Yes
|
|
Packit |
c22fc9 |
add_config_opt([NETLINK_TIMERS])
|
|
Packit |
c22fc9 |
else
|
|
Packit |
c22fc9 |
ENABLE_NETLINK_TIMERS=No
|
|
Packit |
c22fc9 |
fi
|
|
Packit |
c22fc9 |
|
|
Packit |
c22fc9 |
dnl ----[ smtp-alert debugging or not ? ]----
|
|
Packit |
c22fc9 |
if test "${enable_smtp_alert_debug}" = yes; then
|
|
Packit |
c22fc9 |
AC_DEFINE([_SMTP_ALERT_DEBUG_], [ 1 ], [Define to 1 to build with smtp-alert debugging support])
|
|
Packit |
c22fc9 |
ENABLE_SMTP_ALERT_DEBUG=Yes
|
|
Packit |
c22fc9 |
add_config_opt([SMTP_ALERT_DEBUG])
|
|
Packit |
c22fc9 |
ENABLE_LOG_FILE_APPEND=Yes
|
|
Packit |
c22fc9 |
else
|
|
Packit |
c22fc9 |
ENABLE_SMTP_ALERT_DEBUG=No
|
|
Packit |
c22fc9 |
fi
|
|
Packit |
c22fc9 |
|
|
Packit |
c22fc9 |
dnl ----[ Stacktrace support or not ? ]----
|
|
Packit |
c22fc9 |
if test "${enable_stacktrace}" = yes; then
|
|
Packit |
c22fc9 |
AC_DEFINE([_WITH_STACKTRACE_], [ 1 ], [Define to 1 to build with stacktrace support])
|
|
Packit |
c22fc9 |
ENABLE_STACKTRACE=Yes
|
|
Packit |
c22fc9 |
add_config_opt([STACKTRACE])
|
|
Packit |
c22fc9 |
add_to_var([KA_LDFLAGS], [-rdynamic])
|
|
Packit |
c22fc9 |
else
|
|
Packit |
c22fc9 |
ENABLE_STACKTRACE=No
|
|
Packit |
c22fc9 |
fi
|
|
Packit |
c22fc9 |
|
|
Packit |
c22fc9 |
dnl ----[ Thread dumping support or not ? ]----
|
|
Packit |
c22fc9 |
if test "${enable_dump_threads}" = yes; then
|
|
Packit |
c22fc9 |
AC_DEFINE([_WITH_DUMP_THREADS_], [ 1 ], [Define to 1 to build with thread dumping support])
|
|
Packit |
c22fc9 |
ENABLE_DUMP_THREADS=Yes
|
|
Packit |
c22fc9 |
add_config_opt([DUMP_THREADS])
|
|
Packit |
c22fc9 |
else
|
|
Packit |
c22fc9 |
ENABLE_DUMP_THREADS=No
|
|
Packit |
c22fc9 |
fi
|
|
Packit |
c22fc9 |
|
|
Packit |
c22fc9 |
dnl ----[ epoll() debugging support or not ? ]----
|
|
Packit |
c22fc9 |
if test "${enable_epoll_debug}" = yes; then
|
|
Packit |
c22fc9 |
AC_DEFINE([_EPOLL_DEBUG_], [ 1 ], [Define to 1 to build with epoll_wait() debugging support])
|
|
Packit |
c22fc9 |
ENABLE_EPOLL_DEBUG=Yes
|
|
Packit |
c22fc9 |
add_config_opt([EPOLL_DEBUG])
|
|
Packit |
c22fc9 |
else
|
|
Packit |
c22fc9 |
ENABLE_EPOLL_DEBUG=No
|
|
Packit |
c22fc9 |
fi
|
|
Packit |
c22fc9 |
|
|
Packit |
c22fc9 |
dnl ----[ epoll() thread dumping support or not ? ]----
|
|
Packit |
c22fc9 |
if test "${enable_epoll_thread_dump}" = yes; then
|
|
Packit |
c22fc9 |
AC_DEFINE([_EPOLL_THREAD_DUMP_], [ 1 ], [Define to 1 to build with epoll thread dumping support])
|
|
Packit |
c22fc9 |
ENABLE_EPOLL_THREAD_DUMP=Yes
|
|
Packit |
c22fc9 |
add_config_opt([EPOLL_THREAD_DUMP])
|
|
Packit |
c22fc9 |
else
|
|
Packit |
c22fc9 |
ENABLE_EPOLL_THREAD_DUMP=No
|
|
Packit |
c22fc9 |
fi
|
|
Packit |
c22fc9 |
|
|
Packit |
c22fc9 |
if test $ENABLE_EPOLL_THREAD_DUMP = Yes -o $ENABLE_DUMP_THREADS = Yes -o $ENABLE_EPOLL_DEBUG = Yes; then
|
|
Packit |
c22fc9 |
AC_DEFINE([THREAD_DUMP], [ 1 ], [Define to 1 to build with thread dumping support])
|
|
Packit |
c22fc9 |
fi
|
|
Packit |
c22fc9 |
|
|
Packit |
c22fc9 |
dnl ----[ TSM debugging support or not ? ]----
|
|
Packit |
c22fc9 |
if test "${enable_tsm_debug}" = yes; then
|
|
Packit |
c22fc9 |
AC_DEFINE([_TSM_DEBUG_], [ 1 ], [Define to 1 to build with TSM debugging support])
|
|
Packit |
c22fc9 |
ENABLE_TSM_DEBUG=Yes
|
|
Packit |
c22fc9 |
add_config_opt([TSM_DEBUG])
|
|
Packit |
c22fc9 |
else
|
|
Packit |
c22fc9 |
ENABLE_TSM_DEBUG=No
|
|
Packit |
c22fc9 |
fi
|
|
Packit |
c22fc9 |
|
|
Packit |
c22fc9 |
dnl ----[ VRRP FD debugging support or not ? ]----
|
|
Packit |
c22fc9 |
if test "${enable_vrrp_fd_debug}" = yes; then
|
|
Packit |
c22fc9 |
AC_DEFINE([_VRRP_FD_DEBUG_], [ 1 ], [Define to 1 to build with vrrp fd debugging support])
|
|
Packit |
c22fc9 |
ENABLE_VRRP_FD_DEBUG=Yes
|
|
Packit |
c22fc9 |
add_config_opt([VRRP_FD_DEBUG])
|
|
Packit |
c22fc9 |
else
|
|
Packit |
c22fc9 |
ENABLE_VRRP_FD_DEBUG=No
|
|
Packit |
c22fc9 |
fi
|
|
Packit |
c22fc9 |
|
|
Packit |
c22fc9 |
dnl ----[ Specify interface type to be unchangeable ]----
|
|
Packit |
c22fc9 |
if test "${with_fixed_if_type}"; then
|
|
Packit |
c22fc9 |
if test "${with_fixed_if_type}" = yes -o ${with_fixed_if_type} = no; then
|
|
Packit |
c22fc9 |
AC_MSG_ERROR([An interface type must be specified with --with-fixed-if-type])
|
|
Packit |
c22fc9 |
fi
|
|
Packit |
c22fc9 |
AC_DEFINE_UNQUOTED([_FIXED_IF_TYPE_], [ "${with_fixed_if_type}" ], [Consider ${with_fixed_if_type} interfaces to be unchangeable])
|
|
Packit |
c22fc9 |
FIXED_IF_TYPE=${with_fixed_if_type}
|
|
Packit |
c22fc9 |
add_config_opt([FIXED_IF_TYPE=${with_fixed_if_type}])
|
|
Packit |
c22fc9 |
else
|
|
Packit |
c22fc9 |
FIXED_IF_TYPE=
|
|
Packit |
c22fc9 |
fi
|
|
Packit |
c22fc9 |
|
|
Packit |
c22fc9 |
dnl ----[ Profiling or not ? ]----
|
|
Packit |
c22fc9 |
WITH_PROFILING=No
|
|
Packit |
c22fc9 |
if test "${enable_profile}" = yes; then
|
|
Packit |
c22fc9 |
WITH_PROFILING=Yes
|
|
Packit |
c22fc9 |
add_config_opt([PROFILING])
|
|
Packit |
c22fc9 |
add_to_var([KA_CFLAGS], [-pg])
|
|
Packit |
c22fc9 |
fi
|
|
Packit |
c22fc9 |
AM_CONDITIONAL([PROFILE], [test $WITH_PROFILING = Yes])
|
|
Packit |
c22fc9 |
|
|
Packit |
c22fc9 |
dnl ----[ perf support or not? keepalived provides runtime options ]----
|
|
Packit |
c22fc9 |
if test "${enable_perf}" = yes; then
|
|
Packit |
c22fc9 |
AC_DEFINE([_WITH_PERF_], [ 1 ], [Define to 1 to build with perf support])
|
|
Packit |
c22fc9 |
ENABLE_PERF=Yes
|
|
Packit |
c22fc9 |
add_config_opt([PERF])
|
|
Packit |
c22fc9 |
add_to_var([KA_CFLAGS], [-pg])
|
|
Packit |
c22fc9 |
else
|
|
Packit |
c22fc9 |
ENABLE_PERF=No
|
|
Packit |
c22fc9 |
fi
|
|
Packit |
c22fc9 |
|
|
Packit |
c22fc9 |
if test ${enable_log_file} = yes; then
|
|
Packit |
c22fc9 |
AC_DEFINE([ENABLE_LOG_TO_FILE], [ 1 ], [Define if enabling logging to files])
|
|
Packit |
c22fc9 |
ENABLE_LOG_FILE_APPEND=Yes
|
|
Packit |
c22fc9 |
add_config_opt([FILE_LOGGING])
|
|
Packit |
c22fc9 |
fi
|
|
Packit |
c22fc9 |
|
|
Packit |
c22fc9 |
if test ${ENABLE_LOG_FILE_APPEND} = Yes; then
|
|
Packit |
c22fc9 |
AC_DEFINE([ENABLE_LOG_FILE_APPEND], [ 1 ], [Define if appending to log files is allowed])
|
|
Packit |
c22fc9 |
add_config_opt([LOG_FILE_APPEND])
|
|
Packit |
c22fc9 |
fi
|
|
Packit |
c22fc9 |
|
|
Packit |
c22fc9 |
if test ${NEED_LIBDL} = Yes; then
|
|
Packit |
c22fc9 |
add_to_var([KA_LIBS], [-ldl])
|
|
Packit |
c22fc9 |
fi
|
|
Packit |
c22fc9 |
|
|
Packit |
c22fc9 |
dnl ----[ Determine if we are using pthreads ]----
|
|
Packit |
c22fc9 |
echo " $KA_LIBS" | grep -qE -- " -l?pthread "
|
|
Packit |
c22fc9 |
if test $? -eq 0 ;then
|
|
Packit |
c22fc9 |
AC_DEFINE([_WITH_PTHREADS_], [ 1 ], [Define to 1 if using pthreads])
|
|
Packit |
c22fc9 |
fi
|
|
Packit |
c22fc9 |
|
|
Packit |
c22fc9 |
dnl ----[ Check if rpmbuild supports --build-in-place ]----
|
|
Packit |
c22fc9 |
RPM_NO_BIP=1
|
|
Packit |
c22fc9 |
AC_CHECK_PROG([HAVE_RPM], [rpm], [Yes], [No])
|
|
Packit |
c22fc9 |
if test $HAVE_RPM = Yes; then
|
|
Packit |
c22fc9 |
AC_CHECK_PROG([HAVE_RPMBUILD], [rpmbuild], [Yes], [No])
|
|
Packit |
c22fc9 |
RPM_SRC_DIR=`rpm --eval "%{_sourcedir}"`
|
|
Packit |
c22fc9 |
if ! test -d $RPM_SRC_DIR; then
|
|
Packit |
c22fc9 |
HAVE_RPMBUILD=No
|
|
Packit |
c22fc9 |
fi
|
|
Packit |
c22fc9 |
if test $HAVE_RPMBUILD = Yes; then
|
|
Packit |
c22fc9 |
rpmbuild --help | grep -q -- --build-in-place
|
|
Packit |
c22fc9 |
RPM_NO_BIP=$?
|
|
Packit |
c22fc9 |
fi
|
|
Packit |
c22fc9 |
fi
|
|
Packit |
c22fc9 |
AM_CONDITIONAL([RPM], [test $HAVE_RPM = Yes])
|
|
Packit |
c22fc9 |
AM_CONDITIONAL([RPM_BIP], [test $RPM_NO_BIP -eq 0])
|
|
Packit |
c22fc9 |
|
|
Packit |
c22fc9 |
dnl ----[ Determine system init type]----
|
|
Packit |
c22fc9 |
INIT_TYPE=
|
|
Packit |
c22fc9 |
if test -z $init_type; then
|
|
Packit |
c22fc9 |
/sbin/init --version 2>/dev/null | grep -q upstart
|
|
Packit |
c22fc9 |
if test $? -eq 0; then
|
|
Packit |
c22fc9 |
INIT_TYPE=upstart
|
|
Packit |
c22fc9 |
else
|
|
Packit |
c22fc9 |
init_path=`which systemctl 2>/dev/null`
|
|
Packit |
c22fc9 |
if test \( $? -eq 0 -a -x "$init_path" \); then
|
|
Packit |
c22fc9 |
systemctl | grep -q -- "-\.mount"
|
|
Packit |
c22fc9 |
if test $? -eq 0; then
|
|
Packit |
c22fc9 |
INIT_TYPE=systemd
|
|
Packit |
c22fc9 |
fi
|
|
Packit |
c22fc9 |
fi
|
|
Packit |
c22fc9 |
if test \( -z "$INIT_TYPE" -a -f /etc/init.d/networking \); then
|
|
Packit |
c22fc9 |
init_path=`which openrc-run 2>/dev/null`
|
|
Packit |
c22fc9 |
if test \( $? -eq 0 -a -x "$init_path" \); then
|
|
Packit |
c22fc9 |
head -1 /etc/init.d/networking | grep -q "^#! */.*/openrc-run$"
|
|
Packit |
c22fc9 |
if test $? -eq 0; then
|
|
Packit |
c22fc9 |
INIT_TYPE=openrc
|
|
Packit |
c22fc9 |
fi
|
|
Packit |
c22fc9 |
fi
|
|
Packit |
c22fc9 |
fi
|
|
Packit |
c22fc9 |
if test \( -z "$INIT_TYPE" -a -f /etc/init.d/cron -a ! -h /etc/init.d/cron \); then
|
|
Packit |
c22fc9 |
INIT_TYPE=SYSV
|
|
Packit |
c22fc9 |
fi
|
|
Packit |
c22fc9 |
fi
|
|
Packit |
c22fc9 |
else
|
|
Packit |
c22fc9 |
INIT_TYPE=$init_type
|
|
Packit |
c22fc9 |
fi
|
|
Packit |
c22fc9 |
|
|
Packit |
c22fc9 |
dnl ----[Default keepalived configuration file]----
|
|
Packit |
c22fc9 |
AS_IF([test $default_config_file],
|
|
Packit |
c22fc9 |
[
|
|
Packit |
c22fc9 |
AS_IF([test $default_config_file = yes -o $default_config_file = no],
|
|
Packit |
c22fc9 |
AC_MSG_ERROR([A filename must be specified for default-config-file])
|
|
Packit |
c22fc9 |
])
|
|
Packit |
c22fc9 |
CONFIG_FILE=$default_config_file
|
|
Packit |
c22fc9 |
add_config_opt([DEFAULT_CONFIG_FILE=${default_config_file}])
|
|
Packit |
c22fc9 |
],
|
|
Packit |
c22fc9 |
[default_config_file="/etc/$PACKAGE/$PACKAGE.conf"])
|
|
Packit |
c22fc9 |
AC_DEFINE_UNQUOTED([DEFAULT_CONFIG_FILE], ["$default_config_file"], [The default configuration file])
|
|
Packit |
c22fc9 |
AC_SUBST([DEFAULT_CONFIG_FILE], [$default_config_file])
|
|
Packit |
c22fc9 |
|
|
Packit |
c22fc9 |
if test -z $INIT_TYPE; then
|
|
Packit |
c22fc9 |
INIT_TYPE=undetected
|
|
Packit |
c22fc9 |
elif test $INIT_TYPE = systemd; then
|
|
Packit |
c22fc9 |
AC_SUBST([systemdsystemunitdir], [$with_systemdsystemunitdir])
|
|
Packit |
c22fc9 |
fi
|
|
Packit |
c22fc9 |
|
|
Packit |
c22fc9 |
AM_CONDITIONAL([INIT_UPSTART], [test $INIT_TYPE = upstart])
|
|
Packit |
c22fc9 |
AM_CONDITIONAL([INIT_SYSTEMD], [test $INIT_TYPE = systemd])
|
|
Packit |
c22fc9 |
AM_CONDITIONAL([INIT_SYSV], [test $INIT_TYPE = SYSV])
|
|
Packit |
c22fc9 |
AM_CONDITIONAL([INIT_OPENRC], [test $INIT_TYPE = openrc])
|
|
Packit |
c22fc9 |
AM_CONDITIONAL([INIT_SUSE], [test $INIT_TYPE = SUSE])
|
|
Packit |
c22fc9 |
|
|
Packit |
c22fc9 |
AC_DEFINE_UNQUOTED([CONFIGURATION_OPTIONS], ["$CONFIG_OPTIONS"], [The configuration options from which the package is built])
|
|
Packit |
c22fc9 |
AC_DEFINE_UNQUOTED([SYSTEM_OPTIONS], ["$SYSTEM_OPTIONS"], [The system options from which the package is built])
|
|
Packit |
c22fc9 |
|
|
Packit |
c22fc9 |
if test $NETLINK_VER -eq 0; then
|
|
Packit |
c22fc9 |
NETLINK_VER=None
|
|
Packit |
c22fc9 |
fi
|
|
Packit |
c22fc9 |
|
|
Packit |
c22fc9 |
dnl ----[ Process output target ]----
|
|
Packit |
c22fc9 |
echo
|
|
Packit |
c22fc9 |
|
|
Packit |
c22fc9 |
AC_OUTPUT
|
|
Packit |
c22fc9 |
|
|
Packit |
c22fc9 |
dnl ----[ Display current configuration ]----
|
|
Packit |
c22fc9 |
cat <
|
|
Packit |
c22fc9 |
|
|
Packit |
c22fc9 |
Keepalived configuration
|
|
Packit |
c22fc9 |
------------------------
|
|
Packit |
c22fc9 |
Keepalived version : ${VERSION}
|
|
Packit |
c22fc9 |
Compiler : ${CC}
|
|
Packit |
c22fc9 |
Preprocessor flags : ${KA_CPPFLAGS}
|
|
Packit |
c22fc9 |
Compiler flags : ${KA_CFLAGS}
|
|
Packit |
c22fc9 |
EOF
|
|
Packit |
c22fc9 |
|
|
Packit |
c22fc9 |
dnl ----[ display optional vars ]----
|
|
Packit |
c22fc9 |
if test -n "$KA_LDFLAGS$KA_LIBS"; then
|
|
Packit |
c22fc9 |
echo "Linker flags : $KA_LDFLAGS"
|
|
Packit |
c22fc9 |
echo "Extra Lib : $KA_LIBS"
|
|
Packit |
c22fc9 |
fi
|
|
Packit |
c22fc9 |
|
|
Packit |
c22fc9 |
echo "Use IPVS Framework : ${IPVS_SUPPORT}"
|
|
Packit |
c22fc9 |
if test ${IPVS_SUPPORT} = Yes; then
|
|
Packit |
c22fc9 |
echo "IPVS use libnl : ${IPVS_USE_NL}"
|
|
Packit |
c22fc9 |
echo "IPVS syncd attributes : ${IPVS_SYNCD_ATTRIBUTES}"
|
|
Packit |
c22fc9 |
echo "IPVS 64 bit stats : ${IPVS_64BIT_STATS}"
|
|
Packit |
c22fc9 |
echo "HTTP_GET regex support : ${WITH_REGEX}"
|
|
Packit |
c22fc9 |
fi
|
|
Packit |
c22fc9 |
echo "fwmark socket support : ${SO_MARK_SUPPORT}"
|
|
Packit |
c22fc9 |
echo "Use VRRP Framework : ${VRRP_SUPPORT}"
|
|
Packit |
c22fc9 |
if test ${VRRP_SUPPORT} = Yes; then
|
|
Packit |
c22fc9 |
echo "Use VRRP VMAC : ${MACVLAN_SUPPORT}"
|
|
Packit |
c22fc9 |
echo "Use VRRP authentication : ${VRRP_AUTH_SUPPORT}"
|
|
Packit |
c22fc9 |
echo "With ip rules/routes : ${FIB_ROUTING_SUPPORT}"
|
|
Packit |
c22fc9 |
fi
|
|
Packit |
c22fc9 |
echo "Use BFD Framework : ${BFD_SUPPORT}"
|
|
Packit |
c22fc9 |
echo "SNMP vrrp support : ${SNMP_VRRP_SUPPORT}"
|
|
Packit |
c22fc9 |
echo "SNMP checker support : ${SNMP_CHECKER_SUPPORT}"
|
|
Packit |
c22fc9 |
echo "SNMP RFCv2 support : ${SNMP_RFCV2_SUPPORT}"
|
|
Packit |
c22fc9 |
echo "SNMP RFCv3 support : ${SNMP_RFCV3_SUPPORT}"
|
|
Packit |
c22fc9 |
if test ${SNMP_RFCV3_SUPPORT} = Yes; then
|
|
Packit |
c22fc9 |
echo "SNMP send V3 for V2 : ${SNMP_V3_FOR_V2}"
|
|
Packit |
c22fc9 |
fi
|
|
Packit |
c22fc9 |
echo "DBUS support : ${DBUS_SUPPORT}"
|
|
Packit |
c22fc9 |
if test ${DBUS_SUPPORT} = Yes; then
|
|
Packit |
c22fc9 |
echo "DBUS create instance : ${DBUS_CREATE_INSTANCE}"
|
|
Packit |
c22fc9 |
fi
|
|
Packit |
c22fc9 |
echo "SHA1 support : ${SHA1_SUPPORT}"
|
|
Packit |
c22fc9 |
echo "Use Json output : ${ENABLE_JSON}"
|
|
Packit |
c22fc9 |
echo "libnl version : ${NETLINK_VER}"
|
|
Packit |
c22fc9 |
echo "Use IPv4 devconf : ${IPV4_DEVCONF}"
|
|
Packit |
c22fc9 |
echo "Use libiptc : ${USE_LIBIPTC}"
|
|
Packit |
c22fc9 |
echo "Use libipset : ${USE_LIBIPSET}"
|
|
Packit |
c22fc9 |
echo "init type : ${INIT_TYPE}"
|
|
Packit |
c22fc9 |
echo "Strict config checks : ${STRICT_CONFIG}"
|
|
Packit |
c22fc9 |
echo "Build genhash : ${BUILD_GENHASH}"
|
|
Packit |
c22fc9 |
echo "Build documentation : ${HAVE_SPHINX_BUILD}"
|
|
Packit |
c22fc9 |
if test ${ENABLE_STACKTRACE} = Yes; then
|
|
Packit |
c22fc9 |
echo "Stacktrace support : ${ENABLE_STACKTRACE}"
|
|
Packit |
c22fc9 |
fi
|
|
Packit |
c22fc9 |
if test ${ENABLE_PERF} = Yes; then
|
|
Packit |
c22fc9 |
echo "Perf support : ${ENABLE_PERF}"
|
|
Packit |
c22fc9 |
fi
|
|
Packit |
c22fc9 |
if test ${MEM_CHECK} = Yes; then
|
|
Packit |
c22fc9 |
echo "Memory alloc check : ${MEM_CHECK}"
|
|
Packit |
c22fc9 |
echo "Memory alloc check log : ${MEM_CHECK_LOG}"
|
|
Packit |
c22fc9 |
fi
|
|
Packit |
c22fc9 |
if test ${TIMER_CHECK} = Yes; then
|
|
Packit |
c22fc9 |
echo "Set time logging : ${TIMER_CHECK}"
|
|
Packit |
c22fc9 |
fi
|
|
Packit |
c22fc9 |
if test ${ENABLE_DUMP_THREADS} = Yes; then
|
|
Packit |
c22fc9 |
echo "Thread debugging : ${ENABLE_DUMP_THREADS}"
|
|
Packit |
c22fc9 |
fi
|
|
Packit |
c22fc9 |
if test ${ENABLE_EPOLL_DEBUG} = Yes; then
|
|
Packit |
c22fc9 |
echo "epoll_wait() debugging : ${ENABLE_EPOLL_DEBUG}"
|
|
Packit |
c22fc9 |
fi
|
|
Packit |
c22fc9 |
if test ${ENABLE_EPOLL_THREAD_DUMP} = Yes; then
|
|
Packit |
c22fc9 |
echo "epoll thread dumping : ${ENABLE_EPOLL_THREAD_DUMP}"
|
|
Packit |
c22fc9 |
fi
|
|
Packit |
c22fc9 |
if test ${ENABLE_REGEX_DEBUG} = Yes; then
|
|
Packit |
c22fc9 |
echo "regex debugging : ${ENABLE_REGEX_DEBUG}"
|
|
Packit |
c22fc9 |
fi
|
|
Packit |
c22fc9 |
if test ${ENABLE_TSM_DEBUG} = Yes; then
|
|
Packit |
c22fc9 |
echo "TSM debugging : ${ENABLE_TSM_DEBUG}"
|
|
Packit |
c22fc9 |
fi
|
|
Packit |
c22fc9 |
if test ${ENABLE_VRRP_FD_DEBUG} = Yes; then
|
|
Packit |
c22fc9 |
echo "VRRP_FD debugging : ${ENABLE_VRRP_FD_DEBUG}"
|
|
Packit |
c22fc9 |
fi
|
|
Packit |
c22fc9 |
if test ${ENABLE_DEBUG} = Yes; then
|
|
Packit |
c22fc9 |
echo "Use Debug flags : ${ENABLE_DEBUG}"
|
|
Packit |
c22fc9 |
fi
|
|
Packit |
c22fc9 |
if test ${ENABLE_NETLINK_TIMERS} = Yes; then
|
|
Packit |
c22fc9 |
echo "Netlink command timers : ${ENABLE_NETLINK_TIMERS}"
|
|
Packit |
c22fc9 |
fi
|
|
Packit |
c22fc9 |
if test ${ENABLE_SMTP_ALERT_DEBUG} = Yes; then
|
|
Packit |
c22fc9 |
echo "smtp-alert debugging : ${ENABLE_SMTP_ALERT_DEBUG}"
|
|
Packit |
c22fc9 |
fi
|
|
Packit |
c22fc9 |
if test "${FIXED_IF_TYPE}"; then
|
|
Packit |
c22fc9 |
echo "Fixed interface type : ${FIXED_IF_TYPE}"
|
|
Packit |
c22fc9 |
fi
|
|
Packit |
c22fc9 |
if test "${CONFIG_FILE}"; then
|
|
Packit |
c22fc9 |
echo "Default config file : ${CONFIG_FILE}"
|
|
Packit |
c22fc9 |
fi
|
|
Packit |
c22fc9 |
|
|
Packit |
c22fc9 |
dnl ----[ end configure ]---
|
|
Packit |
c22fc9 |
|
|
Packit |
c22fc9 |
if test ${IPVS_SUPPORT} = Yes -a ${IPVS_USE_NL} = No; then
|
|
Packit |
c22fc9 |
echo
|
|
Packit |
c22fc9 |
echo "*** WARNING - this build will not support IPVS with IPv6. Please install libnl/libnl-3 dev libraries to support IPv6 with IPVS."
|
|
Packit |
c22fc9 |
echo
|
|
Packit |
c22fc9 |
fi
|
|
Packit |
c22fc9 |
|
|
Packit |
c22fc9 |
if test ${ENABLE_DEBUG} = Yes; then
|
|
Packit |
c22fc9 |
echo
|
|
Packit |
c22fc9 |
echo "*** WARNING --enable-debug is only for debugging purposes and isn't expected to work properly"
|
|
Packit |
c22fc9 |
echo
|
|
Packit |
c22fc9 |
fi
|