blob: 6864378a3fcb996d0f861cc97bb464ccec29669b [file] [log] [blame]
Jan Engelhardtf82070f2008-01-20 13:14:00 +00001
Pablo Neira Ayusof485d322021-01-13 16:47:07 +01002AC_INIT([iptables], [1.8.7])
Thomas Jaroschc634cb92008-06-03 15:02:18 +02003
Jan Engelhardtdacafa52009-01-27 20:56:23 +01004# See libtool.info "Libtool's versioning system"
Pablo Neira Ayusof485d322021-01-13 16:47:07 +01005libxtables_vcurrent=16
6libxtables_vage=4
Jan Engelhardtdacafa52009-01-27 20:56:23 +01007
Jan Engelhardtde26cd22011-12-18 20:21:27 +01008AC_CONFIG_AUX_DIR([build-aux])
Jan Engelhardtf82070f2008-01-20 13:14:00 +00009AC_CONFIG_HEADERS([config.h])
Jan Engelhardt0086b8b2009-01-07 15:11:59 +010010AC_CONFIG_MACRO_DIR([m4])
Jan Engelhardtf82070f2008-01-20 13:14:00 +000011AC_PROG_INSTALL
Jan Engelhardt0086b8b2009-01-07 15:11:59 +010012AM_INIT_AUTOMAKE([-Wall])
Jan Engelhardtf82070f2008-01-20 13:14:00 +000013AC_PROG_CC
14AM_PROG_CC_C_O
15AC_DISABLE_STATIC
Jan Engelhardt053a4fd2012-08-31 04:06:38 +020016m4_ifdef([AM_PROG_AR], [AM_PROG_AR])
Jan Engelhardt0086b8b2009-01-07 15:11:59 +010017AM_PROG_LIBTOOL
Jan Engelhardtf82070f2008-01-20 13:14:00 +000018
Jan Engelhardtf82070f2008-01-20 13:14:00 +000019AC_ARG_WITH([kernel],
20 AS_HELP_STRING([--with-kernel=PATH],
21 [Path to kernel source/build directory]),
22 [kbuilddir="$withval"; ksourcedir="$withval";])
23AC_ARG_WITH([kbuild],
24 AS_HELP_STRING([--with-kbuild=PATH],
25 [Path to kernel build directory [[/lib/modules/CURRENT/build]]]),
26 [kbuilddir="$withval"])
27AC_ARG_WITH([ksource],
28 AS_HELP_STRING([--with-ksource=PATH],
29 [Path to kernel source directory [[/lib/modules/CURRENT/source]]]),
30 [ksourcedir="$withval"])
Jan Engelhardt21b41ee2008-02-11 01:02:00 +010031AC_ARG_WITH([xtlibdir],
32 AS_HELP_STRING([--with-xtlibdir=PATH],
Jan Engelhardtd31a6592008-02-11 14:11:14 +010033 [Path where to install Xtables extensions [[LIBEXECDIR/xtables]]]),
Jan Engelhardt21b41ee2008-02-11 01:02:00 +010034 [xtlibdir="$withval"],
Jan Engelhardt411a4e52011-07-04 12:44:43 +020035 [xtlibdir="${libdir}/xtables"])
Jan Engelhardta094eb02009-04-03 22:37:49 +020036AC_ARG_ENABLE([ipv4],
37 AS_HELP_STRING([--disable-ipv4], [Do not build iptables]),
38 [enable_ipv4="$enableval"], [enable_ipv4="yes"])
Jan Engelhardt8e586132009-04-03 22:28:34 +020039AC_ARG_ENABLE([ipv6],
40 AS_HELP_STRING([--disable-ipv6], [Do not build ip6tables]),
41 [enable_ipv6="$enableval"], [enable_ipv6="yes"])
Karl Hiramoto967cb712010-05-10 17:50:41 +020042AC_ARG_ENABLE([largefile],
43 AS_HELP_STRING([--disable-largefile], [Do not build largefile support]),
44 [enable_largefile="$enableval"],
Juergen Borleisf4b80ce2017-09-28 10:59:44 +020045 [enable_largefile="yes"])
46AS_IF([test "$enable_largefile" = "yes"], [largefile_cppflags='-D_LARGEFILE_SOURCE=1 -D_LARGE_FILES -D_FILE_OFFSET_BITS=64'])
47
Jan Engelhardtf82070f2008-01-20 13:14:00 +000048AC_ARG_ENABLE([devel],
49 AS_HELP_STRING([--enable-devel],
Jan Engelhardt77f15382008-02-11 15:01:03 +010050 [Install Xtables development headers]),
51 [enable_devel="$enableval"], [enable_devel="yes"])
52AC_ARG_ENABLE([libipq],
Eric Leblondfe42fac2013-06-05 04:16:25 +020053 AS_HELP_STRING([--enable-libipq], [Build and install libipq]),
54 [enable_libipq="$enableval"], [enable_libipq="no"])
Willem de Bruijn1ac30c92013-03-12 05:44:12 +000055AC_ARG_ENABLE([bpf-compiler],
56 AS_HELP_STRING([--enable-bpf-compiler], [Build bpf compiler]),
Mike Frysingerb8b751b2015-08-15 14:13:35 -040057 [enable_bpfc="$enableval"], [enable_bpfc="no"])
Patrick McHardy9e6928f2013-08-28 09:32:44 +020058AC_ARG_ENABLE([nfsynproxy],
59 AS_HELP_STRING([--enable-nfsynproxy], [Build SYNPROXY configuration tool]),
Mike Frysingerb8b751b2015-08-15 14:13:35 -040060 [enable_nfsynproxy="$enableval"], [enable_nfsynproxy="no"])
Jan Engelhardt126c1362008-08-04 18:37:38 +020061AC_ARG_WITH([pkgconfigdir], AS_HELP_STRING([--with-pkgconfigdir=PATH],
62 [Path to the pkgconfig directory [[LIBDIR/pkgconfig]]]),
63 [pkgconfigdir="$withval"], [pkgconfigdir='${libdir}/pkgconfig'])
Pablo Neira Ayuso38495862012-09-27 19:12:53 +020064AC_ARG_ENABLE([nftables],
Pablo Neira Ayuso9e48e502014-02-04 13:20:09 +010065 AS_HELP_STRING([--disable-nftables], [Do not build nftables compat]),
Pablo Neira Ayuso38495862012-09-27 19:12:53 +020066 [enable_nftables="$enableval"], [enable_nftables="yes"])
Shivani Bhardwaj3b7a2272016-03-22 10:43:06 +053067AC_ARG_ENABLE([connlabel],
68 AS_HELP_STRING([--disable-connlabel],
69 [Do not build libnetfilter_conntrack]),
70 [enable_connlabel="$enableval"], [enable_connlabel="yes"])
Lorenzo Colittib91af532017-03-14 17:55:50 +090071AC_ARG_WITH([xt-lock-name], AS_HELP_STRING([--with-xt-lock-name=PATH],
72 [Path to the xtables lock [[/run/xtables.lock]]]),
73 [xt_lock_name="$withval"],
74 [xt_lock_name="/run/xtables.lock"])
Jan Engelhardtf82070f2008-01-20 13:14:00 +000075
Jan Engelhardt79cefab2011-12-30 02:14:00 +010076AC_MSG_CHECKING([whether $LD knows -Wl,--no-undefined])
77saved_LDFLAGS="$LDFLAGS";
78LDFLAGS="-Wl,--no-undefined";
79AC_LINK_IFELSE([AC_LANG_SOURCE([int main(void) {}])],
80 [noundef_LDFLAGS="$LDFLAGS"; AC_MSG_RESULT([yes])],
81 [AC_MSG_RESULT([no])]
82)
83LDFLAGS="$saved_LDFLAGS";
84
Mike Frysinger4ecdf832015-08-18 18:48:54 -040085blacklist_modules=""
86blacklist_x_modules=""
87blacklist_b_modules=""
88blacklist_a_modules=""
89blacklist_4_modules=""
90blacklist_6_modules=""
Hannes Ederc36d05e2010-07-23 12:51:26 +020091
Willem de Bruijnf17f9ac2016-12-08 17:09:38 -050092AC_CHECK_HEADERS([linux/dccp.h linux/ip_vs.h linux/magic.h linux/proc_fs.h linux/bpf.h])
Jan Engelhardt2c570e72008-06-05 19:54:48 +020093if test "$ac_cv_header_linux_dccp_h" != "yes"; then
94 blacklist_modules="$blacklist_modules dccp";
95fi;
Hannes Ederc36d05e2010-07-23 12:51:26 +020096if test "$ac_cv_header_linux_ip_vs_h" != "yes"; then
97 blacklist_modules="$blacklist_modules ipvs";
98fi;
99
Jan Engelhardt4d8656a2011-07-22 12:25:43 +0200100AC_CHECK_SIZEOF([struct ip6_hdr], [], [#include <netinet/ip6.h>])
Jan Engelhardt2c570e72008-06-05 19:54:48 +0200101
Jan Engelhardtee3228a2008-06-23 11:37:08 +0200102AM_CONDITIONAL([ENABLE_STATIC], [test "$enable_static" = "yes"])
103AM_CONDITIONAL([ENABLE_SHARED], [test "$enable_shared" = "yes"])
Jan Engelhardta094eb02009-04-03 22:37:49 +0200104AM_CONDITIONAL([ENABLE_IPV4], [test "$enable_ipv4" = "yes"])
Jan Engelhardt8e586132009-04-03 22:28:34 +0200105AM_CONDITIONAL([ENABLE_IPV6], [test "$enable_ipv6" = "yes"])
Karl Hiramoto967cb712010-05-10 17:50:41 +0200106AM_CONDITIONAL([ENABLE_LARGEFILE], [test "$enable_largefile" = "yes"])
Jan Engelhardtee3228a2008-06-23 11:37:08 +0200107AM_CONDITIONAL([ENABLE_DEVEL], [test "$enable_devel" = "yes"])
108AM_CONDITIONAL([ENABLE_LIBIPQ], [test "$enable_libipq" = "yes"])
Willem de Bruijn1ac30c92013-03-12 05:44:12 +0000109AM_CONDITIONAL([ENABLE_BPFC], [test "$enable_bpfc" = "yes"])
Patrick McHardy9e6928f2013-08-28 09:32:44 +0200110AM_CONDITIONAL([ENABLE_SYNCONF], [test "$enable_nfsynproxy" = "yes"])
Pablo Neira Ayuso38495862012-09-27 19:12:53 +0200111AM_CONDITIONAL([ENABLE_NFTABLES], [test "$enable_nftables" = "yes"])
Shivani Bhardwaj3b7a2272016-03-22 10:43:06 +0530112AM_CONDITIONAL([ENABLE_CONNLABEL], [test "$enable_connlabel" = "yes"])
Jan Engelhardtf82070f2008-01-20 13:14:00 +0000113
Patrick McHardy9e6928f2013-08-28 09:32:44 +0200114if test "x$enable_bpfc" = "xyes" || test "x$enable_nfsynproxy" = "xyes"; then
115 AC_CHECK_LIB(pcap, pcap_compile,, AC_MSG_ERROR(missing libpcap library required by bpf compiler or nfsynproxy tool))
Willem de Bruijnc18f2ce2013-07-21 20:02:38 -0400116fi
117
Jan Engelhardtdb6d0272010-03-27 12:48:55 +0100118PKG_CHECK_MODULES([libnfnetlink], [libnfnetlink >= 1.0],
119 [nfnetlink=1], [nfnetlink=0])
120AM_CONDITIONAL([HAVE_LIBNFNETLINK], [test "$nfnetlink" = 1])
121
Pablo Neira Ayuso38e5ce62014-02-04 13:32:58 +0100122if test "x$enable_nftables" = "xyes"; then
123 PKG_CHECK_MODULES([libmnl], [libmnl >= 1.0], [mnl=1], [mnl=0])
124
Giuseppe Longo3d202e52016-04-26 21:27:58 +0200125 if test "$mnl" = 0;
126 then
127 echo "*** Error: No suitable libmnl found. ***"
128 echo " Please install the 'libmnl' package"
129 echo " Or consider --disable-nftables to skip"
130 echo " iptables-compat over nftables support."
131 exit 1
132 fi
133
Phil Sutter50564b72020-06-03 11:41:55 +0200134 PKG_CHECK_MODULES([libnftnl], [libnftnl >= 1.1.6], [nftables=1], [nftables=0])
Pablo Neira Ayuso38e5ce62014-02-04 13:32:58 +0100135
Giuseppe Longo3d202e52016-04-26 21:27:58 +0200136 if test "$nftables" = 0;
137 then
138 echo "*** Error: no suitable libnftnl found. ***"
139 echo " Please install the 'libnftnl' package"
140 echo " Or consider --disable-nftables to skip"
141 echo " iptables-compat over nftables support."
142 exit 1
143 fi
Pablo Neira Ayuso38e5ce62014-02-04 13:32:58 +0100144fi
145
Pablo Neira Ayuso38495862012-09-27 19:12:53 +0200146AM_CONDITIONAL([HAVE_LIBMNL], [test "$mnl" = 1])
Tomasz Bursztykaa4e10982014-01-20 17:56:41 +0200147AM_CONDITIONAL([HAVE_LIBNFTNL], [test "$nftables" = 1])
Pablo Neira Ayuso38495862012-09-27 19:12:53 +0200148
Mike Frysinger4ecdf832015-08-18 18:48:54 -0400149if test "$nftables" != 1; then
150 blacklist_b_modules="$blacklist_b_modules limit mark nflog mangle"
151 blacklist_a_modules="$blacklist_a_modules mangle"
152fi
153
Shivani Bhardwaj3b7a2272016-03-22 10:43:06 +0530154if test "x$enable_connlabel" = "xyes"; then
155 PKG_CHECK_MODULES([libnetfilter_conntrack],
Pablo Neira Ayusoc4482052016-11-10 01:47:09 +0100156 [libnetfilter_conntrack >= 1.0.6],
Shivani Bhardwaj3b7a2272016-03-22 10:43:06 +0530157 [nfconntrack=1], [nfconntrack=0])
158
159 if test "$nfconntrack" -ne 1; then
160 blacklist_modules="$blacklist_modules connlabel";
161 echo "WARNING: libnetfilter_conntrack not found, connlabel match will not be built";
Shivani Bhardwaj6490f0b2016-06-23 01:11:39 +0530162 enable_connlabel="no";
Shivani Bhardwaj3b7a2272016-03-22 10:43:06 +0530163 fi;
164else
165 blacklist_modules="$blacklist_modules connlabel";
166fi;
167
168AM_CONDITIONAL([HAVE_LIBNETFILTER_CONNTRACK], [test "$nfconntrack" = 1])
169
Mike Frysinger4ecdf832015-08-18 18:48:54 -0400170AC_SUBST([blacklist_modules])
171AC_SUBST([blacklist_x_modules])
172AC_SUBST([blacklist_b_modules])
173AC_SUBST([blacklist_a_modules])
174AC_SUBST([blacklist_4_modules])
175AC_SUBST([blacklist_6_modules])
176
Jan Engelhardt8e336252011-06-01 02:16:05 +0200177regular_CFLAGS="-Wall -Waggregate-return -Wmissing-declarations \
Jan Engelhardtf82070f2008-01-20 13:14:00 +0000178 -Wmissing-prototypes -Wredundant-decls -Wshadow -Wstrict-prototypes \
Florian Westphal107b7eb2018-06-15 11:04:39 +0200179 -Wlogical-op \
Jan Engelhardt8e336252011-06-01 02:16:05 +0200180 -Winline -pipe";
Lorenzo Colitti836846f2017-03-16 12:54:20 +0900181regular_CPPFLAGS="${largefile_cppflags} -D_REENTRANT \
Jan Engelhardt21b41ee2008-02-11 01:02:00 +0100182 -DXTABLES_LIBDIR=\\\"\${xtlibdir}\\\" -DXTABLES_INTERNAL";
Jan Engelhardt5085c3a2011-06-01 02:20:40 +0200183kinclude_CPPFLAGS="";
Jan Engelhardtca7cd662008-02-11 01:23:01 +0100184if [[ -n "$kbuilddir" ]]; then
Phil Oester59bbc592013-07-21 08:30:49 -0700185 kinclude_CPPFLAGS="$kinclude_CPPFLAGS -I$kbuilddir/include/uapi -I$kbuilddir/include";
Jan Engelhardtca7cd662008-02-11 01:23:01 +0100186fi;
187if [[ -n "$ksourcedir" ]]; then
Phil Oester59bbc592013-07-21 08:30:49 -0700188 kinclude_CPPFLAGS="$kinclude_CPPFLAGS -I$ksourcedir/include/uapi -I$ksourcedir/include";
Jan Engelhardtca7cd662008-02-11 01:23:01 +0100189fi;
Jan Engelhardtdb6d0272010-03-27 12:48:55 +0100190pkgdatadir='${datadir}/xtables';
Jan Engelhardtf82070f2008-01-20 13:14:00 +0000191
Eric Leblondfe42fac2013-06-05 04:16:25 +0200192define([EXPAND_VARIABLE],
193[$2=[$]$1
194if test $prefix = 'NONE'; then
195 prefix="/usr/local"
196fi
197while true; do
198 case "[$]$2" in
199 *\[$]* ) eval "$2=[$]$2" ;;
200 *) break ;;
201 esac
202done
203eval "$2=[$]$2"
204])dnl EXPAND_VARIABLE
205
Jan Engelhardtb95fc082008-04-15 09:13:17 +0200206AC_SUBST([regular_CFLAGS])
Jan Engelhardt8e336252011-06-01 02:16:05 +0200207AC_SUBST([regular_CPPFLAGS])
Jan Engelhardt79cefab2011-12-30 02:14:00 +0100208AC_SUBST([noundef_LDFLAGS])
Jan Engelhardt5085c3a2011-06-01 02:20:40 +0200209AC_SUBST([kinclude_CPPFLAGS])
Jan Engelhardtf82070f2008-01-20 13:14:00 +0000210AC_SUBST([kbuilddir])
211AC_SUBST([ksourcedir])
Jan Engelhardt21b41ee2008-02-11 01:02:00 +0100212AC_SUBST([xtlibdir])
Jan Engelhardt126c1362008-08-04 18:37:38 +0200213AC_SUBST([pkgconfigdir])
Jan Engelhardtdb6d0272010-03-27 12:48:55 +0100214AC_SUBST([pkgdatadir])
Jan Engelhardtdacafa52009-01-27 20:56:23 +0100215AC_SUBST([libxtables_vcurrent])
216AC_SUBST([libxtables_vage])
217libxtables_vmajor=$(($libxtables_vcurrent - $libxtables_vage));
218AC_SUBST([libxtables_vmajor])
Lorenzo Colitti836846f2017-03-16 12:54:20 +0900219
220AC_DEFINE_UNQUOTED([XT_LOCK_NAME], "${xt_lock_name}",
221 [Location of the iptables lock file])
Giuseppe Scrivano5105e842020-07-17 10:39:40 +0200222AC_SUBST([XT_LOCK_NAME], "${xt_lock_name}")
Thomas Jaroschc634cb92008-06-03 15:02:18 +0200223
Jan Engelhardtf567ac92009-02-12 15:01:37 +0100224AC_CONFIG_FILES([Makefile extensions/GNUmakefile include/Makefile
Jan Engelhardt033e25a2011-06-07 14:02:37 +0200225 iptables/Makefile iptables/xtables.pc
Florian Westphalc25defa2013-07-14 19:32:12 +0200226 iptables/iptables.8 iptables/iptables-extensions.8.tmpl
Pablo Neira Ayuso74bd60b2013-08-22 13:11:45 +0200227 iptables/iptables-save.8 iptables/iptables-restore.8
228 iptables/iptables-apply.8 iptables/iptables-xml.1
Jan Engelhardt4982fe42011-08-08 02:38:41 +0200229 libipq/Makefile libipq/libipq.pc
Jan Engelhardtb8c42ec2011-12-18 02:52:15 +0100230 libiptc/Makefile libiptc/libiptc.pc
231 libiptc/libip4tc.pc libiptc/libip6tc.pc
232 libxtables/Makefile utils/Makefile
Jan Engelhardt093cec72019-05-28 11:43:26 +0200233 include/xtables-version.h
Florian Westphald26c5382018-05-09 01:15:10 +0200234 iptables/xtables-monitor.8
Phil Sutter032dc4a2019-01-16 22:47:59 +0100235 utils/nfnl_osf.8
236 utils/nfbpf_compile.8])
Jan Engelhardt0086b8b2009-01-07 15:11:59 +0100237AC_OUTPUT
Eric Leblondfe42fac2013-06-05 04:16:25 +0200238
239
240EXPAND_VARIABLE(xtlibdir, e_xtlibdir)
241EXPAND_VARIABLE(pkgconfigdir, e_pkgconfigdir)
242
243echo "
244Iptables Configuration:
245 IPv4 support: ${enable_ipv4}
246 IPv6 support: ${enable_ipv6}
247 Devel support: ${enable_devel}
248 IPQ support: ${enable_libipq}
249 Large file support: ${enable_largefile}
250 BPF utils support: ${enable_bpfc}
Patrick McHardy9e6928f2013-08-28 09:32:44 +0200251 nfsynproxy util support: ${enable_nfsynproxy}
Pablo Neira Ayuso38495862012-09-27 19:12:53 +0200252 nftables support: ${enable_nftables}
Shivani Bhardwaj3b7a2272016-03-22 10:43:06 +0530253 connlabel support: ${enable_connlabel}
Eric Leblondfe42fac2013-06-05 04:16:25 +0200254
255Build parameters:
256 Put plugins into executable (static): ${enable_static}
257 Support plugins via dlopen (shared): ${enable_shared}
258 Installation prefix (--prefix): ${prefix}
259 Xtables extension directory: ${e_xtlibdir}
Lorenzo Colittib91af532017-03-14 17:55:50 +0900260 Pkg-config directory: ${e_pkgconfigdir}
261 Xtables lock file: ${xt_lock_name}"
Eric Leblondfe42fac2013-06-05 04:16:25 +0200262
263if [[ -n "$ksourcedir" ]]; then
264 echo " Kernel source directory: ${ksourcedir}"
265fi;
266if [[ -n "$kbuilddir" ]]; then
267 echo " Kernel build directory: ${kbuilddir}"
268fi;
269
270echo " Host: ${host}
271 GCC binary: ${CC}"
Florian Westphal51340f72013-07-15 16:35:08 +0200272
273test x"$blacklist_modules" = "x" || echo "
274Iptables modules that will not be built: $blacklist_modules"