blob: df031b0c04dd51375b1ae0543faf5fcbac9f165e [file] [log] [blame]
Patrick Venturee6206562018-03-08 15:36:53 -08001# Initialization
2AC_PREREQ([2.69])
Patrick Ventured7523572018-11-26 09:01:54 -08003AC_INIT([swampd], [0.1], [https://github.com/openbmc/phosphor-pid-control/issues])
Patrick Venturee6206562018-03-08 15:36:53 -08004AC_LANG([C++])
5AC_CONFIG_HEADERS([config.h])
Patrick Venture90e9dbc2019-03-19 09:10:41 -07006AM_INIT_AUTOMAKE([subdir-objects -Wall -Wno-portability -Werror foreign dist-xz])
Patrick Venturee6206562018-03-08 15:36:53 -08007AM_SILENT_RULES([yes])
8
Patrick Venture94feffa2019-03-06 09:54:49 -08009# Make sure the default CFLAGS of `-O2 -g` don't override CODE_COVERAGE_CFLAGS
10# It is important that this comes before AC_PROG_C{C,XX}, as we are attempting
11# to stop them from populating default CFLAGS and CXXFLAGS.
12AS_IF([test "x$enable_tests" = "xno"], [enable_code_coverage=no])
13AS_IF([test "x$enable_code_coverage" != "xno"], [
14 AS_IF([test "x${CXXFLAGS+set}" != "xset"], [
15 AC_SUBST(CXXFLAGS, [""])
16 ])
17 AS_IF([test "x${CFLAGS+set}" != "xset"], [
18 AC_SUBST(CFLAGS, [""])
19 ])
20])
21
Patrick Venturee6206562018-03-08 15:36:53 -080022# Checks for programs.
23AC_PROG_CXX
24AM_PROG_AR
25AC_PROG_INSTALL
26AC_PROG_MAKE_SET
27
Patrick Venturee6206562018-03-08 15:36:53 -080028# Checks for typedefs, structures, and compiler characteristics.
Patrick Venture54c2e5e2018-09-10 13:06:38 -070029AX_CXX_COMPILE_STDCXX_17([noext])
Patrick Ventureab28cb32018-06-20 18:37:48 -070030AX_APPEND_COMPILE_FLAGS([-fpic -Wall -Werror], [CXXFLAGS])
Patrick Venturee6206562018-03-08 15:36:53 -080031
32# Checks for libraries.
Patrick Venturee54c7ff2018-11-21 21:30:56 -080033PKG_CHECK_MODULES(
34 [SYSTEMD],
35 [libsystemd >= 221],
36 [],
37 [AC_MSG_ERROR(["systemd required and not found"])]
38)
Patrick Venturef72ad442019-02-13 07:28:58 -080039PKG_CHECK_MODULES([SDBUSPLUS], [sdbusplus])
40PKG_CHECK_MODULES([PHOSPHOR_LOGGING], [phosphor-logging])
41PKG_CHECK_MODULES([PHOSPHOR_DBUS_INTERFACES], [phosphor-dbus-interfaces])
William A. Kennington III331143c2019-02-07 15:52:44 -080042PKG_CHECK_MODULES(
43 [LIBIPMID],
44 [libipmid],
45 [],
46 [AC_MSG_ERROR([Could not find libipmid...openbmc/phosphor-host-ipmid package required])]
Patrick Venturee54c7ff2018-11-21 21:30:56 -080047)
48AC_CHECK_HEADER(
Patrick Venture31eebcd2019-02-12 07:23:42 -080049 nlohmann/json.hpp,
50 [],
51 [AC_MSG_ERROR([Could not find nlohmann/json.hpp])]
52)
Patrick Ventureb5cc37c2019-03-11 09:11:55 -070053# We need the header only CLI library
54AC_CHECK_HEADERS(
55 [CLI/CLI.hpp],
56 [],
57 [AC_MSG_ERROR([Could not find CLI11 CLI/CLI.hpp])]
58)
Patrick Venture2e3ecb52018-06-22 08:18:19 -070059AX_PTHREAD([], [AC_MSG_ERROR(["pthread required and not found"])])
Patrick Venturee6206562018-03-08 15:36:53 -080060
61# Checks for library functions.
62LT_INIT # Required for systemd linking
63
Patrick Venture90f9bb52019-03-06 09:39:11 -080064# Make it possible for users to choose if they want test support
65# explicitly or not at all
66AC_ARG_ENABLE([tests], AC_HELP_STRING([--disable-tests],
67 [Build test cases]))
68
Patrick Venturee6206562018-03-08 15:36:53 -080069# Check/set gtest specific functions.
Patrick Venture90f9bb52019-03-06 09:39:11 -080070AS_IF([test "x$enable_tests" != "xno"], [
71 PKG_CHECK_MODULES([GTEST], [gtest], [], [true])
72 PKG_CHECK_MODULES([GMOCK], [gmock], [], [true])
73 AX_PTHREAD
74
75 AX_SAVE_FLAGS_WITH_PREFIX(OLD, [CPPFLAGS])
76 AX_APPEND_COMPILE_FLAGS([$GTEST_CFLAGS], [CPPFLAGS])
77 AC_LANG_PUSH([C++])
78 AC_CHECK_HEADERS([gtest/gtest.h], [
79 AS_IF([test "x$GTEST_CFLAGS" = "x"], [
80 AS_IF([test "x$PTHREAD_CFLAGS" = "x"], [
81 AX_APPEND_COMPILE_FLAGS(["-DGTEST_HAS_PTHREAD=0"], [GTEST_CFLAGS])
82 ], [
83 AX_APPEND_COMPILE_FLAGS(["-DGTEST_HAS_PTHREAD=1"], [GTEST_CFLAGS])
84 AX_APPEND_COMPILE_FLAGS([$PTHREAD_CFLAGS], [GTEST_CFLAGS])
85 ])
86 ])
87 ], [
88 AS_IF([test "x$enable_tests" = "xyes"], [
89 AC_MSG_ERROR([Testing enabled but could not find gtest/gtest.h])
90 ])
91 ])
92 AC_LANG_POP([C++])
93 AX_RESTORE_FLAGS_WITH_PREFIX(OLD, [CPPFLAGS])
94
95 AX_SAVE_FLAGS_WITH_PREFIX(OLD, [CPPFLAGS])
96 AX_APPEND_COMPILE_FLAGS([$GMOCK_CFLAGS], [CPPFLAGS])
97 AC_LANG_PUSH([C++])
98 AC_CHECK_HEADERS([gmock/gmock.h], [], [
99 AS_IF([test "x$enable_tests" = "xyes"], [
100 AC_MSG_ERROR([Testing enabled but could not find gmock/gmock.h])
101 ])
102 ])
103 AC_LANG_POP([C++])
104 AX_RESTORE_FLAGS_WITH_PREFIX(OLD, [CPPFLAGS])
105
106 AX_SAVE_FLAGS_WITH_PREFIX(OLD, [LDFLAGS])
107 AX_APPEND_COMPILE_FLAGS([$GTEST_LIBS], [LDFLAGS])
108 AC_CHECK_LIB([gtest], [main], [
109 AS_IF([test "x$GTEST_LIBS" = "x"], [
110 AX_APPEND_COMPILE_FLAGS([-lgtest], [GTEST_LIBS])
111 ])
112 ], [
113 AS_IF([test "x$enable_tests" = "xyes"], [
114 AC_MSG_ERROR([Testing enabled but couldn't find gtest libs])
115 ])
116 ])
117 AX_RESTORE_FLAGS_WITH_PREFIX(OLD, [LDFLAGS])
118
119 AX_SAVE_FLAGS_WITH_PREFIX(OLD, [LDFLAGS])
120 AX_APPEND_COMPILE_FLAGS([$GMOCK_LIBS], [LDFLAGS])
121 AC_CHECK_LIB([gmock], [main], [
122 AS_IF([test "x$GMOCK_LIBS" = "x"], [
123 AX_APPEND_COMPILE_FLAGS([-lgmock], [GMOCK_LIBS])
124 ])
125 ], [
126 AS_IF([test "x$enable_tests" = "xyes"], [
127 AC_MSG_ERROR([Testing enabled but couldn't find gmock libs])
128 ])
129 ])
130 AX_RESTORE_FLAGS_WITH_PREFIX(OLD, [LDFLAGS])
131])
Patrick Venturee6206562018-03-08 15:36:53 -0800132
Patrick Venture94feffa2019-03-06 09:54:49 -0800133# Code coverage
134AX_CODE_COVERAGE
Patrick Venture94feffa2019-03-06 09:54:49 -0800135AS_IF([test "x$CODE_COVERAGE_ENABLED" = "xyes"], [
136 AX_APPEND_COMPILE_FLAGS([-DHAVE_GCOV], [CODE_COVERAGE_CPPFLAGS])
137])
Patrick Venture90e9dbc2019-03-19 09:10:41 -0700138m4_ifdef([_AX_CODE_COVERAGE_RULES],
139 [AM_CONDITIONAL(AUTOCONF_CODE_COVERAGE_2019_01_06, [true])],
140 [AM_CONDITIONAL(AUTOCONF_CODE_COVERAGE_2019_01_06, [false])])
141AX_ADD_AM_MACRO_STATIC([])
Patrick Venture94feffa2019-03-06 09:54:49 -0800142
Patrick Venturee6206562018-03-08 15:36:53 -0800143AC_ARG_ENABLE([oe-sdk],
Patrick Venturef77ecc72018-11-26 09:08:49 -0800144 AS_HELP_STRING(
145 [--enable-oe-sdk],
146 [Link testcases absolutely against OE SDK so they can be ran within it.]
147 )
Patrick Venturee6206562018-03-08 15:36:53 -0800148)
149AC_ARG_VAR(OECORE_TARGET_SYSROOT,
Patrick Venturef77ecc72018-11-26 09:08:49 -0800150 [Path to the OE SDK SYSROOT]
151)
Patrick Venturee6206562018-03-08 15:36:53 -0800152AS_IF([test "x$enable_oe_sdk" == "xyes"],
153 AS_IF([test "x$OECORE_TARGET_SYSROOT" == "x"],
154 AC_MSG_ERROR([OECORE_TARGET_SYSROOT must be set with --enable-oe-sdk])
155 )
156 AC_MSG_NOTICE([Enabling OE-SDK at $OECORE_TARGET_SYSROOT])
157 [
158 testcase_flags="-Wl,-rpath,\${OECORE_TARGET_SYSROOT}/lib"
159 testcase_flags="${testcase_flags} -Wl,-rpath,\${OECORE_TARGET_SYSROOT}/usr/lib"
160 testcase_flags="${testcase_flags} -Wl,-dynamic-linker,`find \${OECORE_TARGET_SYSROOT}/lib/ld-*.so | sort -r -n | head -n1`"
161 ]
162 AC_SUBST([OESDK_TESTCASE_FLAGS], [$testcase_flags])
163)
164
James Feist7136a5a2018-07-19 09:52:05 -0700165AC_ARG_ENABLE([configure-dbus],
Patrick Venturef77ecc72018-11-26 09:08:49 -0800166 AS_HELP_STRING(
167 [--enable-configure-dbus], [Enable configuring pid from D-Bus.]
168 )
169)
James Feist7136a5a2018-07-19 09:52:05 -0700170AM_CONDITIONAL(CONFIGURE_DBUS, [test "x$enable_configure_dbus" = "xyes"])
171AS_IF([test "x$enable_configure_dbus" = "xyes"],
James Feistce15e022018-09-26 10:01:33 -0700172 [AC_DEFINE(CONFIGURE_DBUS, [1], [Read configuration from D-Bus.])],
173 [AC_DEFINE(CONFIGURE_DBUS, [0], [Do not read configuration from D-Bus.])]
James Feist7136a5a2018-07-19 09:52:05 -0700174)
175
Patrick Venturee6206562018-03-08 15:36:53 -0800176# Create configured output
Patrick Venture7a841b62018-06-13 09:39:46 -0700177AC_CONFIG_FILES([Makefile test/Makefile])
Patrick Venturee6206562018-03-08 15:36:53 -0800178AC_OUTPUT