blob: 1e0f27daa1c9976df519c9c6ecaca262a998ff5c [file] [log] [blame]
Matthew Barth6292aee2016-10-06 10:15:48 -05001# Initialization
2AC_PREREQ([2.69])
3AC_INIT([phosphor-hwmon], [1.0], [https://github.com/openbmc/phosphor-hwmon/issues])
Brad Bishop20938e42016-12-19 08:58:31 -05004AC_LANG([C++])
Matthew Barth6292aee2016-10-06 10:15:48 -05005AC_CONFIG_HEADERS([config.h])
6AM_INIT_AUTOMAKE([subdir-objects -Wall -Werror foreign dist-xz])
7AM_SILENT_RULES([yes])
8
9# Checks for programs.
10AC_PROG_CXX
11AM_PROG_AR
12AC_PROG_INSTALL
13AC_PROG_MAKE_SET
14
15# Checks for libraries.
Brad Bishopbf86e722017-02-16 11:10:40 -050016PKG_CHECK_MODULES([SDBUSPLUS], [sdbusplus], [], [AC_MSG_ERROR(["sdbusplus required and not found."])])
17PKG_CHECK_MODULES([PHOSPHOR_DBUS_INTERFACES], [phosphor-dbus-interfaces], [], [AC_MSG_ERROR(["phosphor-dbus-interfaces required and not found."])])
Brad Bishop4db64422017-02-16 11:33:32 -050018PKG_CHECK_MODULES([PHOSPHOR_LOGGING], [phosphor-logging], [], [AC_MSG_ERROR(["phosphor-logging required and not found."])])
Matthew Barth6292aee2016-10-06 10:15:48 -050019
20# Checks for typedefs, structures, and compiler characteristics.
21AX_CXX_COMPILE_STDCXX_14([noext])
Brad Bishop3b1b5d42016-12-05 15:05:57 -050022AX_APPEND_COMPILE_FLAGS([-fpic -Wall -Werror], [CXXFLAGS])
Matthew Barth6292aee2016-10-06 10:15:48 -050023
Brad Bishop20938e42016-12-19 08:58:31 -050024# Checks for header files.
Gunnar Millsca64c252017-10-25 17:13:45 -050025AC_CHECK_HEADER(sdbusplus/server.hpp, ,[AC_MSG_ERROR([Could not find sdbusplus/server.hpp...sdbusplus development package required])])
26AC_CHECK_HEADER(experimental/filesystem, ,[AC_MSG_ERROR([Could not find experimental/filesystem...libstdc++fs development package required])])
Brad Bishop20938e42016-12-19 08:58:31 -050027
Matthew Barth6292aee2016-10-06 10:15:48 -050028# Checks for library functions.
Brad Bishop0be1f8d2017-03-06 21:52:00 -050029LT_INIT
Matthew Barth6292aee2016-10-06 10:15:48 -050030
31# Check/set gtest specific functions.
Patrick Venturecaac77d2018-04-17 17:38:02 -070032PKG_CHECK_MODULES([GTEST], [gtest], [], [AC_MSG_NOTICE([gtest not found, tests will not build])])
33PKG_CHECK_MODULES([GMOCK], [gmock], [], [AC_MSG_NOTICE([gmock not found, tests will not build])])
34AX_PTHREAD([GTEST_CFLAGS+=" -DGTEST_HAS_PTHREAD=1 "],[GTEST_CFLAGS+=" -DGTEST_HAS_PTHREAD=0 "])
Matthew Barth6292aee2016-10-06 10:15:48 -050035
Patrick Venturecaac77d2018-04-17 17:38:02 -070036# Add --enable-oe-sdk flag to configure script
Matthew Barth6292aee2016-10-06 10:15:48 -050037AC_ARG_ENABLE([oe-sdk],
38 AS_HELP_STRING([--enable-oe-sdk], [Link testcases absolutely against OE SDK so they can be ran within it.])
39)
Patrick Venturecaac77d2018-04-17 17:38:02 -070040
41# Check for OECORE_TARGET_SYSROOT in the environment.
Matthew Barth6292aee2016-10-06 10:15:48 -050042AC_ARG_VAR(OECORE_TARGET_SYSROOT,
43 [Path to the OE SDK SYSROOT])
Patrick Venturecaac77d2018-04-17 17:38:02 -070044
45# Configure OESDK_TESTCASE_FLAGS environment variable, which will be later
46# used in test/Makefile.am
Matthew Barth6292aee2016-10-06 10:15:48 -050047AS_IF([test "x$enable_oe_sdk" == "xyes"],
48 AS_IF([test "x$OECORE_TARGET_SYSROOT" == "x"],
49 AC_MSG_ERROR([OECORE_TARGET_SYSROOT must be set with --enable-oe-sdk])
50 )
51 AC_MSG_NOTICE([Enabling OE-SDK at $OECORE_TARGET_SYSROOT])
52 [
53 testcase_flags="-Wl,-rpath,\${OECORE_TARGET_SYSROOT}/lib"
54 testcase_flags="${testcase_flags} -Wl,-rpath,\${OECORE_TARGET_SYSROOT}/usr/lib"
55 testcase_flags="${testcase_flags} -Wl,-dynamic-linker,`find \${OECORE_TARGET_SYSROOT}/lib/ld-*.so | sort -r -n | head -n1`"
56 ]
57 AC_SUBST([OESDK_TESTCASE_FLAGS], [$testcase_flags])
58)
59
Patrick Venturec1cece72017-11-07 12:09:49 -080060# When a sensor access fails, just remove the sensor from dbus instead of exiting the daemon.
Matt Spinlerf9c83c42017-08-10 08:51:45 -050061AC_ARG_ENABLE([remove-from-dbus-on-fail],
62 AS_HELP_STRING([--enable-remove-from-dbus-on-fail], [Remove properties from D-Bus on access failures])
63)
64
65AC_ARG_VAR(REMOVE_ON_FAIL, [Remove properties from D-Bus on access failures])
66
67AS_IF([test "x$enable_remove_from_dbus_on_fail" == "xyes"],
68 [REMOVE_ON_FAIL="yes"]
69 AC_DEFINE_UNQUOTED([REMOVE_ON_FAIL], ["$REMOVE_ON_FAIL"], [Remove properties from D-Bus on access failures])
70)
71
Patrick Venturec1cece72017-11-07 12:09:49 -080072# When a sensor read fails, set the Value on dbus with -errno.
73# Incompatible with remove-from-dbus-on-fail.
74AC_ARG_ENABLE([negative-errno-on-fail],
75 AS_HELP_STRING([--enable-negative-errno-on-fail], [Set sensor value to -errno on read failures])
76)
77
78AC_ARG_VAR(NEGATIVE_ERRNO_ON_FAIL, [Set sensor value to -errno on read failures])
79
80AS_IF([test "x$enable_negative_errno_on_fail" == "xyes"],
81 [NEGATIVE_ERRNO_ON_FAIL="yes"]
82 AC_DEFINE_UNQUOTED([NEGATIVE_ERRNO_ON_FAIL], ["$NEGATIVE_ERRNO_ON_FAIL"], [Set sensor value to -errno on read failures])
83)
84
Brad Bishopb9e2b072016-12-19 13:47:10 -050085AC_ARG_VAR(BUSNAME_PREFIX, [The DBus busname prefix.])
86AC_ARG_VAR(SENSOR_ROOT, [The DBus sensors namespace root.])
87AS_IF([test "x$BUSNAME_PREFIX" == "x"], [BUSNAME_PREFIX="xyz.openbmc_project.Hwmon"])
Leonel Gonzalez2260efb2017-02-23 10:40:40 -060088AS_IF([test "x$SENSOR_ROOT" == "x"], [SENSOR_ROOT="/xyz/openbmc_project/sensors"])
Brad Bishopb9e2b072016-12-19 13:47:10 -050089AC_DEFINE_UNQUOTED([BUSNAME_PREFIX], ["$BUSNAME_PREFIX"], [The DBus busname prefix.])
90AC_DEFINE_UNQUOTED([SENSOR_ROOT], ["$SENSOR_ROOT"], [The DBus sensors namespace root.])
91
Matthew Barth6292aee2016-10-06 10:15:48 -050092# Create configured output
Patrick Venturec635e862018-04-17 14:45:31 -070093AC_CONFIG_FILES([Makefile tools/Makefile msl/Makefile])
Matthew Barth6292aee2016-10-06 10:15:48 -050094AC_OUTPUT