summaryrefslogtreecommitdiff
path: root/configure.ac
diff options
context:
space:
mode:
Diffstat (limited to 'configure.ac')
-rw-r--r--configure.ac350
1 files changed, 350 insertions, 0 deletions
diff --git a/configure.ac b/configure.ac
new file mode 100644
index 0000000..65a318a
--- /dev/null
+++ b/configure.ac
@@ -0,0 +1,350 @@
+##
+## This file is part of the sigrok project.
+##
+## Copyright (C) 2010 Bert Vermeulen <bert@biot.com>
+##
+## This program is free software: you can redistribute it and/or modify
+## it under the terms of the GNU General Public License as published by
+## the Free Software Foundation, either version 3 of the License, or
+## (at your option) any later version.
+##
+## This program is distributed in the hope that it will be useful,
+## but WITHOUT ANY WARRANTY; without even the implied warranty of
+## MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. See the
+## GNU General Public License for more details.
+##
+## You should have received a copy of the GNU General Public License
+## along with this program. If not, see <http://www.gnu.org/licenses/>.
+##
+
+AC_PREREQ(2.61)
+
+m4_define([sigrok_major_version], [0])
+m4_define([sigrok_minor_version], [2])
+m4_define([sigrok_micro_version], [0])
+m4_define([sigrok_version],
+ [sigrok_major_version.sigrok_minor_version.sigrok_micro_version])
+
+AC_INIT([sigrok], [sigrok_version], [sigrok-devel@lists.sourceforge.net],
+ [sigrok], [http://www.sigrok.org])
+AC_CONFIG_HEADER([config.h])
+AC_CONFIG_MACRO_DIR([m4])
+
+AM_INIT_AUTOMAKE([-Wall -Werror foreign std-options])
+m4_ifdef([AM_SILENT_RULES], [AM_SILENT_RULES([yes])])
+
+AH_TOP([#ifndef SGIROK_CONFIG_H
+#define SIGROK_CONFIG_H /* To stop multiple inclusions. */])
+AH_BOTTOM([#endif /* SIGROK_CONFIG_H */])
+
+CFLAGS="-g -Wall -Wextra"
+
+# Checks for programs.
+AC_PROG_CXX
+AC_PROG_CC
+AC_PROG_CPP
+AC_PROG_INSTALL
+AC_PROG_LN_S
+
+# Initialize libtool.
+LT_INIT
+
+# Initialize pkg-config.
+# We require at least 0.22, as "Requires.private" behaviour changed there.
+PKG_PROG_PKG_CONFIG([0.22])
+
+# Library version for libsigrok.
+# Carefully read the libtool docs before updating these numbers!
+# The algorithm for determining which number to change (and how) is nontrivial!
+# http://www.gnu.org/software/libtool/manual/libtool.html#Updating-version-info
+SIGROK_LT_CURRENT=0
+SIGROK_LT_REVISION=0
+SIGROK_LT_AGE=0
+SIGROK_LT_VERSION="$SIGROK_LT_CURRENT:$SIGROK_LT_REVISION:$SIGROK_LT_AGE"
+SIGROK_LT_LDFLAGS="-version-info $SIGROK_LT_VERSION"
+AC_SUBST(SIGROK_LT_LDFLAGS)
+
+# Library version for libsigrokdecode.
+# Carefully read the libtool docs before updating these numbers!
+# The algorithm for determining which number to change (and how) is nontrivial!
+# http://www.gnu.org/software/libtool/manual/libtool.html#Updating-version-info
+SIGROKDECODE_LT_CURRENT=0
+SIGROKDECODE_LT_REVISION=0
+SIGROKDECODE_LT_AGE=0
+SIGROKDECODE_LT_VERSION="$SIGROKDECODE_LT_CURRENT:$SIGROKDECODE_LT_REVISION:$SIGROKDECODE_LT_AGE"
+SIGROKDECODE_LT_LDFLAGS="-version-info $SIGROKDECODE_LT_VERSION"
+AC_SUBST(SIGROKDECODE_LT_LDFLAGS)
+
+# Logic analyzer hardware support '--enable' options.
+
+# Disabled by default, unfinished.
+AC_ARG_ENABLE(alsa, AC_HELP_STRING([--enable-alsa],
+ [enable ALSA driver support [default=no]]),
+ [LA_ALSA="$enableval"],
+ [LA_ALSA=no])
+AM_CONDITIONAL(LA_ALSA, test x$LA_ALSA = xyes)
+if test "x$LA_ALSA" = "xyes"; then
+ AC_DEFINE(HAVE_LA_ALSA, 1, [ALSA driver support])
+fi
+
+AC_ARG_ENABLE(asix-sigma, AC_HELP_STRING([--enable-asix-sigma],
+ [enable ASIX Sigma support [default=yes]]),
+ [LA_ASIX_SIGMA="$enableval"],
+ [LA_ASIX_SIGMA=yes])
+AM_CONDITIONAL(LA_ASIX_SIGMA, test x$LA_ASIX_SIGMA = xyes)
+if test "x$LA_ASIX_SIGMA" = "xyes"; then
+ AC_DEFINE(HAVE_LA_ASIX_SIGMA, 1, [ASIX Sigma support])
+fi
+
+AC_ARG_ENABLE(chronovu-la8, AC_HELP_STRING([--enable-chronovu-la8],
+ [enable ChronoVu LA8 support [default=yes]]),
+ [LA_CHRONOVU_LA8="$enableval"],
+ [LA_CHRONOVU_LA8=yes])
+AM_CONDITIONAL(LA_CHRONOVU_LA8, test x$LA_CHRONOVU_LA8 = xyes)
+if test "x$LA_CHRONOVU_LA8" = "xyes"; then
+ AC_DEFINE(HAVE_LA_CHRONOVU_LA8, 1, [ChronoVu LA8 support])
+fi
+
+AC_ARG_ENABLE(demo, AC_HELP_STRING([--enable-demo],
+ [enable demo driver support [default=yes]]),
+ [LA_DEMO="$enableval"],
+ [LA_DEMO=yes])
+AM_CONDITIONAL(LA_DEMO, test x$LA_DEMO = xyes)
+if test "x$LA_DEMO" = "xyes"; then
+ AC_DEFINE(HAVE_LA_DEMO, 1, [Demo driver support])
+fi
+
+# Disabled by default, unfinished.
+AC_ARG_ENABLE(link-mso19, AC_HELP_STRING([--enable-link-mso19],
+ [enable Link Instruments MSO-19 support [default=no]]),
+ [LA_LINK_MSO19="$enableval"],
+ [LA_LINK_MSO19=no])
+AM_CONDITIONAL(LA_LINK_MSO19, test x$LA_LINK_MSO19 = xyes)
+if test "x$LA_LINK_MSO19" = "xyes"; then
+ AC_DEFINE(HAVE_LA_LINK_MSO19, 1, [Link Instruments MSO-19 support])
+fi
+
+AC_ARG_ENABLE(ols, AC_HELP_STRING([--enable-ols],
+ [enable OpenBench Logic Sniffer (OLS) support [default=yes]]),
+ [LA_OLS="$enableval"],
+ [LA_OLS=yes])
+AM_CONDITIONAL(LA_OLS, test x$LA_OLS = xyes)
+if test "x$LA_OLS" = "xyes"; then
+ AC_DEFINE(HAVE_LA_OLS, 1, [OpenBench Logic Sniffer (OLS) support])
+fi
+
+AC_ARG_ENABLE(saleae-logic, AC_HELP_STRING([--enable-saleae-logic],
+ [enable Saleae Logic support [default=yes]]),
+ [LA_SALEAE_LOGIC="$enableval"],
+ [LA_SALEAE_LOGIC=yes])
+AM_CONDITIONAL(LA_SALEAE_LOGIC, test x$LA_SALEAE_LOGIC = xyes)
+if test "x$LA_SALEAE_LOGIC" = "xyes"; then
+ AC_DEFINE(HAVE_LA_SALEAE_LOGIC, 1, [Saleae Logic support])
+fi
+
+AC_ARG_ENABLE(zeroplus-logic-cube,
+ AC_HELP_STRING([--enable-zeroplus-logic-cube],
+ [enable Zeroplus Logic Cube support [default=yes]]),
+ [LA_ZEROPLUS_LOGIC_CUBE="$enableval"],
+ [LA_ZEROPLUS_LOGIC_CUBE=yes])
+AM_CONDITIONAL(LA_ZEROPLUS_LOGIC_CUBE, test x$LA_ZEROPLUS_LOGIC_CUBE = xyes)
+if test "x$LA_ZEROPLUS_LOGIC_CUBE" = "xyes"; then
+ AC_DEFINE(HAVE_LA_ZEROPLUS_LOGIC_CUBE, 1, [Zeroplus Logic Cube support])
+fi
+
+# Checks for libraries.
+
+# This variable collects the pkg-config names of all detected libs.
+# It is then used to construct the "Requires.private:" field in the
+# libsigrok.pc file.
+LIBSIGROK_PKGLIBS=""
+
+# libglib-2.0 is always needed.
+# Note: glib-2.0 is part of the libsigrok API (hard pkg-config requirement).
+AM_PATH_GLIB_2_0([2.22.0],
+ [CFLAGS="$CFLAGS $GLIB_CFLAGS"; LIBS="$LIBS $GLIB_LIBS"])
+
+# libgthread-2.0 is always needed (e.g. for the demo hardware driver).
+PKG_CHECK_MODULES([gthread], [gthread-2.0 >= 2.22.0],
+ [CFLAGS="$CFLAGS $gthread_CFLAGS"; LIBS="$LIBS $gthread_LIBS";
+ LIBSIGROK_PKGLIBS="$LIBSIGROK_PKGLIBS gthread-2.0"])
+
+# libusb is only needed for some hardware drivers.
+if test "x$LA_SALEAE_LOGIC" != xno \
+ -o "x$LA_ASIX_SIGMA" != xno \
+ -o "x$LA_CHRONOVU_LA8" != xno \
+ -o "x$LA_ZEROPLUS_LOGIC_CUBE" != xno; then
+ case "$build" in
+ *freebsd*)
+ # FreeBSD comes with an "integrated" libusb-1.0-style USB API.
+ AC_DEFINE_UNQUOTED(HAVE_LIBUSB_1_0, [1],
+ [Specifies whether we have a libusb.h header.])
+ ;;
+ *)
+ PKG_CHECK_MODULES([libusb], [libusb-1.0 >= 1.0.5],
+ [CFLAGS="$CFLAGS $libusb_CFLAGS";
+ LIBS="$LIBS $libusb_LIBS";
+ LIBSIGROK_PKGLIBS="$LIBSIGROK_PKGLIBS libusb-1.0"])
+ AC_CHECK_LIB(usb-1.0, libusb_init)
+ ;;
+ esac
+fi
+
+# libzip is always needed.
+PKG_CHECK_MODULES([libzip], [libzip >= 0.8],
+ [CFLAGS="$CFLAGS $libzip_CFLAGS"; LIBS="$LIBS $libzip_LIBS";
+ LIBSIGROK_PKGLIBS="$LIBSIGROK_PKGLIBS libzip"])
+
+# zlib is only needed for some hardware drivers.
+if test "x$LA_ASIX_SIGMA" != xno; then
+ PKG_CHECK_MODULES([zlib], [zlib >= 1.2.3.1],
+ [CFLAGS="$CFLAGS $zlib_CFLAGS"; LIBS="$LIBS $zlib_LIBS";
+ LIBSIGROK_PKGLIBS="$LIBSIGROK_PKGLIBS zlib"])
+fi
+
+# libftdi is only needed for some hardware drivers.
+if test "x$LA_ASIX_SIGMA" != xno \
+ -o "x$LA_CHRONOVU_LA8" != xno; then
+ PKG_CHECK_MODULES([libftdi], [libftdi >= 0.16],
+ [CFLAGS="$CFLAGS $libftdi_CFLAGS";
+ LIBS="$LIBS $libftdi_LIBS";
+ LIBSIGROK_PKGLIBS="$LIBSIGROK_PKGLIBS libftdi"])
+fi
+
+# libudev is only needed for some hardware drivers.
+if test "x$LA_LINK_MSO19" != xno; then
+ PKG_CHECK_MODULES([libudev], [libudev >= 151],
+ [CFLAGS="$CFLAGS $libudev_CFLAGS"; LIBS="$LIBS $libudev_LIBS";
+ LIBSIGROK_PKGLIBS="$LIBSIGROK_PKGLIBS libudev"])
+fi
+
+# ALSA is only needed for some hardware drivers.
+if test "x$LA_ALSA" != xno; then
+ PKG_CHECK_MODULES([alsa], [alsa >= 1.0],
+ [CFLAGS="$CFLAGS $alsa_CFLAGS"; LIBS="$LIBS $alsa_LIBS";
+ LIBSIGROK_PKGLIBS="$LIBSIGROK_PKGLIBS alsa"])
+fi
+
+# Python support.
+CPPFLAGS_PYTHON=""
+LDFLAGS_PYTHON=""
+case "$build" in
+*linux*)
+ # We know that Linux has 'python3-config'.
+ CPPFLAGS_PYTHON="$(python3-config --includes)"
+ LDFLAGS_PYTHON="$(python3-config --ldflags)"
+ ;;
+*darwin*)
+ # On Darwin, Macports has python3.x-config, fink has python3-config.
+ # Mac OS X (Snow Leopard) ships with 'python-config' per default, but
+ # that's Python 2.x, so not useful for us.
+ if test -x python3-config; then
+ # python3-config exists, use it.
+ CPPFLAGS_PYTHON="$(python3-config --includes)"
+ LDFLAGS_PYTHON="$(python3-config --ldflags)"
+ else
+ # No python3-config found, so try hardcoded python3.2-config.
+ CPPFLAGS_PYTHON="$(python3.2-config --includes)"
+ LDFLAGS_PYTHON="$(python3.2-config --ldflags)"
+ fi
+ ;;
+*mingw*)
+ # We currently hardcode the paths to the Python 3.2 default install
+ # location as there's no 'python-config' script on Windows, it seems.
+ CPPFLAGS_PYTHON="-I/c/Python32/include"
+ LDFLAGS_PYTHON="-L/c/Python32/libs -lpython32"
+ ;;
+*)
+ # Everything else is untested, we just hope 'python3-config' works.
+ CPPFLAGS_PYTHON="$(python3-config --includes)"
+ LDFLAGS_PYTHON="$(python3-config --ldflags)"
+ ;;
+esac
+AC_SUBST(CPPFLAGS_PYTHON)
+AC_SUBST(LDFLAGS_PYTHON)
+
+AC_SUBST(LIBSIGROK_PKGLIBS)
+
+# Checks for header files.
+# These are already checked: inttypes.h stdint.h stdlib.h string.h unistd.h.
+AC_CHECK_HEADERS([fcntl.h sys/time.h termios.h])
+
+# Checks for typedefs, structures, and compiler characteristics.
+AC_C_INLINE
+AC_TYPE_INT8_T
+AC_TYPE_INT16_T
+AC_TYPE_INT32_T
+AC_TYPE_INT64_T
+AC_TYPE_UINT8_T
+AC_TYPE_UINT16_T
+AC_TYPE_UINT32_T
+AC_TYPE_UINT64_T
+AC_TYPE_SIZE_T
+
+# Checks for library functions.
+AC_CHECK_FUNCS([gettimeofday memset strchr strcspn strdup strerror strncasecmp strstr strtol strtoul strtoull])
+
+AC_SUBST(FIRMWARE_DIR, "$datadir/sigrok/firmware")
+AC_SUBST(DECODERS_DIR, "$datadir/sigrok/decoders")
+AC_SUBST(MAKEFLAGS, '--no-print-directory')
+AC_SUBST(AM_LIBTOOLFLAGS, '--silent')
+
+SIGROK_MAJOR_VERSION=sigrok_major_version
+SIGROK_MINOR_VERSION=sigrok_minor_version
+SIGROK_MICRO_VERSION=sigrok_micro_version
+SIGROK_VERSION=sigrok_version
+
+AC_SUBST(SIGROK_MAJOR_VERSION)
+AC_SUBST(SIGROK_MINOR_VERSION)
+AC_SUBST(SIGROK_MICRO_VERSION)
+AC_SUBST(SIGROK_VERSION)
+
+AC_DEFINE(SIGROK_MAJOR_VERSION, [sigrok_major_version],
+ [Define to the sigrok major version])
+AC_DEFINE(SIGROK_MINOR_VERSION, [sigrok_minor_version],
+ [Define to the sigrok minor version])
+AC_DEFINE(SIGROK_MICRO_VERSION, [sigrok_micro_version],
+ [Define to the sigrok micro version])
+AC_DEFINE(SIGROK_VERSION, [sigrok_version],
+ [Define to the sigrok version])
+
+AC_CONFIG_FILES([Makefile
+ contrib/Makefile
+ contrib/nsis/Makefile
+ contrib/nsis/sigrok.nsi
+ libsigrok/Makefile
+ libsigrok/sigrok.h
+ libsigrok/firmware/Makefile
+ libsigrok/hardware/Makefile
+ libsigrok/hardware/alsa/Makefile
+ libsigrok/hardware/asix-sigma/Makefile
+ libsigrok/hardware/chronovu-la8/Makefile
+ libsigrok/hardware/common/Makefile
+ libsigrok/hardware/demo/Makefile
+ libsigrok/hardware/link-mso19/Makefile
+ libsigrok/hardware/openbench-logic-sniffer/Makefile
+ libsigrok/hardware/saleae-logic/Makefile
+ libsigrok/hardware/zeroplus-logic-cube/Makefile
+ libsigrok/input/Makefile
+ libsigrok/output/Makefile
+ libsigrok/output/text/Makefile
+ libsigrok/libsigrok.pc
+ libsigrok/contrib/Makefile
+ libsigrokdecode/Makefile
+ libsigrokdecode/libsigrokdecode.pc
+ libsigrokdecode/decoders/Makefile
+ ])
+
+AC_OUTPUT
+
+echo
+echo "Building drivers:"
+echo
+echo "ASIX SIGMA...................... " $LA_ASIX_SIGMA
+echo "ChronoVu LA8.................... " $LA_CHRONOVU_LA8
+echo "Link MSO-19..................... " $LA_LINK_MSO19
+echo "Openbench Logic Sniffer......... " $LA_OLS
+echo "Saleae Logic.................... " $LA_SALEAE_LOGIC
+echo "Zeroplus Logic Cube............. " $LA_ZEROPLUS_LOGIC_CUBE
+echo
+