summaryrefslogtreecommitdiffstats
path: root/configure.ac
diff options
context:
space:
mode:
Diffstat (limited to 'configure.ac')
-rw-r--r--configure.ac334
1 files changed, 334 insertions, 0 deletions
diff --git a/configure.ac b/configure.ac
new file mode 100644
index 0000000..2594b39
--- /dev/null
+++ b/configure.ac
@@ -0,0 +1,334 @@
+# iperf, Copyright (c) 2014-2023, The Regents of the University of
+# California, through Lawrence Berkeley National Laboratory (subject
+# to receipt of any required approvals from the U.S. Dept. of
+# Energy). All rights reserved.
+#
+# If you have questions about your rights to use or distribute this
+# software, please contact Berkeley Lab's Technology Transfer
+# Department at TTD@lbl.gov.
+#
+# NOTICE. This software is owned by the U.S. Department of Energy.
+# As such, the U.S. Government has been granted for itself and others
+# acting on its behalf a paid-up, nonexclusive, irrevocable,
+# worldwide license in the Software to reproduce, prepare derivative
+# works, and perform publicly and display publicly. Beginning five
+# (5) years after the date permission to assert copyright is obtained
+# from the U.S. Department of Energy, and subject to any subsequent
+# five (5) year renewals, the U.S. Government is granted for itself
+# and others acting on its behalf a paid-up, nonexclusive,
+# irrevocable, worldwide license in the Software to reproduce,
+# prepare derivative works, distribute copies to the public, perform
+# publicly and display publicly, and to permit others to do so.
+#
+# This code is distributed under a BSD style license, see the LICENSE
+# file for complete information.
+
+# Initialize the autoconf system for the specified tool, version and mailing list
+AC_PREREQ([2.71])
+AC_INIT([iperf],[3.16],[https://github.com/esnet/iperf],[iperf],[https://software.es.net/iperf/])
+m4_include([config/ax_check_openssl.m4])
+m4_include([config/ax_pthread.m4])
+m4_include([config/iperf_config_static_bin.m4])
+AC_LANG(C)
+
+# Specify where the auxiliary files created by configure should go. The config
+# directory is picked so that they don't clutter up more useful directories.
+AC_CONFIG_AUX_DIR(config)
+
+
+# Initialize the automake system
+AM_INIT_AUTOMAKE([foreign])
+m4_ifdef([AM_SILENT_RULES], [AM_SILENT_RULES([yes])])
+LT_INIT
+
+AM_MAINTAINER_MODE
+AC_CONFIG_HEADERS(src/iperf_config.h)
+
+AC_CANONICAL_HOST
+
+# Checks for tools: c compiler, ranlib (used for creating static libraries),
+# symlinks and libtool
+AC_PROG_CC
+AC_PROG_LN_S
+
+# Add -Wall if we are using GCC.
+if test "x$GCC" = "xyes"; then
+ CFLAGS="$CFLAGS -Wall"
+fi
+
+# Check if enable profiling
+AC_ARG_ENABLE([profiling],
+ AS_HELP_STRING([--enable-profiling], [Enable iperf3 profiling binary]))
+AM_CONDITIONAL([ENABLE_PROFILING], [test x$enable_profiling = xyes])
+
+# Check for the math library (needed by cjson on some platforms)
+AC_SEARCH_LIBS(floor, [m], [], [
+echo "floor()"
+exit 1
+])
+
+# On illumos we need -lsocket
+AC_SEARCH_LIBS(socket, [socket], [], [
+echo "socket()"
+exit 1
+])
+
+# On illumos inet_ntop in in -lnsl
+AC_SEARCH_LIBS(inet_ntop, [nsl], [], [
+echo "inet_ntop()"
+exit 1
+])
+
+# Checks for typedefs, structures, and compiler characteristics.
+AC_C_CONST
+
+AX_PTHREAD(
+[AC_DEFINE([HAVE_PTHREAD],[1],[Define if you have POSIX threads libraries and header files.])
+LIBS="$PTHREAD_LIBS $LIBS"
+CFLAGS="$CFLAGS $PTHREAD_CFLAGS"
+CXXFLAGS="$CXXFLAGS $PTHREAD_CFLAGS"
+CC="$PTHREAD_CC"
+CXX="$PTHREAD_CXX"
+])
+
+# Atomics
+AC_CHECK_HEADERS([stdatomic.h])
+
+# Check for poll.h (it's in POSIX so everyone should have it?)
+AC_CHECK_HEADERS([poll.h])
+
+# SCTP. Allow user to disable SCTP support with --without-sctp.
+# Otherwise we try to find whatever support is required.
+try_sctp=true
+AC_ARG_WITH([sctp],
+ [AS_HELP_STRING([--without-sctp],
+ [disable SCTP])],
+ [
+ case "$withval" in
+ y | ye | yes)
+ ;;
+ n | no)
+ try_sctp=false
+ ;;
+ *)
+ AC_MSG_ERROR([Invalid --with-sctp value])
+ ;;
+ esac
+ ], [
+ try_sctp=true
+ ]
+)
+
+AC_CHECK_HEADERS([linux/tcp.h])
+
+# Check for SCTP support
+if $try_sctp; then
+AC_CHECK_HEADERS([sys/socket.h])
+AC_CHECK_HEADERS([netinet/sctp.h],
+ AC_DEFINE([HAVE_SCTP_H], [1], [Have SCTP support.])
+ AC_SEARCH_LIBS(sctp_bindx, [sctp])
+ AC_CHECK_TYPES([struct sctp_assoc_value], [], [],
+ [[#include <netinet/sctp.h>]]),
+ [],
+ [#ifdef HAVE_SYS_SOCKET_H
+#include <sys/socket.h>
+#endif
+])
+fi
+
+AC_CHECK_HEADER([endian.h],
+ AC_DEFINE([HAVE_ENDIAN_H], [1], [Define to 1 if you have the <endian.h> header file.]),
+ AC_CHECK_HEADER([sys/endian.h],
+ AC_DEFINE([HAVE_SYS_ENDIAN_H], [1], [Define to 1 if you have the <sys/endian.h> header file.]),
+ AC_MSG_WARN([Couldn't find endian.h or sys/endian.h files: doing compile-time tests.])
+ )
+ )
+
+if test "x$with_openssl" = "xno"; then
+ AC_MSG_WARN( [Building without OpenSSL; disabling iperf_auth functionality.] )
+else
+ # Check for OPENSSL support
+ have_ssl=false
+ AX_CHECK_OPENSSL(
+ [ AC_DEFINE([HAVE_SSL], [1], [OpenSSL Is Available])
+ have_ssl=true ],
+ [ if test "x$with_openssl" != "x"; then
+ AC_MSG_FAILURE([--with-openssl was given, but test for OpenSSL failed])
+ fi ]
+ )
+ if $have_ssl; then
+ case $host in
+ *-*-cygwin)
+ CFLAGS="$CFLAGS -DNOCRYPT"
+ ;;
+ esac
+ LDFLAGS="$LDFLAGS $OPENSSL_LDFLAGS"
+ LIBS="$OPENSSL_LIBS $LIBS"
+ CPPFLAGS="$OPENSSL_INCLUDES $CPPFLAGS"
+ fi
+fi
+
+# Check for TCP_CONGESTION sockopt (believed to be Linux and FreeBSD only)
+AC_CACHE_CHECK([TCP_CONGESTION socket option],
+[iperf3_cv_header_tcp_congestion],
+AC_COMPILE_IFELSE(
+ [AC_LANG_PROGRAM([[#include <netinet/tcp.h>]],
+ [[int foo = TCP_CONGESTION;]])],
+ iperf3_cv_header_tcp_congestion=yes,
+ iperf3_cv_header_tcp_congestion=no))
+if test "x$iperf3_cv_header_tcp_congestion" = "xyes"; then
+ AC_DEFINE([HAVE_TCP_CONGESTION], [1], [Have TCP_CONGESTION sockopt.])
+fi
+
+# Check for TCP_USER_TIMEOUT sockopt (believed to be Linux 2.6.37+ only)
+AC_CACHE_CHECK([TCP_USER_TIMEOUT socket option],
+[iperf3_cv_header_tcp_user_timeout],
+AC_COMPILE_IFELSE(
+ [AC_LANG_PROGRAM([[#include <netinet/tcp.h>]],
+ [[int foo = TCP_USER_TIMEOUT;]])],
+ iperf3_cv_header_tcp_user_timeout=yes,
+ iperf3_cv_header_tcp_user_timeout=no))
+if test "x$iperf3_cv_header_tcp_user_timeout" = "xyes"; then
+ AC_DEFINE([HAVE_TCP_USER_TIMEOUT], [1], [Have TCP_USER_TIMEOUT sockopt.])
+fi
+
+# Check for IPv6 flowlabel support (believed to be Linux only)
+# We check for IPV6_FLOWLABEL_MGR in <linux/in6.h> even though we
+# don't use that file directly (we have our own stripped-down
+# copy, see src/flowlabel.h for more details).
+AC_CACHE_CHECK([IPv6 flowlabel support],
+[iperf3_cv_header_flowlabel],
+AC_COMPILE_IFELSE(
+ [AC_LANG_PROGRAM([[#include <sys/types.h>
+ #include <linux/in6.h>]],
+ [[int foo = IPV6_FLOWLABEL_MGR;]])],
+ iperf3_cv_header_flowlabel=yes,
+ iperf3_cv_header_flowlabel=no))
+if test "x$iperf3_cv_header_flowlabel" = "xyes"; then
+ AC_DEFINE([HAVE_FLOWLABEL], [1], [Have IPv6 flowlabel support.])
+fi
+
+# Check for CPU affinity support. FreeBSD and Linux do this differently
+# unfortunately so we have to check separately for each of them.
+# FreeBSD uses cpuset_setaffinity while Linux uses sched_setaffinity.
+# Define HAVE_CPU_AFFINITY to indicate the CPU affinity setting as a
+# generic concept is available.
+AC_CHECK_FUNCS([cpuset_setaffinity sched_setaffinity SetProcessAffinityMask],
+ AC_DEFINE([HAVE_CPU_AFFINITY], [1],
+ [Have CPU affinity support.]))
+
+# Check for daemon(). Most systems have this but a few (IRIX) don't.
+AC_CHECK_FUNCS([daemon])
+
+# Check for sendfile support. FreeBSD, Linux, and MacOS all support
+# this system call, but they're all different in terms of what headers
+# it needs and what arguments it expects.
+AC_CHECK_FUNCS([sendfile])
+
+# Check for getline support, used as a part of authenticated
+# connections.
+AC_CHECK_FUNCS([getline])
+
+# Check for packet pacing socket option (Linux only for now).
+AC_CACHE_CHECK([SO_MAX_PACING_RATE socket option],
+[iperf3_cv_header_so_max_pacing_rate],
+AC_COMPILE_IFELSE(
+ [AC_LANG_PROGRAM([[#include <sys/socket.h>]],
+ [[int foo = SO_MAX_PACING_RATE;]])],
+ iperf3_cv_header_so_max_pacing_rate=yes,
+ iperf3_cv_header_so_max_pacing_rate=no))
+if test "x$iperf3_cv_header_so_max_pacing_rate" = "xyes"; then
+ AC_DEFINE([HAVE_SO_MAX_PACING_RATE], [1], [Have SO_MAX_PACING_RATE sockopt.])
+fi
+
+# Check for SO_BINDTODEVICE sockopt (believed to be Linux only)
+AC_CACHE_CHECK([SO_BINDTODEVICE socket option],
+[iperf3_cv_header_so_bindtodevice],
+AC_COMPILE_IFELSE(
+ [AC_LANG_PROGRAM([[#include <sys/socket.h>]],
+ [[int foo = SO_BINDTODEVICE;]])],
+ iperf3_cv_header_so_bindtodevice=yes,
+ iperf3_cv_header_so_bindtodevice=no))
+if test "x$iperf3_cv_header_so_bindtodevice" = "xyes"; then
+ AC_DEFINE([HAVE_SO_BINDTODEVICE], [1], [Have SO_BINDTODEVICE sockopt.])
+fi
+
+# Check for IP_MTU_DISCOVER (mostly on Linux)
+AC_CACHE_CHECK([IP_MTU_DISCOVER socket option],
+[iperf3_cv_header_ip_mtu_discover],
+AC_COMPILE_IFELSE(
+ [AC_LANG_PROGRAM([[#include <sys/types.h>
+ #include <sys/socket.h>
+ #include <netinet/in.h>]],
+ [[int foo = IP_MTU_DISCOVER;]])],
+ iperf3_cv_header_ip_mtu_discover=yes,
+ iperf3_cv_header_ip_mtu_discover=no))
+if test "x$iperf3_cv_header_ip_mtu_discover" = "xyes"; then
+ AC_DEFINE([HAVE_IP_MTU_DISCOVER], [1], [Have IP_MTU_DISCOVER sockopt.])
+fi
+
+# Check for IP_DONTFRAG (BSD?)
+AC_CACHE_CHECK([IP_DONTFRAG socket option],
+[iperf3_cv_header_ip_dontfrag],
+AC_COMPILE_IFELSE(
+ [AC_LANG_PROGRAM([[#include <sys/types.h>
+ #include <sys/socket.h>
+ #include <netinet/in.h>]],
+ [[int foo = IP_DONTFRAG;]])],
+ iperf3_cv_header_ip_dontfrag=yes,
+ iperf3_cv_header_ip_dontfrag=no))
+if test "x$iperf3_cv_header_ip_dontfrag" = "xyes"; then
+ AC_DEFINE([HAVE_IP_DONTFRAG], [1], [Have IP_DONTFRAG sockopt.])
+fi
+
+# Check for IP_DONTFRAGMENT (Windows?)
+AC_CACHE_CHECK([IP_DONTFRAGMENT socket option],
+[iperf3_cv_header_ip_dontfragment],
+AC_COMPILE_IFELSE(
+ [AC_LANG_PROGRAM([[#include <sys/types.h>
+ #include <sys/socket.h>
+ #include <netinet/in.h>]],
+ [[int foo = IP_DONTFRAGMENT;]])],
+ iperf3_cv_header_ip_dontfragment=yes,
+ iperf3_cv_header_ip_dontfragment=no))
+if test "x$iperf3_cv_header_ip_dontfragment" = "xyes"; then
+ AC_DEFINE([HAVE_IP_DONTFRAGMENT], [1], [Have IP_DONTFRAGMENT sockopt.])
+fi
+
+# Check for IP DF support
+AC_CACHE_CHECK([any kind of DF socket option],
+[iperf3_cv_header_dontfragment],
+[if test "x$iperf3_cv_header_ip_mtu_discover" = "xyes" -o "x$iperf3_cv_header_ip_dontfrag" = "xyes" -o "x$iperf3_cv_header_ip_dontfragment" = "xyes"; then
+ iperf3_cv_header_dontfragment=yes
+else
+ iperf3_cv_header_dontfragment=no
+fi])
+
+if test "x$iperf3_cv_header_dontfragment" = "xyes"; then
+ AC_DEFINE([HAVE_DONT_FRAGMENT], [1], [Have IP_MTU_DISCOVER/IP_DONTFRAG/IP_DONTFRAGMENT sockopt.])
+fi
+
+#
+# Check for tcpi_snd_wnd in struct tcp_info
+#
+AC_CHECK_MEMBER([struct tcp_info.tcpi_snd_wnd],
+[iperf3_cv_header_tcp_info_snd_wnd=yes], [iperf3_cv_header_tcp_info_snd_wnd=no],
+[#ifdef HAVE_LINUX_TCP_H
+#include <linux/tcp.h>
+#else
+#include <sys/types.h>
+#include <netinet/tcp.h>
+#endif
+])
+
+if test "x$iperf3_cv_header_tcp_info_snd_wnd" = "xyes"; then
+ AC_DEFINE([HAVE_TCP_INFO_SND_WND], [1], [Have tcpi_snd_wnd field in tcp_info.])
+fi
+
+# Check if we need -lrt for clock_gettime
+AC_SEARCH_LIBS(clock_gettime, [rt posix4])
+# Check for clock_gettime support
+AC_CHECK_FUNCS([clock_gettime])
+
+AC_CONFIG_FILES([Makefile src/Makefile src/version.h examples/Makefile iperf3.spec])
+AC_OUTPUT