2012-10-17 04:58:07 +08:00
#
2010-02-03 21:21:48 +08:00
# This file is part of systemd.
#
2012-04-04 03:24:46 +08:00
# Copyright 2010-2012 Lennart Poettering
# Copyright 2010-2012 Kay Sievers
2010-02-03 21:21:48 +08:00
#
# systemd is free software; you can redistribute it and/or modify it
2012-04-12 06:20:58 +08:00
# under the terms of the GNU Lesser General Public License as published by
# the Free Software Foundation; either version 2.1 of the License, or
2010-02-03 21:21:48 +08:00
# (at your option) any later version.
#
# systemd 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
2012-04-12 06:20:58 +08:00
# Lesser General Public License for more details.
2010-02-03 21:21:48 +08:00
#
2012-04-12 06:20:58 +08:00
# You should have received a copy of the GNU Lesser General Public License
2010-02-03 21:21:48 +08:00
# along with systemd; If not, see <http://www.gnu.org/licenses/>.
2011-11-22 01:18:33 +08:00
AC_PREREQ([2.64])
AC_INIT([systemd],
2014-10-28 22:29:49 +08:00
[217],
2011-11-22 01:18:33 +08:00
[http://bugs.freedesktop.org/enter_bug.cgi?product=systemd],
[systemd],
[http://www.freedesktop.org/wiki/Software/systemd])
2010-02-03 21:21:48 +08:00
2012-04-12 18:58:55 +08:00
AC_CONFIG_SRCDIR([src/core/main.c])
2010-02-03 21:21:48 +08:00
AC_CONFIG_MACRO_DIR([m4])
AC_CONFIG_HEADERS([config.h])
2011-10-03 06:31:59 +08:00
AC_CONFIG_AUX_DIR([build-aux])
2011-04-26 04:00:12 +08:00
AC_USE_SYSTEM_EXTENSIONS
2011-04-26 03:50:42 +08:00
AC_SYS_LARGEFILE
2012-01-05 10:42:48 +08:00
AC_PREFIX_DEFAULT([/usr])
2013-11-13 16:47:57 +08:00
AM_MAINTAINER_MODE([enable])
2014-06-11 18:00:47 +08:00
AM_INIT_AUTOMAKE([foreign 1.11 -Wall -Wno-portability silent-rules tar-pax no-dist-gzip dist-xz subdir-objects])
2012-04-04 03:24:46 +08:00
AM_SILENT_RULES([yes])
2010-02-03 21:21:48 +08:00
AC_CANONICAL_HOST
2010-09-23 21:01:41 +08:00
AC_DEFINE_UNQUOTED([CANONICAL_HOST], "$host", [Canonical host string.])
2011-03-17 10:13:01 +08:00
AS_IF([test "x$host_cpu" = "xmips" || test "x$host_cpu" = "xmipsel" ||
test "x$host_cpu" = "xmips64" || test "x$host_cpu" = "xmips64el"],
[AC_DEFINE(ARCH_MIPS, [], [Whether on mips arch])])
2010-02-03 21:21:48 +08:00
2012-04-04 03:24:46 +08:00
LT_PREREQ(2.2)
2013-01-08 06:48:21 +08:00
LT_INIT([disable-static])
2010-02-03 21:21:48 +08:00
2013-06-05 02:42:56 +08:00
AS_IF([test "x$enable_static" = "xyes"], [AC_MSG_ERROR([--enable-static is not supported by systemd])])
2013-06-06 16:38:31 +08:00
AS_IF([test "x$enable_largefile" = "xno"], [AC_MSG_ERROR([--disable-largefile is not supported by systemd])])
2013-06-05 02:42:56 +08:00
2011-07-12 00:01:28 +08:00
# i18n stuff for the PolicyKit policy files
2014-06-25 14:06:46 +08:00
# Check whether intltool can be found, disable NLS otherwise
AC_CHECK_PROG(intltool_found, [intltool-merge], [yes], [no])
AS_IF([test x"$intltool_found" != xyes],
[AS_IF([test x"$enable_nls" = xyes],
[AC_MSG_ERROR([--enable-nls requested but intltool not found])],
[AS_IF([test x"$enable_nls" != xno],
[AC_MSG_WARN([*** Disabling NLS support because intltool was not found])
enable_nls=no])
])
])
2014-06-25 14:06:45 +08:00
AM_NLS
2014-07-31 20:18:59 +08:00
AS_IF([test x"$enable_nls" != xno -o "x$enable_polkit" != xno], [
2014-06-25 14:06:45 +08:00
# intltoolize greps for '^(AC|IT)_PROG_INTLTOOL', so it needs to be on its own line
2011-07-12 00:01:28 +08:00
IT_PROG_INTLTOOL([0.40.0])
2014-06-25 14:06:45 +08:00
])
AS_IF([test -z "$INTLTOOL_POLICY_RULE"], [
# If intltool is not available, provide a dummy rule to fail generation of %.policy files with a meaningful error message
INTLTOOL_POLICY_RULE='%.policy: %.policy.in ; @echo " ITMRG " $@ && echo "*** intltool support required to build target $@" && false'
AC_SUBST(INTLTOOL_POLICY_RULE)
])
2011-07-12 00:01:28 +08:00
GETTEXT_PACKAGE=systemd
AC_SUBST(GETTEXT_PACKAGE)
2010-05-17 00:34:31 +08:00
AC_PROG_MKDIR_P
AC_PROG_LN_S
AC_PROG_SED
2012-02-13 08:46:44 +08:00
AC_PROG_GREP
2011-08-01 06:43:05 +08:00
AC_PROG_AWK
2010-05-17 00:34:31 +08:00
2010-02-03 21:21:48 +08:00
AC_PROG_CC_C99
2012-04-04 03:24:46 +08:00
AC_PATH_PROG([M4], [m4])
2012-08-25 07:57:03 +08:00
AC_PATH_PROG([XSLTPROC], [xsltproc])
2012-04-17 22:17:27 +08:00
2014-03-08 15:49:29 +08:00
AC_PATH_PROG([QUOTAON], [quotaon], [/usr/sbin/quotaon], [$PATH:/usr/sbin:/sbin])
AC_PATH_PROG([QUOTACHECK], [quotacheck], [/usr/sbin/quotacheck], [$PATH:/usr/sbin:/sbin])
2012-09-03 05:28:30 +08:00
2014-03-08 15:49:29 +08:00
AC_PATH_PROG([KILL], [kill], [/usr/bin/kill], [$PATH:/usr/sbin:/sbin])
2012-10-10 04:25:32 +08:00
2014-03-08 15:49:29 +08:00
AC_PATH_PROG([KMOD], [kmod], [/usr/bin/kmod], [$PATH:/usr/sbin:/sbin])
2013-06-15 04:56:39 +08:00
2014-03-08 15:49:29 +08:00
AC_PATH_PROG([KEXEC], [kexec], [/usr/sbin/kexec], [$PATH:/usr/sbin:/sbin])
2013-07-16 11:04:52 +08:00
2014-05-16 22:51:42 +08:00
AS_IF([! ln --relative --help > /dev/null 2>&1], [AC_MSG_ERROR([*** ln doesn't support --relative ***])])
2013-12-28 01:08:04 +08:00
M4_DEFINES=
2012-04-17 23:03:38 +08:00
# gtkdocize greps for '^GTK_DOC_CHECK', so it needs to be on its own line
2013-05-15 10:23:00 +08:00
m4_ifdef([GTK_DOC_CHECK], [
GTK_DOC_CHECK([1.18],[--flavour no-tmpl])],
2013-05-15 10:10:44 +08:00
[AM_CONDITIONAL([ENABLE_GTK_DOC], [false])
enable_gtk_doc=no])
2012-04-17 22:17:27 +08:00
2012-08-25 07:57:03 +08:00
AS_IF([test "x$enable_gtk_doc" = "xyes" -a "x$XSLTPROC" = x], [
AC_MSG_ERROR([*** GTK doc requested but xsltproc not found])
])
2012-05-15 21:05:36 +08:00
m4_ifdef([GOBJECT_INTROSPECTION_CHECK], [
2012-04-13 18:49:51 +08:00
GOBJECT_INTROSPECTION_CHECK([1.31.1])
2013-01-05 11:52:32 +08:00
], [
AM_CONDITIONAL([HAVE_INTROSPECTION], [false])
enable_introspection=no])
2012-04-04 03:24:46 +08:00
2013-04-16 20:26:30 +08:00
AC_CHECK_TOOL(STRINGS, strings)
AC_CHECK_TOOL(GPERF, gperf)
2011-08-03 23:09:55 +08:00
if test -z "$GPERF" ; then
AC_MSG_ERROR([*** gperf not found])
fi
2010-11-24 04:12:11 +08:00
2013-09-26 16:31:44 +08:00
# ------------------------------------------------------------------------------
address_sanitizer_cflags=
address_sanitizer_cppflags=
address_sanitizer_ldflags=
AC_ARG_ENABLE(address-sanitizer, AS_HELP_STRING([--enable-address-sanitizer], [enable -fsanitize=address]))
AS_IF([test "x$enable_address_sanitizer" = "xyes"], [
CC_CHECK_FLAG_APPEND([with_as_cflags], [CFLAGS], [-fsanitize=address])
AS_IF([test -z "$with_as_cflags"],
[AC_MSG_ERROR([*** -fsanitize=address is not supported])])
address_sanitizer_cflags="$with_as_cflags -fno-omit-frame-pointer -DVALGRIND=1"
address_sanitizer_cppflags="-DVALGRIND=1"
address_sanitizer_ldflags="-Wc,-fsanitize=address"
])
2014-04-25 02:49:15 +08:00
undefined_sanitizer_cflags=
undefined_sanitizer_cppflags=
undefined_sanitizer_ldflags=
AC_ARG_ENABLE(undefined-sanitizer, AS_HELP_STRING([--enable-undefined-sanitizer], [enable -fsanitize=undefined]))
AS_IF([test "x$enable_undefined_sanitizer" = "xyes"], [
CC_CHECK_FLAG_APPEND([with_us_cflags], [CFLAGS], [-fsanitize=undefined])
AS_IF([test -z "$with_us_cflags"],
[AC_MSG_ERROR([*** -fsanitize=undefined is not supported])])
undefined_sanitizer_cflags="$with_us_cflags -fno-omit-frame-pointer -DVALGRIND=1"
undefined_sanitizer_cppflags="-DVALGRIND=1"
undefined_sanitizer_ldflags="-Wc,-fsanitize=undefined"
])
sanitizer_cflags="$address_sanitizer_cflags $undefined_sanitizer_cflags"
sanitizer_cppflags="$address_sanitizer_cppflags $undefined_sanitizer_cppflags"
sanitizer_ldflags="$address_sanitizer_ldflags $undefined_sanitizer_ldflags"
2012-03-20 00:20:42 +08:00
CC_CHECK_FLAGS_APPEND([with_cflags], [CFLAGS], [\
2010-06-18 05:41:21 +08:00
-pipe \
2010-05-16 05:06:41 +08:00
-Wall \
-Wextra \
2010-07-09 10:46:49 +08:00
-Wno-inline \
2010-05-16 05:06:41 +08:00
-Wundef \
2013-01-23 01:10:55 +08:00
"-Wformat=2 -Wformat-security -Wformat-nonliteral" \
2010-05-16 05:06:41 +08:00
-Wlogical-op \
-Wsign-compare \
-Wmissing-include-dirs \
-Wold-style-definition \
-Wpointer-arith \
-Winit-self \
2013-11-29 09:09:58 +08:00
-Wdeclaration-after-statement \
2010-05-16 05:06:41 +08:00
-Wfloat-equal \
2013-12-26 00:46:45 +08:00
-Wsuggest-attribute=noreturn \
2010-05-16 05:06:41 +08:00
-Wmissing-prototypes \
-Wstrict-prototypes \
-Wredundant-decls \
-Wmissing-declarations \
-Wmissing-noreturn \
-Wshadow \
-Wendif-labels \
-Wstrict-aliasing=2 \
-Wwrite-strings \
2010-06-18 05:41:21 +08:00
-Wno-long-long \
-Wno-overlength-strings \
2010-05-16 05:06:41 +08:00
-Wno-unused-parameter \
2010-06-18 05:41:21 +08:00
-Wno-missing-field-initializers \
2010-06-18 05:47:59 +08:00
-Wno-unused-result \
2012-01-16 07:23:59 +08:00
-Werror=overflow \
2013-12-16 11:43:42 +08:00
-Wdate-time \
2013-12-26 00:46:45 +08:00
-Wnested-externs \
2010-06-18 05:41:21 +08:00
-ffast-math \
2010-05-16 05:06:41 +08:00
-fno-common \
-fdiagnostics-show-option \
2010-10-06 03:45:51 +08:00
-fno-strict-aliasing \
-fvisibility=hidden \
-ffunction-sections \
2012-08-08 18:03:34 +08:00
-fdata-sections \
2012-08-08 18:26:53 +08:00
-fstack-protector \
2014-04-12 09:57:02 +08:00
-fstack-protector-strong \
2014-05-18 23:46:42 +08:00
-fPIE \
2012-08-08 18:26:53 +08:00
--param=ssp-buffer-size=4])
2014-10-10 11:25:01 +08:00
AS_CASE([$CC], [*clang*],
[CC_CHECK_FLAGS_APPEND([with_cppflags], [CPPFLAGS], [\
2014-10-10 11:30:45 +08:00
-Wno-typedef-redefinition \
-Wno-gnu-variable-sized-type-not-at-end \
])])
2014-10-10 11:25:01 +08:00
2013-11-22 04:56:18 +08:00
AS_CASE([$CFLAGS], [*-O[[12345\ ]]*],
[CC_CHECK_FLAGS_APPEND([with_cflags], [CFLAGS], [\
2014-06-04 23:45:42 +08:00
-flto -ffat-lto-objects])],
2013-11-22 04:56:18 +08:00
[AC_MSG_RESULT([skipping -flto, optimization not enabled])])
2014-04-25 02:49:15 +08:00
AC_SUBST([OUR_CFLAGS], "$with_cflags $sanitizer_cflags")
2012-08-08 18:03:34 +08:00
2013-10-22 00:28:23 +08:00
AS_CASE([$CFLAGS], [*-O[[12345\ ]]*],
2013-07-26 22:08:15 +08:00
[CC_CHECK_FLAGS_APPEND([with_cppflags], [CPPFLAGS], [\
-Wp,-D_FORTIFY_SOURCE=2])],
[AC_MSG_RESULT([skipping -D_FORTIFY_SOURCE, optimization not enabled])])
2014-04-25 02:49:15 +08:00
AC_SUBST([OUR_CPPFLAGS], "$with_cppflags $sanitizer_cppflags")
2012-03-20 00:20:43 +08:00
CC_CHECK_FLAGS_APPEND([with_ldflags], [LDFLAGS], [\
2010-10-06 03:45:51 +08:00
-Wl,--as-needed \
2013-04-20 05:17:08 +08:00
-Wl,--no-undefined \
2012-08-08 18:03:34 +08:00
-Wl,--gc-sections \
-Wl,-z,relro \
2014-01-22 09:38:49 +08:00
-Wl,-z,now \
2014-05-18 23:46:42 +08:00
-pie \
2014-01-22 09:38:49 +08:00
-Wl,-fuse-ld=gold])
2014-04-25 02:49:15 +08:00
AC_SUBST([OUR_LDFLAGS], "$with_ldflags $sanitizer_ldflags")
2010-02-03 21:21:48 +08:00
2013-12-31 06:22:26 +08:00
AC_CHECK_SIZEOF(pid_t)
AC_CHECK_SIZEOF(uid_t)
2014-03-05 02:20:21 +08:00
AC_CHECK_SIZEOF(gid_t)
2014-04-25 19:45:15 +08:00
AC_CHECK_SIZEOF(time_t)
2014-08-19 06:04:46 +08:00
AC_CHECK_SIZEOF(dev_t)
2014-04-25 19:45:15 +08:00
AC_CHECK_SIZEOF(rlim_t,,[
#include <sys/time.h>
#include <sys/resource.h>
])
2013-12-31 06:22:26 +08:00
2013-02-11 14:08:30 +08:00
# ------------------------------------------------------------------------------
# we use python to build the man page index, and for systemd-python
have_python=no
AC_ARG_WITH([python],
[AS_HELP_STRING([--without-python], [Disable building the man page index and systemd-python (default: test)])])
2014-02-12 15:58:41 +08:00
have_lxml=no
2013-02-11 14:08:30 +08:00
AS_IF([test "x$with_python" != "xno"], [
AM_PATH_PYTHON(,, [:])
2014-06-17 11:54:50 +08:00
AS_IF([test "x$PYTHON" != "x:"], [
AC_MSG_CHECKING([for python lxml module])
AS_IF(["$PYTHON" -c 'import lxml' 2>/dev/null], [have_lxml=yes])
AC_MSG_RESULT([$have_lxml])
AS_IF([test "x$have_lxml" = "xyes"], [have_python=yes],
[AC_MSG_WARN([*** python support requires python-lxml module installed])])
])
2013-02-11 14:08:30 +08:00
])
2014-06-21 06:14:22 +08:00
AS_IF([test "$have_python" != "yes"], [
AS_IF([test "$with_python" = "yes"],
[AC_MSG_ERROR([*** python support requested but python support not found])])
AS_IF([test "$with_python" != "no"],
[AC_MSG_WARN([*** python support not found, some documentation cannot be built])])
])
2013-02-11 14:08:30 +08:00
AM_CONDITIONAL([HAVE_PYTHON], [test "x$have_python" = "xyes"])
AS_IF([test "x$PYTHON_BINARY" = "x"],
[AS_IF([test "x$have_python" = "xyes"],
2013-03-04 08:38:16 +08:00
[PYTHON_BINARY="$(which "$PYTHON")"],
2013-02-11 14:08:30 +08:00
[PYTHON_BINARY=/usr/bin/python])])
AC_ARG_VAR(PYTHON_BINARY, [Python binary used to launch installed scripts])
2013-09-20 02:53:38 +08:00
AS_IF([test "x$have_python" != "xyes" -a "x$enable_python_devel" = "xyes"],
[AC_MSG_ERROR([*** python-devel support requires --with-python])])
2013-07-26 22:08:15 +08:00
have_python_devel=no
AC_ARG_ENABLE(python_devel, AS_HELP_STRING([--disable-python-devel], [Do not build python modules]))
2013-09-20 02:53:38 +08:00
AS_IF([test "x$have_python" = "xyes" -a "x$enable_python_devel" != "xno"], [
2013-07-26 22:08:15 +08:00
PKG_CHECK_MODULES([PYTHON_DEVEL], [python-${PYTHON_VERSION}],
[have_python_devel=yes],
[PKG_CHECK_MODULES([PYTHON_DEVEL], [python],
[have_python_devel=yes],
[have_python_devel=no])])
AS_IF([test "x$have_python_devel" = xno -a "x$enable_python_devel" = xyes],
[AC_MSG_ERROR([*** python-devel support requested but libraries not found])])
2013-09-27 14:24:00 +08:00
AC_PATH_PROGS(SPHINX_BUILD, sphinx-build-${PYTHON_VERSION} sphinx-build)
2013-02-11 14:08:30 +08:00
])
AM_CONDITIONAL([HAVE_PYTHON_DEVEL], [test "$have_python_devel" = "yes"])
# ------------------------------------------------------------------------------
2010-08-12 05:31:07 +08:00
AC_SEARCH_LIBS([dlsym], [dl], [], [AC_MSG_ERROR([*** Dynamic linking loader library not found])])
2013-07-30 09:38:55 +08:00
AC_CHECK_HEADERS([sys/capability.h], [], [AC_MSG_ERROR([*** POSIX caps headers not found])])
2013-08-15 23:50:57 +08:00
AC_CHECK_HEADERS([linux/btrfs.h], [], [])
2014-10-06 06:41:31 +08:00
AC_CHECK_HEADERS([linux/memfd.h], [], [])
2013-07-30 09:38:55 +08:00
# unconditionally pull-in librt with old glibc versions
AC_SEARCH_LIBS([clock_gettime], [rt], [], [])
2011-07-28 10:02:32 +08:00
save_LIBS="$LIBS"
LIBS=
2010-02-03 21:21:48 +08:00
AC_SEARCH_LIBS([cap_init], [cap], [], [AC_MSG_ERROR([*** POSIX caps library not found])])
2011-07-28 10:02:32 +08:00
CAP_LIBS="$LIBS"
2013-07-30 09:38:55 +08:00
AC_SUBST(CAP_LIBS)
LIBS=
2013-07-22 11:57:35 +08:00
AC_SEARCH_LIBS([mq_open], [rt], [], [AC_MSG_ERROR([*** POSIX RT library not found])])
RT_LIBS="$LIBS"
AC_SUBST(RT_LIBS)
2011-07-28 10:02:32 +08:00
LIBS="$save_LIBS"
2010-02-03 21:21:48 +08:00
2014-10-06 06:41:31 +08:00
AC_CHECK_FUNCS([memfd_create])
2012-09-17 06:21:25 +08:00
AC_CHECK_FUNCS([__secure_getenv secure_getenv])
2014-10-30 00:06:32 +08:00
AC_CHECK_DECLS([gettid, pivot_root, name_to_handle_at, setns, getrandom, LO_FLAGS_PARTSCAN],
2014-06-21 07:45:45 +08:00
[], [], [[
#include <sys/types.h>
2012-09-05 06:20:04 +08:00
#include <unistd.h>
2012-10-09 20:58:51 +08:00
#include <sys/mount.h>
2014-02-20 21:39:13 +08:00
#include <fcntl.h>
2014-03-19 08:10:14 +08:00
#include <sched.h>
2014-06-21 07:45:45 +08:00
#include <linux/loop.h>
2014-10-30 00:06:32 +08:00
#include <linux/random.h>
2014-06-21 07:45:45 +08:00
]])
2014-07-17 04:44:45 +08:00
AC_CHECK_DECLS([IFLA_MACVLAN_FLAGS,
2014-07-22 09:04:44 +08:00
IFLA_VTI_REMOTE,
2014-07-17 04:44:45 +08:00
IFLA_PHYS_PORT_ID,
2014-06-21 07:45:45 +08:00
IFLA_BOND_AD_INFO,
IFLA_VLAN_PROTOCOL,
IFLA_VXLAN_LOCAL6,
IFLA_IPTUN_6RD_RELAY_PREFIXLEN,
IFLA_BRIDGE_VLAN_INFO],
[], [], [[
#include <inttypes.h>
#include <netinet/in.h>
#include <netinet/ether.h>
#include <linux/rtnetlink.h>
#include <net/if.h>
#include <linux/ip.h>
#include <linux/if_tunnel.h>
#include <linux/if_link.h>
#include <linux/if_bridge.h>
]])
2012-09-05 06:20:04 +08:00
2010-04-30 23:44:43 +08:00
# This makes sure pkg.m4 is available.
2010-05-11 04:07:25 +08:00
m4_pattern_forbid([^_?PKG_[A-Z_]+$],[*** pkg.m4 missing, please install pkg-config])
2010-05-16 05:06:41 +08:00
2013-11-06 09:03:05 +08:00
# ------------------------------------------------------------------------------
2014-01-01 09:20:17 +08:00
have_dbus=no
AC_ARG_ENABLE(dbus, AS_HELP_STRING([--disable-dbus], [disable usage of dbus-1 in tests]))
2014-01-15 13:06:00 +08:00
AS_IF([test "x$enable_dbus" != "xno"], [
2014-01-01 09:20:17 +08:00
PKG_CHECK_MODULES(DBUS, [dbus-1 >= 1.3.2],
[AC_DEFINE(HAVE_DBUS, 1, [Define if dbus-1 library is available]) have_dbus=yes],
[have_dbus=no])
AS_IF([test "x$have_dbus" = "xno" -a "x$enable_dbus" = "xyes"],
[AC_MSG_ERROR([*** dbus-1 support requested but libraries not found])])])
2013-11-06 09:03:05 +08:00
AM_CONDITIONAL(HAVE_DBUS, [test "$have_dbus" = "yes"])
2013-08-15 23:50:57 +08:00
2014-09-24 23:25:00 +08:00
# ------------------------------------------------------------------------------
have_utmp=yes
AC_ARG_ENABLE([utmp], AS_HELP_STRING([--disable-utmp], [disable utmp/wtmp log handling]),
AS_CASE("x${enableval}",
[xyes], [have_utmp=yes],
[xno], [have_utmp=no],
AC_MSG_ERROR(bad value ${enableval} for --enable-utmp)))
AS_IF([test "x$have_utmp" = "xyes"], [AC_DEFINE(HAVE_UTMP, 1, [Define if utmp/wtmp support is enabled])])
AM_CONDITIONAL([HAVE_UTMP], [test "x$have_utmp" = "xyes"])
2014-01-19 21:50:02 +08:00
# ------------------------------------------------------------------------------
have_compat_libs=no
AC_ARG_ENABLE([compat_libs], AS_HELP_STRING([--enable-compat-libs],[Enable creation of compatibility libraries]),
[case "${enableval}" in
yes) have_compat_libs=yes ;;
no) have_compat_libs=no ;;
*) AC_MSG_ERROR(bad value ${enableval} for --enable-compat-libs) ;;
esac],
[have_compat_libs=no])
AM_CONDITIONAL([ENABLE_COMPAT_LIBS], [test "$have_compat_libs" = "yes"])
2013-03-28 21:54:06 +08:00
# ------------------------------------------------------------------------------
have_coverage=no
AC_ARG_ENABLE(coverage, AS_HELP_STRING([--enable-coverage], [enable test coverage]))
if test "x$enable_coverage" = "xyes" ; then
AC_CHECK_PROG(lcov_found, [lcov], [yes], [no])
if test "x$lcov_found" = xno ; then
AC_MSG_ERROR([*** lcov support requested but the program was not found])
else
lcov_version_major="`lcov --version | cut -d ' ' -f 4 | cut -d '.' -f 1`"
lcov_version_minor="`lcov --version | cut -d ' ' -f 4 | cut -d '.' -f 2`"
if test "$lcov_version_major" -eq 1 -a "$lcov_version_minor" -lt 10; then
AC_MSG_ERROR([*** lcov version is too old. 1.10 required])
else
have_coverage=yes
CC_CHECK_FLAGS_APPEND([with_coverage_cflags], [CFLAGS], [\
-fprofile-arcs \
-ftest-coverage])
AC_SUBST([OUR_CFLAGS], "$with_cflags $with_coverage_cflags")
fi
fi
fi
AM_CONDITIONAL(ENABLE_COVERAGE, [test "$have_coverage" = "yes"])
2012-11-20 08:24:32 +08:00
# ------------------------------------------------------------------------------
have_kmod=no
AC_ARG_ENABLE(kmod, AS_HELP_STRING([--disable-kmod], [disable loadable modules support]))
if test "x$enable_kmod" != "xno"; then
2013-07-11 22:33:48 +08:00
PKG_CHECK_EXISTS([ libkmod ], have_kmod=yes, have_kmod=no)
if test "x$have_kmod" = "xyes"; then
2013-10-18 01:49:19 +08:00
PKG_CHECK_MODULES(KMOD, [ libkmod >= 15 ],
2013-07-11 22:33:48 +08:00
[AC_DEFINE(HAVE_KMOD, 1, [Define if kmod is available])],
2013-10-18 04:19:29 +08:00
AC_MSG_ERROR([*** kmod version >= 15 not found]))
2013-07-11 22:33:48 +08:00
fi
2012-11-20 08:24:32 +08:00
if test "x$have_kmod" = xno -a "x$enable_kmod" = xyes; then
2013-07-09 06:12:35 +08:00
AC_MSG_ERROR([*** kmod support requested, but libraries not found])
2012-11-20 08:24:32 +08:00
fi
fi
AM_CONDITIONAL(HAVE_KMOD, [test "$have_kmod" = "yes"])
2012-11-16 08:17:18 +08:00
# ------------------------------------------------------------------------------
have_blkid=no
AC_ARG_ENABLE(blkid, AS_HELP_STRING([--disable-blkid], [disable blkid support]))
if test "x$enable_blkid" != "xno"; then
PKG_CHECK_MODULES(BLKID, [ blkid >= 2.20 ],
[AC_DEFINE(HAVE_BLKID, 1, [Define if blkid is available]) have_blkid=yes], have_blkid=no)
if test "x$have_blkid" = xno -a "x$enable_blkid" = xyes; then
AC_MSG_ERROR([*** blkid support requested but libraries not found])
fi
fi
AM_CONDITIONAL(HAVE_BLKID, [test "$have_blkid" = "yes"])
2012-02-09 04:52:18 +08:00
2014-02-12 08:29:54 +08:00
# ------------------------------------------------------------------------------
have_seccomp=no
AC_ARG_ENABLE(seccomp, AS_HELP_STRING([--disable-seccomp], [Disable optional SECCOMP support]))
if test "x$enable_seccomp" != "xno"; then
PKG_CHECK_MODULES(SECCOMP, [libseccomp >= 1.0.0],
2014-02-13 01:28:21 +08:00
[AC_DEFINE(HAVE_SECCOMP, 1, [Define if seccomp is available])
have_seccomp=yes
M4_DEFINES="$M4_DEFINES -DHAVE_SECCOMP"],
2014-02-12 08:29:54 +08:00
[have_seccomp=no])
if test "x$have_seccomp" = "xno" -a "x$enable_seccomp" = "xyes"; then
AC_MSG_ERROR([*** seccomp support requested but libraries not found])
fi
fi
AM_CONDITIONAL(HAVE_SECCOMP, [test "$have_seccomp" = "yes"])
2012-04-04 03:24:46 +08:00
# ------------------------------------------------------------------------------
2012-03-16 02:06:11 +08:00
have_ima=yes
AC_ARG_ENABLE([ima], AS_HELP_STRING([--disable-ima],[Disable optional IMA support]),
[case "${enableval}" in
yes) have_ima=yes ;;
no) have_ima=no ;;
*) AC_MSG_ERROR(bad value ${enableval} for --disable-ima) ;;
esac],
[have_ima=yes])
if test "x${have_ima}" != xno ; then
AC_DEFINE(HAVE_IMA, 1, [Define if IMA is available])
fi
2013-01-05 05:32:31 +08:00
# ------------------------------------------------------------------------------
have_chkconfig=yes
AC_ARG_ENABLE([chkconfig], AS_HELP_STRING([--disable-chkconfig],[Disable optional chkconfig support]),
[case "${enableval}" in
yes) have_chkconfig=yes ;;
no) have_chkconfig=no ;;
*) AC_MSG_ERROR(bad value ${enableval} for --disable-chkconfig) ;;
esac],
[AC_PATH_PROG(CHKCONFIG, chkconfig)
if test -z "$CHKCONFIG"; then
have_chkconfig=no
else
have_chkconfig=yes
fi])
if test "x${have_chkconfig}" != xno ; then
AC_DEFINE(HAVE_CHKCONFIG, 1, [Define if CHKCONFIG is available])
fi
2012-04-04 03:24:46 +08:00
# ------------------------------------------------------------------------------
2011-02-08 18:44:38 +08:00
have_selinux=no
AC_ARG_ENABLE(selinux, AS_HELP_STRING([--disable-selinux], [Disable optional SELINUX support]))
if test "x$enable_selinux" != "xno"; then
2012-09-20 16:20:49 +08:00
PKG_CHECK_MODULES([SELINUX], [libselinux >= 2.1.9],
2014-02-18 00:49:09 +08:00
[AC_DEFINE(HAVE_SELINUX, 1, [Define if SELinux is available])
have_selinux=yes
M4_DEFINES="$M4_DEFINES -DHAVE_SELINUX"],
[have_selinux=no])
2011-02-08 18:44:38 +08:00
if test "x$have_selinux" = xno -a "x$enable_selinux" = xyes; then
AC_MSG_ERROR([*** SELinux support requested but libraries not found])
fi
Systemd is causing mislabeled devices to be created and then attempting to read them.
-----BEGIN PGP SIGNED MESSAGE-----
Hash: SHA1
On 07/28/2010 05:57 AM, Kay Sievers wrote:
> On Wed, Jul 28, 2010 at 11:43, Lennart Poettering
> <lennart@poettering.net> wrote:
>> On Mon, 26.07.10 16:42, Daniel J Walsh (dwalsh@redhat.com) wrote:
>>> tcontext=system_u:object_r:device_t:s0 tclass=chr_file
>>> type=1400 audit(1280174589.476:7): avc: denied { read } for pid=1
>>> comm="systemd" name="autofs" dev=devtmpfs ino=9482
>>> scontext=system_u:system_r:init_t:s0
>>> tcontext=system_u:object_r:device_t:s0 tclass=chr_file
>>> type=1400 audit(1280174589.476:8): avc: denied { read } for pid=1
>>> comm="systemd" name="autofs" dev=devtmpfs ino=9482
>>> scontext=system_u:system_r:init_t:s0
>>> tcontext=system_u:object_r:device_t:s0 tclass=chr_file
>>>
>>> Lennart, we talked about this earlier. I think this is caused by the
>>> modprobe calls to create /dev/autofs. Since udev is not created at the
>>> point that init loads the kernel modules, the devices get created with
>>> the wrong label. Once udev starts the labels get fixed.
>>>
>>> I can allow init_t to read device_t chr_files.
>>
>> Hmm, I think a cleaner fix would be to make systemd relabel this device
>> properly before accessing it? Given that this is only one device this
>> should not be a problem for us to maintain, I think? How would the
>> fixing of the label work? Would we have to spawn restorecon for this, or
>> can we actually do this in C without too much work?
>
> I guess we can just do what udev is doing, and call setfilecon(), with
> a context of an earlier matchpathcon().
>
> Kay
> _______________________________________________
> systemd-devel mailing list
> systemd-devel@lists.freedesktop.org
> http://lists.freedesktop.org/mailman/listinfo/systemd-devel
Here is the updated patch with a fix for the labeling of /dev/autofs
-----BEGIN PGP SIGNATURE-----
Version: GnuPG v2.0.14 (GNU/Linux)
Comment: Using GnuPG with Fedora - http://enigmail.mozdev.org/
iEYEARECAAYFAkxQMyoACgkQrlYvE4MpobNviACfWgxsjW2xzz1qznFex8RVAQHf
gIEAmwRmRcLvGqYtwQaZ3WKIg8wmrwNk
=pC2e
2010-07-28 21:39:54 +08:00
fi
2011-02-08 18:44:38 +08:00
AM_CONDITIONAL(HAVE_SELINUX, [test "$have_selinux" = "yes"])
2013-04-25 08:51:23 +08:00
2014-02-20 23:19:44 +08:00
have_apparmor=no
AC_ARG_ENABLE(apparmor, AS_HELP_STRING([--disable-apparmor], [Disable optional AppArmor support]))
if test "x$enable_apparmor" != "xno"; then
PKG_CHECK_MODULES([APPARMOR], [libapparmor],
[AC_DEFINE(HAVE_APPARMOR, 1, [Define if AppArmor is available])
have_apparmor=yes
M4_DEFINES="$M4_DEFINES -DHAVE_APPARMOR"],
[have_apparmor=no])
if test "x$have_apparmor" = xno -a "x$enable_apparmor" = xyes; then
AC_MSG_ERROR([*** AppArmor support requested but libraries not found])
fi
fi
AM_CONDITIONAL(HAVE_APPARMOR, [test "$have_apparmor" = "yes"])
2013-04-25 08:51:23 +08:00
AC_ARG_WITH(debug-shell,
AS_HELP_STRING([--with-debug-shell=PATH],
[Path to debug shell binary]),
[SUSHELL="$withval"],[
AS_IF([test "x${have_selinux}" != "xno"], [SUSHELL="/sbin/sushell"] , [SUSHELL="/bin/sh"])])
2013-03-26 01:49:55 +08:00
AC_SUBST(SUSHELL)
Systemd is causing mislabeled devices to be created and then attempting to read them.
-----BEGIN PGP SIGNED MESSAGE-----
Hash: SHA1
On 07/28/2010 05:57 AM, Kay Sievers wrote:
> On Wed, Jul 28, 2010 at 11:43, Lennart Poettering
> <lennart@poettering.net> wrote:
>> On Mon, 26.07.10 16:42, Daniel J Walsh (dwalsh@redhat.com) wrote:
>>> tcontext=system_u:object_r:device_t:s0 tclass=chr_file
>>> type=1400 audit(1280174589.476:7): avc: denied { read } for pid=1
>>> comm="systemd" name="autofs" dev=devtmpfs ino=9482
>>> scontext=system_u:system_r:init_t:s0
>>> tcontext=system_u:object_r:device_t:s0 tclass=chr_file
>>> type=1400 audit(1280174589.476:8): avc: denied { read } for pid=1
>>> comm="systemd" name="autofs" dev=devtmpfs ino=9482
>>> scontext=system_u:system_r:init_t:s0
>>> tcontext=system_u:object_r:device_t:s0 tclass=chr_file
>>>
>>> Lennart, we talked about this earlier. I think this is caused by the
>>> modprobe calls to create /dev/autofs. Since udev is not created at the
>>> point that init loads the kernel modules, the devices get created with
>>> the wrong label. Once udev starts the labels get fixed.
>>>
>>> I can allow init_t to read device_t chr_files.
>>
>> Hmm, I think a cleaner fix would be to make systemd relabel this device
>> properly before accessing it? Given that this is only one device this
>> should not be a problem for us to maintain, I think? How would the
>> fixing of the label work? Would we have to spawn restorecon for this, or
>> can we actually do this in C without too much work?
>
> I guess we can just do what udev is doing, and call setfilecon(), with
> a context of an earlier matchpathcon().
>
> Kay
> _______________________________________________
> systemd-devel mailing list
> systemd-devel@lists.freedesktop.org
> http://lists.freedesktop.org/mailman/listinfo/systemd-devel
Here is the updated patch with a fix for the labeling of /dev/autofs
-----BEGIN PGP SIGNATURE-----
Version: GnuPG v2.0.14 (GNU/Linux)
Comment: Using GnuPG with Fedora - http://enigmail.mozdev.org/
iEYEARECAAYFAkxQMyoACgkQrlYvE4MpobNviACfWgxsjW2xzz1qznFex8RVAQHf
gIEAmwRmRcLvGqYtwQaZ3WKIg8wmrwNk
=pC2e
2010-07-28 21:39:54 +08:00
2013-04-25 08:51:23 +08:00
AC_ARG_WITH([debug-tty],
AS_HELP_STRING([--with-debug-tty=PATH],
[Specify the tty device for debug shell]),
[DEBUGTTY="$withval"],
[DEBUGTTY=/dev/tty9])
AC_SUBST(DEBUGTTY)
2014-03-31 11:08:02 +08:00
AC_ARG_WITH([certificate-root],
AS_HELP_STRING([--with-certificate-root=PATH],
[Specify the prefix for TLS certificates [/etc/ssl]]),
[CERTIFICATEROOT="$withval"],
[CERTIFICATEROOT="/etc/ssl"])
AC_SUBST(CERTIFICATEROOT)
2012-04-04 03:24:46 +08:00
# ------------------------------------------------------------------------------
2011-12-21 09:40:59 +08:00
have_xz=no
AC_ARG_ENABLE(xz, AS_HELP_STRING([--disable-xz], [Disable optional XZ support]))
if test "x$enable_xz" != "xno"; then
PKG_CHECK_MODULES(XZ, [ liblzma ],
2014-07-04 10:42:22 +08:00
[AC_DEFINE(HAVE_XZ, 1, [Define if XZ is available]) have_xz=yes])
2011-12-21 09:40:59 +08:00
if test "x$have_xz" = xno -a "x$enable_xz" = xyes; then
2014-07-04 10:42:22 +08:00
AC_MSG_ERROR([*** XZ support requested but libraries not found])
2011-12-21 09:40:59 +08:00
fi
fi
AM_CONDITIONAL(HAVE_XZ, [test "$have_xz" = "yes"])
2014-07-04 10:42:22 +08:00
# ------------------------------------------------------------------------------
have_lz4=no
AC_ARG_ENABLE(lz4, AS_HELP_STRING([--enable-lz4], [Enable optional LZ4 support]))
AS_IF([test "x$enable_lz4" == "xyes"], [
AC_CHECK_HEADERS(lz4.h,
[AC_DEFINE(HAVE_LZ4, 1, [Define in LZ4 is available]) have_lz4=yes],
[AC_MSG_ERROR([*** LZ4 support requested but headers not found])])
])
AM_CONDITIONAL(HAVE_LZ4, [test "$have_lz4" = "yes"])
2014-07-11 22:42:06 +08:00
AM_CONDITIONAL(HAVE_COMPRESSION, [test "$have_xz" = "yes" -o "$have_lz4" = "yes"])
2012-04-04 03:24:46 +08:00
# ------------------------------------------------------------------------------
2010-06-17 03:54:17 +08:00
AC_ARG_ENABLE([pam],
AS_HELP_STRING([--disable-pam],[Disable optional PAM support]),
[case "${enableval}" in
yes) have_pam=yes ;;
no) have_pam=no ;;
*) AC_MSG_ERROR(bad value ${enableval} for --disable-pam) ;;
esac],
[have_pam=auto])
if test "x${have_pam}" != xno ; then
AC_CHECK_HEADERS(
[security/pam_modules.h security/pam_modutil.h security/pam_ext.h],
[have_pam=yes],
[if test "x$have_pam" = xyes ; then
AC_MSG_ERROR([*** PAM headers not found.])
fi])
AC_CHECK_LIB(
[pam],
[pam_syslog],
[have_pam=yes],
[if test "x$have_pam" = xyes ; then
AC_MSG_ERROR([*** libpam not found.])
fi])
if test "x$have_pam" = xyes ; then
PAM_LIBS="-lpam -lpam_misc"
AC_DEFINE(HAVE_PAM, 1, [PAM available])
2014-02-18 00:49:09 +08:00
M4_DEFINES="$M4_DEFINES -DHAVE_PAM"
2010-06-17 05:11:48 +08:00
else
have_pam=no
2010-06-17 03:54:17 +08:00
fi
else
PAM_LIBS=
fi
AC_SUBST(PAM_LIBS)
AM_CONDITIONAL([HAVE_PAM], [test "x$have_pam" != xno])
2012-04-04 03:24:46 +08:00
# ------------------------------------------------------------------------------
2011-05-24 10:20:35 +08:00
AC_ARG_ENABLE([acl],
AS_HELP_STRING([--disable-acl],[Disable optional ACL support]),
[case "${enableval}" in
yes) have_acl=yes ;;
no) have_acl=no ;;
*) AC_MSG_ERROR(bad value ${enableval} for --disable-acl) ;;
esac],
[have_acl=auto])
if test "x${have_acl}" != xno ; then
AC_CHECK_HEADERS(
[sys/acl.h acl/libacl.h],
[have_acl=yes],
[if test "x$have_acl" = xyes ; then
AC_MSG_ERROR([*** ACL headers not found.])
fi])
AC_CHECK_LIB(
[acl],
[acl_get_file],
[have_acl=yes],
[if test "x$have_acl" = xyes ; then
AC_MSG_ERROR([*** libacl not found.])
fi])
if test "x$have_acl" = xyes ; then
ACL_LIBS="-lacl"
AC_DEFINE(HAVE_ACL, 1, [ACL available])
else
have_acl=no
fi
else
ACL_LIBS=
fi
AC_SUBST(ACL_LIBS)
AM_CONDITIONAL([HAVE_ACL], [test "x$have_acl" != xno])
2013-05-16 16:40:03 +08:00
# ------------------------------------------------------------------------------
AC_ARG_ENABLE([smack], AS_HELP_STRING([--disable-smack],[Disable optional SMACK support]),
[case "${enableval}" in
yes) have_smack=yes ;;
no) have_smack=no ;;
*) AC_MSG_ERROR(bad value ${enableval} for --disable-smack) ;;
esac],
[have_smack=auto])
2014-05-28 17:36:40 +08:00
if test "x${have_smack}" = xauto; then
M4_DEFINES="$M4_DEFINES -DHAVE_SMACK"
have_smack=yes
2013-05-16 16:40:03 +08:00
fi
2013-09-26 06:49:42 +08:00
AC_ARG_WITH(smack-run-label,
AS_HELP_STRING([--with-smack-run-label=STRING],
[run systemd --system with a specific SMACK label]),
[AC_DEFINE_UNQUOTED(SMACK_RUN_LABEL, ["$withval"], [Run with a smack label])],
[])
2013-05-16 16:40:03 +08:00
if test "x${have_smack}" = xyes ; then
AC_DEFINE(HAVE_SMACK, 1, [Define if SMACK is available])
fi
2012-08-14 02:31:10 +08:00
# ------------------------------------------------------------------------------
2012-08-20 22:51:46 +08:00
AC_ARG_ENABLE([gcrypt],
2012-08-14 02:31:10 +08:00
AS_HELP_STRING([--disable-gcrypt],[Disable optional GCRYPT support]),
[case "${enableval}" in
yes) have_gcrypt=yes ;;
no) have_gcrypt=no ;;
*) AC_MSG_ERROR(bad value ${enableval} for --disable-gcrypt) ;;
esac],
[have_gcrypt=auto])
if test "x${have_gcrypt}" != xno ; then
AM_PATH_LIBGCRYPT(
[1.4.5],
[have_gcrypt=yes],
[if test "x$have_gcrypt" = xyes ; then
AC_MSG_ERROR([*** GCRYPT headers not found.])
fi])
if test "x$have_gcrypt" = xyes ; then
GCRYPT_LIBS="$LIBGCRYPT_LIBS"
GCRYPT_CFLAGS="$LIBGCRYPT_CFLAGS"
AC_DEFINE(HAVE_GCRYPT, 1, [GCRYPT available])
else
have_gcrypt=no
fi
else
GCRYPT_LIBS=
GCRYPT_CFLAGS=
fi
AC_SUBST(GCRYPT_LIBS)
AC_SUBST(GCRYPT_CFLAGS)
AM_CONDITIONAL([HAVE_GCRYPT], [test "x$have_gcrypt" != xno])
2012-04-04 03:24:46 +08:00
# ------------------------------------------------------------------------------
2010-08-11 07:43:23 +08:00
AC_ARG_ENABLE([audit],
AS_HELP_STRING([--disable-audit],[Disable optional AUDIT support]),
[case "${enableval}" in
yes) have_audit=yes ;;
no) have_audit=no ;;
*) AC_MSG_ERROR(bad value ${enableval} for --disable-audit) ;;
esac],
[have_audit=auto])
if test "x${have_audit}" != xno ; then
AC_CHECK_HEADERS(
[libaudit.h],
[have_audit=yes],
[if test "x$have_audit" = xyes ; then
AC_MSG_ERROR([*** AUDIT headers not found.])
fi])
AC_CHECK_LIB(
[audit],
[audit_open],
[have_audit=yes],
[if test "x$have_audit" = xyes ; then
AC_MSG_ERROR([*** libaudit not found.])
fi])
if test "x$have_audit" = xyes ; then
AUDIT_LIBS="-laudit"
AC_DEFINE(HAVE_AUDIT, 1, [AUDIT available])
else
have_audit=no
fi
else
AUDIT_LIBS=
fi
AC_SUBST(AUDIT_LIBS)
2014-06-19 18:07:12 +08:00
# ------------------------------------------------------------------------------
AC_ARG_ENABLE([elfutils],
AS_HELP_STRING([--disable-elfutils],[Disable optional ELFUTILS support]),
[case "${enableval}" in
yes) have_elfutils=yes ;;
no) have_elfutils=no ;;
*) AC_MSG_ERROR(bad value ${enableval} for --disable-elfutils) ;;
esac],
[have_elfutils=auto])
if test "x${have_elfutils}" != xno ; then
AC_CHECK_HEADERS(
[elfutils/libdwfl.h],
2014-06-21 04:46:04 +08:00
[],
2014-06-19 18:07:12 +08:00
[if test "x$have_elfutils" = xyes ; then
AC_MSG_ERROR([*** ELFUTILS headers not found.])
fi])
AC_CHECK_LIB(
[dw],
[dwfl_begin],
2014-06-21 04:46:04 +08:00
[],
2014-06-19 18:07:12 +08:00
[if test "x$have_elfutils" = xyes ; then
AC_MSG_ERROR([*** ELFUTILS libs not found.])
fi])
2014-06-21 04:46:04 +08:00
AC_CHECK_LIB(
[dw],
[dwfl_core_file_attach],
[have_elfutils=yes],
[if test "x$have_elfutils" = xyes ; then
AC_MSG_ERROR([*** ELFUTILS >= 158 is required.])
fi])
2014-06-19 18:07:12 +08:00
if test "x$have_elfutils" = xyes ; then
ELFUTILS_LIBS="-lelf -ldw"
AC_DEFINE(HAVE_ELFUTILS, 1, [ELFUTILS available])
else
have_elfutils=no
fi
else
ELFUTILS_LIBS=
fi
AC_SUBST(ELFUTILS_LIBS)
AM_CONDITIONAL(HAVE_ELFUTILS, [test "$have_elfutils" = "yes"])
2012-04-04 03:24:46 +08:00
# ------------------------------------------------------------------------------
2010-11-12 07:39:17 +08:00
have_libcryptsetup=no
AC_ARG_ENABLE(libcryptsetup, AS_HELP_STRING([--disable-libcryptsetup], [disable libcryptsetup tools]))
if test "x$enable_libcryptsetup" != "xno"; then
2013-07-13 19:19:38 +08:00
PKG_CHECK_MODULES(LIBCRYPTSETUP, [ libcryptsetup >= 1.6.0 ],
2010-11-12 07:39:17 +08:00
[AC_DEFINE(HAVE_LIBCRYPTSETUP, 1, [Define if libcryptsetup is available]) have_libcryptsetup=yes], have_libcryptsetup=no)
if test "x$have_libcryptsetup" = xno -a "x$enable_libcryptsetup" = xyes; then
2011-02-08 18:44:38 +08:00
AC_MSG_ERROR([*** libcryptsetup support requested but libraries not found])
2010-11-12 07:39:17 +08:00
fi
fi
AM_CONDITIONAL(HAVE_LIBCRYPTSETUP, [test "$have_libcryptsetup" = "yes"])
2012-08-21 04:02:19 +08:00
# ------------------------------------------------------------------------------
have_qrencode=no
AC_ARG_ENABLE(qrencode, AS_HELP_STRING([--disable-qrencode], [disable qrencode support]))
if test "x$enable_qrencode" != "xno"; then
PKG_CHECK_MODULES(QRENCODE, [ libqrencode ],
[AC_DEFINE(HAVE_QRENCODE, 1, [Define if qrencode is available]) have_qrencode=yes], have_qrencode=no)
if test "x$have_qrencode" = xno -a "x$enable_qrencode" = xyes; then
AC_MSG_ERROR([*** qrencode support requested but libraries not found])
fi
fi
AM_CONDITIONAL(HAVE_QRENCODE, [test "$have_qrencode" = "yes"])
2012-09-28 06:46:32 +08:00
# ------------------------------------------------------------------------------
have_microhttpd=no
AC_ARG_ENABLE(microhttpd, AS_HELP_STRING([--disable-microhttpd], [disable microhttpd support]))
if test "x$enable_microhttpd" != "xno"; then
2014-03-17 12:13:48 +08:00
PKG_CHECK_MODULES(MICROHTTPD, [libmicrohttpd >= 0.9.33],
2012-09-28 06:46:32 +08:00
[AC_DEFINE(HAVE_MICROHTTPD, 1, [Define if microhttpd is available]) have_microhttpd=yes], have_microhttpd=no)
if test "x$have_microhttpd" = xno -a "x$enable_microhttpd" = xyes; then
AC_MSG_ERROR([*** microhttpd support requested but libraries not found])
fi
fi
AM_CONDITIONAL(HAVE_MICROHTTPD, [test "$have_microhttpd" = "yes"])
2012-11-28 19:45:31 +08:00
# ------------------------------------------------------------------------------
have_gnutls=no
AC_ARG_ENABLE(gnutls, AS_HELP_STRING([--disable-gnutls], [disable gnutls support]))
if test "x$enable_gnutls" != "xno"; then
2012-12-01 18:12:05 +08:00
PKG_CHECK_MODULES(GNUTLS, [gnutls >= 3.1.4],
2012-11-28 19:45:31 +08:00
[AC_DEFINE(HAVE_GNUTLS, 1, [Define if gnutls is available]) have_gnutls=yes], have_gnutls=no)
if test "x$have_gnutls" = xno -a "x$enable_gnutls" = xyes; then
AC_MSG_ERROR([*** gnutls support requested but libraries not found])
fi
fi
AM_CONDITIONAL(HAVE_GNUTLS, [test "$have_gnutls" = "yes"])
2014-03-18 10:52:53 +08:00
# ------------------------------------------------------------------------------
have_libcurl=no
AC_ARG_ENABLE(libcurl, AS_HELP_STRING([--disable-libcurl], [disable libcurl support]))
if test "x$enable_libcurl" != "xno"; then
PKG_CHECK_MODULES(LIBCURL, [libcurl],
[AC_DEFINE(HAVE_LIBCURL, 1, [Define if libcurl is available]) have_libcurl=yes], have_libcurl=no)
if test "x$have_libcurl" = xno -a "x$enable_libcurl" = xyes; then
AC_MSG_ERROR([*** libcurl support requested but libraries not found])
fi
fi
AM_CONDITIONAL(HAVE_LIBCURL, [test "$have_libcurl" = "yes"])
2014-08-01 05:43:10 +08:00
# ------------------------------------------------------------------------------
have_libidn=no
AC_ARG_ENABLE(libidn, AS_HELP_STRING([--disable-libidn], [Disable optional LIBIDN support]))
if test "x$enable_libidn" != "xno"; then
PKG_CHECK_MODULES(LIBIDN, [libidn],
[AC_DEFINE(HAVE_LIBIDN, 1, [Define if libidn is available])
have_libidn=yes
M4_DEFINES="$M4_DEFINES -DHAVE_LIBIDN"],
[have_libidn=no])
if test "x$have_libidn" = "xno" -a "x$enable_libidn" = "xyes"; then
AC_MSG_ERROR([*** libidn support requested but libraries not found])
fi
fi
AM_CONDITIONAL(HAVE_LIBIDN, [test "$have_libidn" = "yes"])
2012-04-04 03:24:46 +08:00
# ------------------------------------------------------------------------------
2011-04-27 05:31:09 +08:00
have_binfmt=no
AC_ARG_ENABLE(binfmt, AS_HELP_STRING([--disable-binfmt], [disable binfmt tool]))
if test "x$enable_binfmt" != "xno"; then
2012-02-13 08:53:55 +08:00
have_binfmt=yes
2011-04-27 05:31:09 +08:00
fi
AM_CONDITIONAL(ENABLE_BINFMT, [test "$have_binfmt" = "yes"])
2012-04-04 03:24:46 +08:00
# ------------------------------------------------------------------------------
2012-01-01 02:35:52 +08:00
have_vconsole=no
AC_ARG_ENABLE(vconsole, AS_HELP_STRING([--disable-vconsole], [disable vconsole tool]))
if test "x$enable_vconsole" != "xno"; then
2012-02-13 08:53:55 +08:00
have_vconsole=yes
2012-01-01 02:35:52 +08:00
fi
AM_CONDITIONAL(ENABLE_VCONSOLE, [test "$have_vconsole" = "yes"])
2012-10-18 07:01:12 +08:00
# ------------------------------------------------------------------------------
have_bootchart=no
AC_ARG_ENABLE(bootchart, AS_HELP_STRING([--disable-bootchart], [disable bootchart tool]))
if test "x$enable_bootchart" != "xno"; then
have_bootchart=yes
fi
AM_CONDITIONAL(ENABLE_BOOTCHART, [test "$have_bootchart" = "yes"])
2012-04-04 03:24:46 +08:00
# ------------------------------------------------------------------------------
2012-01-03 00:07:00 +08:00
have_quotacheck=no
AC_ARG_ENABLE(quotacheck, AS_HELP_STRING([--disable-quotacheck], [disable quotacheck tools]))
if test "x$enable_quotacheck" != "xno"; then
2012-02-13 08:53:55 +08:00
have_quotacheck=yes
2012-01-03 00:07:00 +08:00
fi
AM_CONDITIONAL(ENABLE_QUOTACHECK, [test "$have_quotacheck" = "yes"])
2013-06-02 16:54:44 +08:00
# ------------------------------------------------------------------------------
have_tmpfiles=no
AC_ARG_ENABLE(tmpfiles, AS_HELP_STRING([--disable-tmpfiles], [disable tmpfiles support]))
if test "x$enable_tmpfiles" != "xno"; then
have_tmpfiles=yes
fi
AM_CONDITIONAL(ENABLE_TMPFILES, [test "$have_tmpfiles" = "yes"])
sysusers: add minimal tool to reconstruct /etc/passwd and /etc/group from static files
systemd-sysusers is a tool to reconstruct /etc/passwd and /etc/group
from static definition files that take a lot of inspiration from
tmpfiles snippets. These snippets should carry information about system
users only. To make sure it is not misused for normal users these
snippets only allow configuring UID and gecos field for each user, but
do not allow configuration of the home directory or shell, which is
necessary for real login users.
The purpose of this tool is to enable state-less systems that can
populate /etc with the minimal files necessary, solely from static data
in /usr. systemd-sysuser is additive only, and will never override
existing users.
This tool will create these files directly, and not via some user
database abtsraction layer. This is appropriate as this tool is supposed
to run really early at boot, and is only useful for creating system
users, and system users cannot be stored in remote databases anyway.
The tool is also useful to be invoked from RPM scriptlets, instead of
useradd. This allows moving from imperative user descriptions in RPM to
declarative descriptions.
The UID/GID for a user/group to be created can either be chosen dynamic,
or fixed, or be read from the owner of a file in the file system, in
order to support reconstructing the correct IDs for files that shall be
owned by them.
This also adds a minimal user definition file, that should be
sufficient for most basic systems. Distributions are expected to patch
these files and augment the contents, for example with fixed UIDs for
the users where that's necessary.
2014-06-13 04:54:02 +08:00
# ------------------------------------------------------------------------------
have_sysusers=no
AC_ARG_ENABLE(sysusers, AS_HELP_STRING([--disable-sysusers], [disable sysusers support]))
if test "x$enable_sysusers" != "xno"; then
have_sysusers=yes
fi
AM_CONDITIONAL(ENABLE_SYSUSERS, [test "$have_sysusers" = "yes"])
2014-07-07 21:05:37 +08:00
# ------------------------------------------------------------------------------
have_firstboot=no
AC_ARG_ENABLE(firstboot, AS_HELP_STRING([--disable-firstboot], [disable firstboot support]))
if test "x$enable_firstboot" != "xno"; then
have_firstboot=yes
fi
AM_CONDITIONAL(ENABLE_FIRSTBOOT, [test "$have_firstboot" = "yes"])
2012-04-04 03:24:46 +08:00
# ------------------------------------------------------------------------------
2012-01-03 00:07:00 +08:00
have_randomseed=no
AC_ARG_ENABLE(randomseed, AS_HELP_STRING([--disable-randomseed], [disable randomseed tools]))
if test "x$enable_randomseed" != "xno"; then
2012-02-13 08:53:55 +08:00
have_randomseed=yes
2012-01-03 00:07:00 +08:00
fi
AM_CONDITIONAL(ENABLE_RANDOMSEED, [test "$have_randomseed" = "yes"])
2013-08-14 07:57:02 +08:00
# ------------------------------------------------------------------------------
have_backlight=no
AC_ARG_ENABLE(backlight, AS_HELP_STRING([--disable-backlight], [disable backlight tools]))
if test "x$enable_backlight" != "xno"; then
have_backlight=yes
fi
AM_CONDITIONAL(ENABLE_BACKLIGHT, [test "$have_backlight" = "yes"])
2013-10-14 10:31:49 +08:00
# ------------------------------------------------------------------------------
have_rfkill=no
AC_ARG_ENABLE(rfkill, AS_HELP_STRING([--disable-rfkill], [disable rfkill tools]))
if test "x$enable_rfkill" != "xno"; then
have_rfkill=yes
fi
AM_CONDITIONAL(ENABLE_RFKILL, [test "$have_rfkill" = "yes"])
2012-04-04 03:24:46 +08:00
# ------------------------------------------------------------------------------
2011-12-31 13:02:42 +08:00
have_logind=no
AC_ARG_ENABLE(logind, AS_HELP_STRING([--disable-logind], [disable login daemon]))
if test "x$enable_logind" != "xno"; then
2012-02-13 08:53:55 +08:00
have_logind=yes
2011-12-31 13:02:42 +08:00
fi
AM_CONDITIONAL(ENABLE_LOGIND, [test "$have_logind" = "yes"])
2012-03-01 05:22:15 +08:00
AS_IF([test "$have_logind" = "yes"], [ AC_DEFINE(HAVE_LOGIND, [1], [Logind support available]) ])
2011-12-31 13:02:42 +08:00
2013-07-02 09:47:23 +08:00
# ------------------------------------------------------------------------------
have_machined=no
AC_ARG_ENABLE(machined, AS_HELP_STRING([--disable-machined], [disable machine daemon]))
if test "x$enable_machined" != "xno"; then
have_machined=yes
fi
AM_CONDITIONAL(ENABLE_MACHINED, [test "$have_machined" = "yes"])
AS_IF([test "$have_machined" = "yes"], [ AC_DEFINE(HAVE_MACHINED, [1], [Machined support available]) ])
2012-04-04 03:24:46 +08:00
# ------------------------------------------------------------------------------
2011-08-02 07:09:13 +08:00
have_hostnamed=no
AC_ARG_ENABLE(hostnamed, AS_HELP_STRING([--disable-hostnamed], [disable hostname daemon]))
if test "x$enable_hostnamed" != "xno"; then
2012-02-13 08:53:55 +08:00
have_hostnamed=yes
2011-08-02 07:09:13 +08:00
fi
AM_CONDITIONAL(ENABLE_HOSTNAMED, [test "$have_hostnamed" = "yes"])
2012-04-04 03:24:46 +08:00
# ------------------------------------------------------------------------------
2011-08-03 05:58:46 +08:00
have_timedated=no
AC_ARG_ENABLE(timedated, AS_HELP_STRING([--disable-timedated], [disable timedate daemon]))
if test "x$enable_timedated" != "xno"; then
2012-02-13 08:53:55 +08:00
have_timedated=yes
2011-08-03 05:58:46 +08:00
fi
AM_CONDITIONAL(ENABLE_TIMEDATED, [test "$have_timedated" = "yes"])
2012-04-04 03:24:46 +08:00
# ------------------------------------------------------------------------------
2014-04-28 20:45:42 +08:00
have_timesyncd=no
AC_ARG_ENABLE(timesyncd, AS_HELP_STRING([--disable-timesyncd], [disable timesync daemon]))
2014-05-06 03:39:10 +08:00
if test "x$enable_timesyncd" != "xno"; then
2014-04-28 20:45:42 +08:00
have_timesyncd=yes
fi
AM_CONDITIONAL(ENABLE_TIMESYNCD, [test "$have_timesyncd" = "yes"])
2014-05-06 23:02:11 +08:00
AC_ARG_WITH(ntp-servers,
AS_HELP_STRING([--with-ntp-servers=NTPSERVERS],
[Space-separated list of default NTP servers]),
[NTP_SERVERS="$withval"],
[NTP_SERVERS="time1.google.com time2.google.com time3.google.com time4.google.com"])
AC_DEFINE_UNQUOTED(NTP_SERVERS, ["$NTP_SERVERS"], [Default NTP Servers])
AC_SUBST(NTP_SERVERS)
2014-05-07 00:08:04 +08:00
AC_ARG_WITH(time-epoch,
AS_HELP_STRING([--with-time-epoch=SECONDS],
2014-05-11 20:34:26 +08:00
[Time epoch for time clients]),
2014-05-07 00:08:04 +08:00
[TIME_EPOCH="$withval"],
[TIME_EPOCH="`stat -c %Y ${srcdir}/NEWS 2>/dev/null || echo 0`"])
AC_DEFINE_UNQUOTED(TIME_EPOCH, [$TIME_EPOCH], [Time Epoch])
2014-05-21 08:31:22 +08:00
# ------------------------------------------------------------------------------
AC_ARG_WITH(system-uid-max,
AS_HELP_STRING([--with-system-uid-max=UID]
[Maximum UID for system users]),
[SYSTEM_UID_MAX="$withval"],
[SYSTEM_UID_MAX="`awk 'BEGIN { uid=999 } /^\s*SYS_UID_MAX\s+/ { uid=$2 } END { print uid }' /etc/login.defs 2>/dev/null || echo 999`"])
AC_DEFINE_UNQUOTED(SYSTEM_UID_MAX, [$SYSTEM_UID_MAX], [Maximum System UID])
AC_SUBST(SYSTEM_UID_MAX)
# ------------------------------------------------------------------------------
AC_ARG_WITH(system-gid-max,
AS_HELP_STRING([--with-system-gid-max=GID]
[Maximum GID for system groups]),
[SYSTEM_GID_MAX="$withval"],
[SYSTEM_GID_MAX="`awk 'BEGIN { gid=999 } /^\s*SYS_GID_MAX\s+/ { gid=$2 } END { print gid }' /etc/login.defs 2>/dev/null || echo 999`"])
AC_DEFINE_UNQUOTED(SYSTEM_GID_MAX, [$SYSTEM_GID_MAX], [Maximum System GID])
AC_SUBST(SYSTEM_GID_MAX)
2014-04-28 20:45:42 +08:00
# ------------------------------------------------------------------------------
2011-08-25 06:45:26 +08:00
have_localed=no
AC_ARG_ENABLE(localed, AS_HELP_STRING([--disable-localed], [disable locale daemon]))
if test "x$enable_localed" != "xno"; then
2012-02-13 08:53:55 +08:00
have_localed=yes
2011-08-25 06:45:26 +08:00
fi
AM_CONDITIONAL(ENABLE_LOCALED, [test "$have_localed" = "yes"])
2012-04-04 03:24:46 +08:00
# ------------------------------------------------------------------------------
2012-01-14 07:37:35 +08:00
have_coredump=no
AC_ARG_ENABLE(coredump, AS_HELP_STRING([--disable-coredump], [disable coredump hook]))
if test "x$enable_coredump" != "xno"; then
2012-02-13 08:53:55 +08:00
have_coredump=yes
2012-01-14 07:37:35 +08:00
fi
AM_CONDITIONAL(ENABLE_COREDUMP, [test "$have_coredump" = "yes"])
2013-02-14 05:56:43 +08:00
# ------------------------------------------------------------------------------
have_polkit=no
AC_ARG_ENABLE(polkit, AS_HELP_STRING([--disable-polkit], [disable PolicyKit support]))
if test "x$enable_polkit" != "xno"; then
AC_DEFINE(ENABLE_POLKIT, 1, [Define if PolicyKit support is to be enabled])
have_polkit=yes
fi
AM_CONDITIONAL(ENABLE_POLKIT, [test "x$have_polkit" = "xyes"])
2013-11-13 04:43:17 +08:00
# ------------------------------------------------------------------------------
2014-05-19 04:10:48 +08:00
have_resolved=no
AC_ARG_ENABLE(resolved, AS_HELP_STRING([--disable-resolved], [disable resolve daemon]))
if test "x$enable_resolved" != "xno"; then
have_resolved=yes
2014-08-27 23:45:41 +08:00
M4_DEFINES="$M4_DEFINES -DENABLE_RESOLVED"
2013-11-13 04:43:17 +08:00
fi
2014-05-19 04:10:48 +08:00
AM_CONDITIONAL(ENABLE_RESOLVED, [test "$have_resolved" = "yes"])
2013-11-13 04:43:17 +08:00
2014-05-16 21:24:09 +08:00
AC_ARG_WITH(dns-servers,
AS_HELP_STRING([--with-dns-servers=DNSSERVERS],
[Space-separated list of default DNS servers]),
2014-05-25 06:23:06 +08:00
[DNS_SERVERS="$withval"],
2014-05-16 23:34:43 +08:00
[DNS_SERVERS="8.8.8.8 8.8.4.4 2001:4860:4860::8888 2001:4860:4860::8844"])
2014-05-16 21:24:09 +08:00
AC_DEFINE_UNQUOTED(DNS_SERVERS, ["$DNS_SERVERS"], [Default DNS Servers])
AC_SUBST(DNS_SERVERS)
2014-05-19 04:10:48 +08:00
# ------------------------------------------------------------------------------
have_networkd=no
AC_ARG_ENABLE(networkd, AS_HELP_STRING([--disable-networkd], [disable networkd]))
2014-06-21 07:45:45 +08:00
AS_IF([test "x$enable_networkd" != "xno"], [
2014-05-19 04:10:48 +08:00
AC_DEFINE(ENABLE_NETWORKD, 1, [Define if networkd support is to be enabled])
have_networkd=yes
2014-06-21 07:45:45 +08:00
])
2014-05-19 04:10:48 +08:00
AM_CONDITIONAL(ENABLE_NETWORKD, [test "x$have_networkd" = "xyes"])
2013-02-14 06:07:59 +08:00
# ------------------------------------------------------------------------------
have_efi=no
AC_ARG_ENABLE(efi, AS_HELP_STRING([--disable-efi], [disable EFI support]))
if test "x$enable_efi" != "xno"; then
AC_DEFINE(ENABLE_EFI, 1, [Define if EFI support is to be enabled])
have_efi=yes
fi
AM_CONDITIONAL(ENABLE_EFI, [test "x$have_efi" = "xyes"])
2014-06-12 23:51:14 +08:00
# ------------------------------------------------------------------------------
have_terminal=no
AC_ARG_ENABLE(terminal, AS_HELP_STRING([--enable-terminal], [enable terminal support]))
if test "x$enable_terminal" = "xyes"; then
2014-09-19 20:05:52 +08:00
PKG_CHECK_MODULES([TERMINAL], [ libevdev >= 1.2 xkbcommon >= 0.4 libdrm >= 2.4], [have_terminal=yes])
2014-08-28 00:31:34 +08:00
AS_IF([test "x$have_terminal" != xyes -a "x$enable_terminal" = xyes],
[AC_MSG_ERROR([*** terminal support requested but required dependencies not available])],
[test "x$have_terminal" = xyes],
[AC_DEFINE(ENABLE_TERMINAL, 1, [Define if terminal support is to be enabled])])
2014-06-12 23:51:14 +08:00
fi
AM_CONDITIONAL(ENABLE_TERMINAL, [test "x$have_terminal" = "xyes"])
2013-12-01 03:18:48 +08:00
# ------------------------------------------------------------------------------
have_kdbus=no
2013-12-13 17:26:55 +08:00
AC_ARG_ENABLE(kdbus, AS_HELP_STRING([--enable-kdbus], [do connect to kdbus by default]))
2014-01-06 00:57:05 +08:00
if test "x$enable_kdbus" = "xyes"; then
2013-12-01 03:18:48 +08:00
AC_DEFINE(ENABLE_KDBUS, 1, [Define if kdbus support is to be enabled])
have_kdbus=yes
2013-12-28 01:08:04 +08:00
M4_DEFINES="$M4_DEFINES -DENABLE_KDBUS"
2013-12-01 03:18:48 +08:00
fi
AM_CONDITIONAL(ENABLE_KDBUS, [test "$have_kdbus" = "yes"])
2013-01-05 04:48:47 +08:00
# ------------------------------------------------------------------------------
AC_ARG_WITH(rc-local-script-path-start,
AS_HELP_STRING([--with-rc-local-script-path-start=PATH],
[Path to /etc/rc.local]),
[RC_LOCAL_SCRIPT_PATH_START="$withval"],
[RC_LOCAL_SCRIPT_PATH_START="/etc/rc.local"])
AC_ARG_WITH(rc-local-script-path-stop,
AS_HELP_STRING([--with-rc-local-script-path-stop=PATH],
2013-01-05 06:24:38 +08:00
[Path to /usr/sbin/halt.local]),
2013-01-05 04:48:47 +08:00
[RC_LOCAL_SCRIPT_PATH_STOP="$withval"],
2013-01-05 06:24:38 +08:00
[RC_LOCAL_SCRIPT_PATH_STOP="/usr/sbin/halt.local"])
2013-01-05 04:48:47 +08:00
AC_DEFINE_UNQUOTED(RC_LOCAL_SCRIPT_PATH_START, ["$RC_LOCAL_SCRIPT_PATH_START"], [Path of /etc/rc.local script])
2013-01-05 06:24:38 +08:00
AC_DEFINE_UNQUOTED(RC_LOCAL_SCRIPT_PATH_STOP, ["$RC_LOCAL_SCRIPT_PATH_STOP"], [Path of /usr/sbin/halt.local script])
2013-01-05 04:48:47 +08:00
AC_SUBST(RC_LOCAL_SCRIPT_PATH_START)
AC_SUBST(RC_LOCAL_SCRIPT_PATH_STOP)
2013-01-05 06:19:02 +08:00
# ------------------------------------------------------------------------------
AC_ARG_WITH(kbd-loadkeys,
AS_HELP_STRING([--with-kbd-loadkeys=PATH],
[Path to loadkeys]),
[KBD_LOADKEYS="$withval"],
[KBD_LOADKEYS="/usr/bin/loadkeys"])
AC_ARG_WITH(kbd-setfont,
AS_HELP_STRING([--with-kbd-setfont=PATH],
[Path to setfont]),
[KBD_SETFONT="$withval"],
[KBD_SETFONT="/usr/bin/setfont"])
AC_DEFINE_UNQUOTED(KBD_LOADKEYS, ["$KBD_LOADKEYS"], [Path of loadkeys])
AC_DEFINE_UNQUOTED(KBD_SETFONT, ["$KBD_SETFONT"], [Path of setfont])
AC_SUBST(KBD_LOADKEYS)
AC_SUBST(KBD_SETFONT)
2013-03-23 08:04:53 +08:00
AC_ARG_WITH(telinit,
AS_HELP_STRING([--with-telinit=PATH],
[Path to telinit]),
[TELINIT="$withval"],
2013-10-01 09:22:41 +08:00
[TELINIT="/lib/sysvinit/telinit"])
2013-03-23 08:04:53 +08:00
AC_DEFINE_UNQUOTED(TELINIT, ["$TELINIT"], [Path to telinit])
AC_SUBST(TELINIT)
2013-11-21 05:11:10 +08:00
AC_CHECK_HEADERS_ONCE([valgrind/memcheck.h valgrind/valgrind.h])
2013-04-12 08:19:26 +08:00
2013-01-06 01:37:52 +08:00
# ------------------------------------------------------------------------------
have_myhostname=no
2013-01-08 05:15:42 +08:00
AC_ARG_ENABLE(myhostname, AS_HELP_STRING([--disable-myhostname], [disable nss-myhostname support]))
2013-01-06 01:37:52 +08:00
if test "x$enable_myhostname" != "xno"; then
AC_HEADER_STDC
2013-10-02 05:11:23 +08:00
AC_CHECK_HEADERS([arpa/inet.h fcntl.h inttypes.h netdb.h netinet/in.h stdlib.h string.h sys/socket.h sys/time.h unistd.h nss.h sys/ioctl.h sys/auxv.h])
2013-01-06 01:37:52 +08:00
AC_C_CONST
AC_TYPE_SIZE_T
AC_HEADER_TIME
AC_FUNC_MALLOC
AC_FUNC_SELECT_ARGTYPES
AC_CHECK_FUNCS([gethostbyaddr gethostbyname gettimeofday inet_ntoa memset select socket strcspn strdup strerror strncasecmp strcasecmp strspn])
have_myhostname=yes
fi
AM_CONDITIONAL(HAVE_MYHOSTNAME, [test "$have_myhostname" = "yes"])
2012-04-04 03:24:46 +08:00
# ------------------------------------------------------------------------------
AC_ARG_ENABLE([gudev],
AS_HELP_STRING([--disable-gudev], [disable Gobject libudev support @<:@default=enabled@:>@]),
[], [enable_gudev=yes])
2013-03-20 03:03:16 +08:00
AS_IF([test "x$enable_gudev" = "xyes"], [ PKG_CHECK_MODULES([GLIB], [glib-2.0 >= 2.22.0 gobject-2.0 >= 2.22.0 gio-2.0]) ])
2012-04-04 03:24:46 +08:00
AM_CONDITIONAL([ENABLE_GUDEV], [test "x$enable_gudev" = "xyes"])
2013-03-20 03:03:16 +08:00
AS_IF([test "x$enable_gudev" = "xyes"], [ AC_DEFINE(HAVE_GLIB, 1, [Define if glib is available]) ])
2012-04-04 03:24:46 +08:00
# ------------------------------------------------------------------------------
2012-02-11 04:44:14 +08:00
have_manpages=no
2012-02-11 04:45:15 +08:00
AC_ARG_ENABLE(manpages, AS_HELP_STRING([--disable-manpages], [disable manpages]))
2014-02-24 00:21:13 +08:00
AS_IF([test "x$enable_manpages" != xno], [have_manpages=yes])
2012-08-25 07:57:03 +08:00
AM_CONDITIONAL(ENABLE_MANPAGES, [test "x$have_manpages" = "xyes"])
2012-02-11 04:44:14 +08:00
2014-09-02 18:31:49 +08:00
# ------------------------------------------------------------------------------
AC_ARG_ENABLE(hibernate,
[AC_HELP_STRING([--disable-hibernate], [disable hibernation support])],
enable_hibernate=$enableval, enable_hibernate=yes)
AM_CONDITIONAL(ENABLE_HIBERNATE, [test x$enable_hibernate = xyes])
2012-04-04 03:24:46 +08:00
# ------------------------------------------------------------------------------
2014-08-05 18:17:09 +08:00
AC_ARG_ENABLE(ldconfig,
[AC_HELP_STRING([--disable-ldconfig], [disable ldconfig])],
enable_ldconfig=$enableval, enable_ldconfig=yes)
AM_CONDITIONAL(ENABLE_LDCONFIG, [test x$enable_ldconfig = xyes])
2010-05-16 05:06:41 +08:00
2014-08-05 18:17:09 +08:00
# ------------------------------------------------------------------------------
2010-05-17 03:28:41 +08:00
# Location of the init scripts as mandated by LSB
SYSTEM_SYSVINIT_PATH=/etc/init.d
2011-03-18 11:31:22 +08:00
SYSTEM_SYSVRCND_PATH=/etc/rc.d
2010-05-18 01:52:57 +08:00
2010-05-16 17:03:34 +08:00
AC_ARG_WITH([sysvinit-path],
2012-02-13 08:53:55 +08:00
[AS_HELP_STRING([--with-sysvinit-path=PATH],
2013-01-05 06:24:38 +08:00
[Specify the path to where the SysV init scripts are located])],
2012-02-13 08:53:55 +08:00
[SYSTEM_SYSVINIT_PATH="$withval"],
[])
2010-05-16 17:03:34 +08:00
2013-01-08 09:37:37 +08:00
AC_ARG_WITH([sysvrcnd-path],
[AS_HELP_STRING([--with-sysvrcnd-path=PATH],
2013-01-05 06:24:38 +08:00
[Specify the path to the base directory for the SysV rcN.d directories])],
2010-05-16 17:03:34 +08:00
[SYSTEM_SYSVRCND_PATH="$withval"],
[])
2010-09-21 11:23:12 +08:00
if test "x${SYSTEM_SYSVINIT_PATH}" != "x" -a "x${SYSTEM_SYSVRCND_PATH}" != "x"; then
AC_DEFINE(HAVE_SYSV_COMPAT, [], [SysV init scripts and rcN.d links are supported.])
SYSTEM_SYSV_COMPAT="yes"
2011-08-01 06:43:05 +08:00
M4_DEFINES="$M4_DEFINES -DHAVE_SYSV_COMPAT"
2010-09-21 11:23:12 +08:00
elif test "x${SYSTEM_SYSVINIT_PATH}" != "x" -o "x${SYSTEM_SYSVRCND_PATH}" != "x"; then
2013-01-08 09:37:37 +08:00
AC_MSG_ERROR([*** You need both --with-sysvinit-path=PATH and --with-sysvrcnd-path=PATH to enable SysV compatibility support, or both empty to disable it.])
2010-09-21 11:23:12 +08:00
else
SYSTEM_SYSV_COMPAT="no"
fi
2013-01-05 06:24:38 +08:00
AC_SUBST(SYSTEM_SYSVINIT_PATH)
AC_SUBST(SYSTEM_SYSVRCND_PATH)
AC_SUBST(M4_DEFINES)
AM_CONDITIONAL(HAVE_SYSV_COMPAT, test "$SYSTEM_SYSV_COMPAT" = "yes")
2011-01-04 08:58:38 +08:00
AC_ARG_WITH([tty-gid],
2011-01-04 09:26:30 +08:00
[AS_HELP_STRING([--with-tty-gid=GID],
2011-01-04 08:58:38 +08:00
[Specify the numeric GID of the 'tty' group])],
2014-06-13 05:22:27 +08:00
[TTY_GID="$withval"],
[TTY_GID="5"])
AC_DEFINE_UNQUOTED(TTY_GID, [$TTY_GID], [GID of the 'tty' group])
AC_SUBST(TTY_GID)
2011-01-04 08:58:38 +08:00
2010-06-08 01:40:25 +08:00
AC_ARG_WITH([dbuspolicydir],
AS_HELP_STRING([--with-dbuspolicydir=DIR], [D-Bus policy directory]),
[],
2013-03-04 08:38:16 +08:00
[with_dbuspolicydir=$($PKG_CONFIG --variable=sysconfdir dbus-1)/dbus-1/system.d])
2010-06-07 10:14:39 +08:00
2010-06-08 01:40:25 +08:00
AC_ARG_WITH([dbussessionservicedir],
AS_HELP_STRING([--with-dbussessionservicedir=DIR], [D-Bus session service directory]),
[],
2013-03-04 08:38:16 +08:00
[with_dbussessionservicedir=$($PKG_CONFIG --variable=session_bus_services_dir dbus-1)])
2010-06-07 10:14:39 +08:00
2010-06-08 01:40:25 +08:00
AC_ARG_WITH([dbussystemservicedir],
AS_HELP_STRING([--with-dbussystemservicedir=DIR], [D-Bus system service directory]),
[],
2013-03-04 09:13:34 +08:00
[with_dbussystemservicedir=$(readlink -m $($PKG_CONFIG --variable=session_bus_services_dir dbus-1)/../system-services)])
2010-06-07 10:14:39 +08:00
2010-06-08 01:40:25 +08:00
AC_ARG_WITH([dbusinterfacedir],
AS_HELP_STRING([--with-dbusinterfacedir=DIR], [D-Bus interface directory]),
[],
2013-03-04 09:13:34 +08:00
[with_dbusinterfacedir=$(readlink -m $($PKG_CONFIG --variable=session_bus_services_dir dbus-1)/../interfaces)])
2010-06-07 10:14:39 +08:00
2013-03-04 04:32:49 +08:00
AC_ARG_WITH([bashcompletiondir],
AS_HELP_STRING([--with-bashcompletiondir=DIR], [Bash completions directory]),
[],
2013-03-04 08:38:16 +08:00
[AS_IF([$($PKG_CONFIG --exists bash-completion)], [
with_bashcompletiondir=$($PKG_CONFIG --variable=completionsdir bash-completion)
2013-03-04 04:32:49 +08:00
] , [
with_bashcompletiondir=${datadir}/bash-completion/completions
])])
2013-07-25 13:57:05 +08:00
AC_ARG_WITH([zshcompletiondir],
AS_HELP_STRING([--with-zshcompletiondir=DIR], [Zsh completions directory]),
[], [with_zshcompletiondir=${datadir}/zsh/site-functions])
2012-01-05 07:40:39 +08:00
AC_ARG_WITH([rootprefix],
AS_HELP_STRING([--with-rootprefix=DIR], [rootfs directory prefix for config files and kernel modules]),
2012-01-05 11:10:59 +08:00
[], [with_rootprefix=${ac_default_prefix}])
2010-06-08 01:40:25 +08:00
2011-07-15 07:31:06 +08:00
AC_ARG_WITH([rootlibdir],
AS_HELP_STRING([--with-rootlibdir=DIR], [Root directory for libraries necessary for boot]),
[],
[with_rootlibdir=${libdir}])
2012-01-05 10:51:52 +08:00
AC_ARG_WITH([pamlibdir],
2012-01-07 07:36:35 +08:00
AS_HELP_STRING([--with-pamlibdir=DIR], [Directory for PAM modules]),
2012-01-05 10:51:52 +08:00
[],
[with_pamlibdir=${with_rootlibdir}/security])
Add pam configuration to allow user sessions to work out of the box
systemd-logind will start user@.service. user@.service unit uses
PAM with service name 'systemd-user' to perform account and session
managment tasks. Previously, the name was 'systemd-shared', it is
now changed to 'systemd-user'.
Most PAM installations use one common setup for different callers.
Based on a quick poll, distributions fall into two camps: those that
have system-auth (Redhat, Fedora, CentOS, Arch, Gentoo, Mageia,
Mandriva), and those that have common-auth (Debian, Ubuntu, OpenSUSE).
Distributions that have system-auth have just one configuration file
that contains auth, password, account, and session blocks, and
distributions that have common-auth also have common-session,
common-password, and common-account. It is thus impossible to use one
configuration file which would work for everybody. systemd-user now
refers to system-auth, because it seems that the approach with one
file is more popular and also easier, so let's follow that.
2013-09-12 02:31:14 +08:00
AC_ARG_WITH([pamconfdir],
AS_HELP_STRING([--with-pamconfdir=DIR], [Directory for PAM configuration]),
[],
[with_pamconfdir=${sysconfdir}/pam.d])
2012-02-10 19:10:41 +08:00
AC_ARG_ENABLE([split-usr],
AS_HELP_STRING([--enable-split-usr], [Assume that /bin, /sbin aren\'t symlinks into /usr]),
[],
[AS_IF([test "x${ac_default_prefix}" != "x${with_rootprefix}"], [
enable_split_usr=yes
], [
enable_split_usr=no
])])
AS_IF([test "x${enable_split_usr}" = "xyes"], [
2012-02-07 22:56:28 +08:00
AC_DEFINE(HAVE_SPLIT_USR, 1, [Define if /bin, /sbin aren't symlinks into /usr])
2012-02-10 19:10:41 +08:00
])
2012-02-07 22:56:28 +08:00
2013-02-07 10:11:27 +08:00
# Work around intltoolize and gtk-doc problems in VPATH builds
AM_CONDITIONAL([ENABLE_GTK_DOC_TESTS], [test "x$0" = "x./configure"],
[Define to do gtk-doc tests])
AS_IF([test "x$0" != "x./configure"], [
AC_SUBST([INTLTOOL_UPDATE], [/bin/true])
])
2013-04-18 20:40:24 +08:00
AC_ARG_ENABLE(tests,
[AC_HELP_STRING([--disable-tests], [disable tests])],
enable_tests=$enableval, enable_tests=yes)
AM_CONDITIONAL(ENABLE_TESTS, [test x$enable_tests = xyes])
2010-06-08 01:40:25 +08:00
AC_SUBST([dbuspolicydir], [$with_dbuspolicydir])
AC_SUBST([dbussessionservicedir], [$with_dbussessionservicedir])
AC_SUBST([dbussystemservicedir], [$with_dbussystemservicedir])
AC_SUBST([dbusinterfacedir], [$with_dbusinterfacedir])
2013-03-04 04:32:49 +08:00
AC_SUBST([bashcompletiondir], [$with_bashcompletiondir])
2013-07-25 13:57:05 +08:00
AC_SUBST([zshcompletiondir], [$with_zshcompletiondir])
2010-06-22 05:27:18 +08:00
AC_SUBST([pamlibdir], [$with_pamlibdir])
Add pam configuration to allow user sessions to work out of the box
systemd-logind will start user@.service. user@.service unit uses
PAM with service name 'systemd-user' to perform account and session
managment tasks. Previously, the name was 'systemd-shared', it is
now changed to 'systemd-user'.
Most PAM installations use one common setup for different callers.
Based on a quick poll, distributions fall into two camps: those that
have system-auth (Redhat, Fedora, CentOS, Arch, Gentoo, Mageia,
Mandriva), and those that have common-auth (Debian, Ubuntu, OpenSUSE).
Distributions that have system-auth have just one configuration file
that contains auth, password, account, and session blocks, and
distributions that have common-auth also have common-session,
common-password, and common-account. It is thus impossible to use one
configuration file which would work for everybody. systemd-user now
refers to system-auth, because it seems that the approach with one
file is more popular and also easier, so let's follow that.
2013-09-12 02:31:14 +08:00
AC_SUBST([pamconfdir], [$with_pamconfdir])
2012-01-05 07:40:39 +08:00
AC_SUBST([rootprefix], [$with_rootprefix])
2011-07-15 07:31:06 +08:00
AC_SUBST([rootlibdir], [$with_rootlibdir])
2010-06-02 06:35:58 +08:00
2012-04-04 03:24:46 +08:00
AC_CONFIG_FILES([
Makefile po/Makefile.in
2012-04-14 00:24:39 +08:00
docs/libudev/Makefile
docs/libudev/version.xml
docs/gudev/Makefile
docs/gudev/version.xml
2012-04-04 03:24:46 +08:00
])
2010-06-03 00:53:19 +08:00
AC_OUTPUT
2011-07-15 07:31:06 +08:00
AC_MSG_RESULT([
2010-04-07 21:35:01 +08:00
$PACKAGE_NAME $VERSION
2010-11-12 07:39:17 +08:00
libcryptsetup: ${have_libcryptsetup}
2010-06-17 03:54:17 +08:00
PAM: ${have_pam}
2010-08-26 09:23:03 +08:00
AUDIT: ${have_audit}
2012-03-16 02:06:11 +08:00
IMA: ${have_ima}
2014-02-20 23:19:44 +08:00
AppArmor: ${have_apparmor}
2010-08-26 09:23:03 +08:00
SELinux: ${have_selinux}
2014-02-12 08:29:54 +08:00
SECCOMP: ${have_seccomp}
2013-05-16 16:40:03 +08:00
SMACK: ${have_smack}
2011-12-21 09:40:59 +08:00
XZ: ${have_xz}
2014-07-04 10:42:22 +08:00
LZ4: ${have_lz4}
2011-05-24 10:20:35 +08:00
ACL: ${have_acl}
2012-08-14 02:31:10 +08:00
GCRYPT: ${have_gcrypt}
2012-08-21 04:02:19 +08:00
QRENCODE: ${have_qrencode}
2012-09-28 06:46:32 +08:00
MICROHTTPD: ${have_microhttpd}
2013-01-05 05:32:31 +08:00
CHKCONFIG: ${have_chkconfig}
2012-11-28 19:45:31 +08:00
GNUTLS: ${have_gnutls}
2014-03-18 10:52:53 +08:00
libcurl: ${have_libcurl}
2014-08-01 05:43:10 +08:00
libidn: ${have_libidn}
2014-06-19 18:07:12 +08:00
ELFUTILS: ${have_elfutils}
2011-04-27 05:31:09 +08:00
binfmt: ${have_binfmt}
2012-01-01 02:35:52 +08:00
vconsole: ${have_vconsole}
2012-10-18 07:01:12 +08:00
bootchart: ${have_bootchart}
2012-01-03 00:07:00 +08:00
quotacheck: ${have_quotacheck}
2013-06-02 16:54:44 +08:00
tmpfiles: ${have_tmpfiles}
sysusers: add minimal tool to reconstruct /etc/passwd and /etc/group from static files
systemd-sysusers is a tool to reconstruct /etc/passwd and /etc/group
from static definition files that take a lot of inspiration from
tmpfiles snippets. These snippets should carry information about system
users only. To make sure it is not misused for normal users these
snippets only allow configuring UID and gecos field for each user, but
do not allow configuration of the home directory or shell, which is
necessary for real login users.
The purpose of this tool is to enable state-less systems that can
populate /etc with the minimal files necessary, solely from static data
in /usr. systemd-sysuser is additive only, and will never override
existing users.
This tool will create these files directly, and not via some user
database abtsraction layer. This is appropriate as this tool is supposed
to run really early at boot, and is only useful for creating system
users, and system users cannot be stored in remote databases anyway.
The tool is also useful to be invoked from RPM scriptlets, instead of
useradd. This allows moving from imperative user descriptions in RPM to
declarative descriptions.
The UID/GID for a user/group to be created can either be chosen dynamic,
or fixed, or be read from the owner of a file in the file system, in
order to support reconstructing the correct IDs for files that shall be
owned by them.
This also adds a minimal user definition file, that should be
sufficient for most basic systems. Distributions are expected to patch
these files and augment the contents, for example with fixed UIDs for
the users where that's necessary.
2014-06-13 04:54:02 +08:00
sysusers: ${have_sysusers}
2014-07-07 21:05:37 +08:00
firstboot: ${have_firstboot}
2012-01-03 00:07:00 +08:00
randomseed: ${have_randomseed}
2013-08-14 07:57:02 +08:00
backlight: ${have_backlight}
2013-10-14 10:31:49 +08:00
rfkill: ${have_rfkill}
2011-12-31 13:02:42 +08:00
logind: ${have_logind}
2013-07-02 09:47:23 +08:00
machined: ${have_machined}
2011-08-02 07:09:13 +08:00
hostnamed: ${have_hostnamed}
2011-08-03 05:58:46 +08:00
timedated: ${have_timedated}
2014-04-29 14:57:51 +08:00
timesyncd: ${have_timesyncd}
2014-05-06 23:02:11 +08:00
default NTP servers: ${NTP_SERVERS}
2014-05-07 00:08:04 +08:00
time epoch: ${TIME_EPOCH}
2011-08-25 06:45:26 +08:00
localed: ${have_localed}
2014-02-21 22:21:21 +08:00
networkd: ${have_networkd}
2014-05-19 04:10:48 +08:00
resolved: ${have_resolved}
2014-05-16 21:24:09 +08:00
default DNS servers: ${DNS_SERVERS}
2012-01-14 07:37:35 +08:00
coredump: ${have_coredump}
2013-02-14 05:56:43 +08:00
polkit: ${have_polkit}
2013-02-14 06:07:59 +08:00
efi: ${have_efi}
2012-11-20 08:24:32 +08:00
kmod: ${have_kmod}
2012-11-16 08:17:18 +08:00
blkid: ${have_blkid}
2014-01-01 09:20:17 +08:00
dbus: ${have_dbus}
2013-01-06 01:37:52 +08:00
nss-myhostname: ${have_myhostname}
2012-04-04 03:24:46 +08:00
gudev: ${enable_gudev}
gintrospection: ${enable_introspection}
2014-06-12 23:51:14 +08:00
terminal: ${have_terminal}
2013-12-01 03:18:48 +08:00
kdbus: ${have_kdbus}
2012-09-13 10:01:18 +08:00
Python: ${have_python}
Python Headers: ${have_python_devel}
2012-12-22 17:09:23 +08:00
man pages: ${have_manpages}
gtk-doc: ${enable_gtk_doc}
2013-03-28 21:54:06 +08:00
test coverage: ${have_coverage}
2012-12-22 17:09:23 +08:00
Split /usr: ${enable_split_usr}
SysV compatibility: ${SYSTEM_SYSV_COMPAT}
2014-01-19 21:50:02 +08:00
compatibility libraries: ${have_compat_libs}
2014-09-24 23:25:00 +08:00
utmp/wtmp support: ${have_utmp}
2012-04-04 03:24:46 +08:00
2010-06-02 06:35:58 +08:00
prefix: ${prefix}
2012-01-05 07:40:39 +08:00
rootprefix: ${with_rootprefix}
2012-04-04 03:24:46 +08:00
sysconf dir: ${sysconfdir}
datarootdir: ${datarootdir}
includedir: ${includedir}
include_prefix: ${INCLUDE_PREFIX}
2011-07-15 07:31:06 +08:00
lib dir: ${libdir}
rootlib dir: ${with_rootlibdir}
2012-12-22 17:09:23 +08:00
SysV init scripts: ${SYSTEM_SYSVINIT_PATH}
SysV rc?.d directories: ${SYSTEM_SYSVRCND_PATH}
Build Python: ${PYTHON}
Installation Python: ${PYTHON_BINARY}
2013-09-27 14:24:00 +08:00
sphinx binary: ${SPHINX_BUILD}
2012-02-07 22:56:28 +08:00
PAM modules dir: ${with_pamlibdir}
Add pam configuration to allow user sessions to work out of the box
systemd-logind will start user@.service. user@.service unit uses
PAM with service name 'systemd-user' to perform account and session
managment tasks. Previously, the name was 'systemd-shared', it is
now changed to 'systemd-user'.
Most PAM installations use one common setup for different callers.
Based on a quick poll, distributions fall into two camps: those that
have system-auth (Redhat, Fedora, CentOS, Arch, Gentoo, Mageia,
Mandriva), and those that have common-auth (Debian, Ubuntu, OpenSUSE).
Distributions that have system-auth have just one configuration file
that contains auth, password, account, and session blocks, and
distributions that have common-auth also have common-session,
common-password, and common-account. It is thus impossible to use one
configuration file which would work for everybody. systemd-user now
refers to system-auth, because it seems that the approach with one
file is more popular and also easier, so let's follow that.
2013-09-12 02:31:14 +08:00
PAM configuration dir: ${with_pamconfdir}
2012-02-07 22:56:28 +08:00
D-Bus policy dir: ${with_dbuspolicydir}
D-Bus session dir: ${with_dbussessionservicedir}
D-Bus system dir: ${with_dbussystemservicedir}
D-Bus interfaces dir: ${with_dbusinterfacedir}
2013-03-04 04:32:49 +08:00
Bash completions dir: ${with_bashcompletiondir}
2013-07-25 13:57:05 +08:00
Zsh completions dir: ${with_zshcompletiondir}
2013-01-05 04:48:47 +08:00
Extra start script: ${RC_LOCAL_SCRIPT_PATH_START}
Extra stop script: ${RC_LOCAL_SCRIPT_PATH_STOP}
2013-04-25 08:51:23 +08:00
Debug shell: ${SUSHELL} @ ${DEBUGTTY}
2014-06-13 05:22:27 +08:00
TTY GID: ${TTY_GID}
2014-05-21 08:31:22 +08:00
Maximum System UID: ${SYSTEM_UID_MAX}
Maximum System GID: ${SYSTEM_GID_MAX}
2014-03-31 11:08:02 +08:00
Certificate root: ${CERTIFICATEROOT}
2012-05-08 08:51:26 +08:00
2012-08-08 18:03:34 +08:00
CFLAGS: ${OUR_CFLAGS} ${CFLAGS}
2013-03-20 22:23:30 +08:00
CPPFLAGS: ${OUR_CPPFLAGS} ${CPPFLAGS}
2012-08-08 18:03:34 +08:00
LDFLAGS: ${OUR_LDFLAGS} ${LDFLAGS}
2013-07-26 22:08:15 +08:00
PYTHON_CFLAGS: ${PYTHON_DEVEL_CFLAGS}
PYTHON_LIBS: ${PYTHON_DEVEL_LIBS}
2011-07-15 07:31:06 +08:00
])