blob: 2074692c007f24d9c1209a8aa0b79fe40a53871d [file] [log] [blame]
Matt Spinlerc1d65772018-03-27 10:15:32 -05001AC_PREREQ([2.69])
2AC_INIT([ibm-logging], [1.0], [https://github.com/openbmc/ibm-logging/issues])
3AC_LANG([C++])
4AC_CONFIG_HEADERS([config.h])
5AM_INIT_AUTOMAKE([subdir-objects -Wall -Werror foreign dist-xz])
6AM_SILENT_RULES([yes])
7
8# Checks for programs.
9AC_PROG_CXX
10AC_PROG_INSTALL
11AC_PROG_MAKE_SET
12
Matt Spinlere0017eb2018-03-27 11:17:38 -050013PKG_CHECK_MODULES([PHOSPHOR_DBUS_INTERFACES], [phosphor-dbus-interfaces],,\
14 AC_MSG_ERROR(["Requires openbmc/phosphor-dbus-interfaces package."]))
Matt Spinler4a6ea6a2018-03-27 14:25:12 -050015PKG_CHECK_MODULES([IBM_DBUS_INTERFACES], [ibm-dbus-interfaces],,\
16 AC_MSG_ERROR(["Requires openbmc/ibm-dbus-interfaces package."]))
Matt Spinlere0017eb2018-03-27 11:17:38 -050017PKG_CHECK_MODULES([SDBUSPLUS], [sdbusplus],,
18 AC_MSG_ERROR(["Requires openbmc/sdbusplus package."]))
19PKG_CHECK_MODULES([PHOSPHOR_LOGGING], [phosphor-logging],,\
20 AC_MSG_ERROR(["Requires openbmc/phosphor-logging package."]))
21
Matt Spinler8c0a63f2018-03-27 12:27:23 -050022AC_CHECK_HEADER(nlohmann/json.hpp, ,
23 [AC_MSG_ERROR([Could not find nlohmann/json.hpp... nlohmann/json package required])])
24
Matt Spinleref3b86f2018-05-23 11:19:10 -050025AC_CHECK_HEADER(cereal/archives/binary.hpp, ,
26 [AC_MSG_ERROR([Could not find cereal/archives/binary.hpp... cereal package required])])
27
Matt Spinlerc1d65772018-03-27 10:15:32 -050028# Checks for typedefs, structures, and compiler characteristics.
29AX_CXX_COMPILE_STDCXX_14([noext])
30AX_APPEND_COMPILE_FLAGS([-Wall -Werror], [CXXFLAGS])
31
32LT_INIT
33
Matt Spinlerb96fa322018-03-27 13:39:33 -050034# Check/set gtest specific functions.
35AX_PTHREAD([GTEST_CPPFLAGS="-DGTEST_HAS_PTHREAD=1"],[GTEST_CPPFLAGS="-DGTEST_HAS_PTHREAD=0"])
36AC_SUBST(GTEST_CPPFLAGS)
37AC_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)
40AC_ARG_VAR(OECORE_TARGET_SYSROOT,
41 [Path to the OE SDK SYSROOT])
42AS_IF([test "x$enable_oe_sdk" == "xyes"],
43 AS_IF([test "x$OECORE_TARGET_SYSROOT" == "x"],
44 AC_MSG_ERROR([OECORE_TARGET_SYSROOT must be set with --enable-oe-sdk])
45 )
46 AC_MSG_NOTICE([Enabling OE-SDK at $OECORE_TARGET_SYSROOT])
47 [
48 testcase_flags="-Wl,-rpath,\${OECORE_TARGET_SYSROOT}/lib"
49 testcase_flags="${testcase_flags} -Wl,-rpath,\${OECORE_TARGET_SYSROOT}/usr/lib"
50 testcase_flags="${testcase_flags} -Wl,-dynamic-linker,`find \${OECORE_TARGET_SYSROOT}/lib/ld-*.so | sort -r -n | head -n1`"
51 ]
52 AC_SUBST([OESDK_TESTCASE_FLAGS], [$testcase_flags])
53)
54
Matt Spinler743e5822018-03-27 13:44:50 -050055#The policy data must have been defined by the service folks
56#for it to be used, so allow its use to be configurable and
57#default it to off.
58AC_ARG_ENABLE([policy-interface],
59 AS_HELP_STRING([--enable-policy-interface],
60 [Enable the Policy D-Bus interface])
61)
62
63AC_ARG_VAR(USE_POLICY_INTERFACE, [If the Policy D-Bus interface should be created])
64
65AS_IF([test "x$enable_policy_interface" == "xyes"],
66 [USE_POLICY_INTERFACE="yes"]
67 AC_DEFINE_UNQUOTED([USE_POLICY_INTERFACE], ["$USE_POLICY_INTERFACE"],
68 [If the Policy D-Bus interface should be created])
69)
70
Matt Spinlere0017eb2018-03-27 11:17:38 -050071AC_DEFINE(LOGGING_PATH, "/xyz/openbmc_project/logging",
72 [The xyz log manager DBus object path])
73AC_DEFINE(LOGGING_IFACE, "xyz.openbmc_project.Logging.Entry",
74 [The xyz log entry interface])
Matt Spinler54bfa7e2018-03-27 11:28:59 -050075AC_DEFINE(LOGGING_BUSNAME, "xyz.openbmc_project.Logging",
76 [The xyz logging busname])
Matt Spinler57724a92018-03-27 11:31:59 -050077AC_DEFINE(IBM_LOGGING_BUSNAME, "com.ibm.Logging",
78 [The IBM log manager DBus busname to own])
Matt Spinler52ee71b2018-05-23 13:18:55 -050079AC_DEFINE(ASSOC_IFACE, "org.openbmc.Associations",
80 [The associations interface])
81AC_DEFINE(ASSET_IFACE, "xyz.openbmc_project.Inventory.Decorator.Asset",
82 [The asset interface])
Matt Spinlere0017eb2018-03-27 11:17:38 -050083
Matt Spinler7ce3eef2018-03-27 13:54:48 -050084AC_DEFINE(DEFAULT_POLICY_EID, "None",
85 [The default event ID to use])
86AC_DEFINE(DEFAULT_POLICY_MSG, "An internal BMC error occurred",
87 [The default policy message to use])
88
Matt Spinler743e5822018-03-27 13:44:50 -050089AC_ARG_VAR(POLICY_JSON_PATH, [The path to the policy json file])
90AS_IF([test "x$POLICY_JSON_PATH" == "x"], [POLICY_JSON_PATH="/usr/share/ibm-logging/policy.json"])
91AC_DEFINE_UNQUOTED([POLICY_JSON_PATH], ["$POLICY_JSON_PATH"], [The path to the policy json file on the BMC])
92
Matt Spinler52ee71b2018-05-23 13:18:55 -050093AC_ARG_VAR(ERRLOG_PERSIST_PATH, [Path to save errors in])
94AS_IF([test "x$ERRLOG_PERSIST_PATH" == "x"], \
95 [ERRLOG_PERSIST_PATH="/var/lib/ibm-logging/errors"])
96AC_DEFINE_UNQUOTED([ERRLOG_PERSIST_PATH], ["$ERRLOG_PERSIST_PATH"], \
97 [Path to save errors in])
98
Matt Spinleref3b86f2018-05-23 11:19:10 -050099AC_ARG_VAR(CALLOUT_CLASS_VERSION,
100 [Callout class version to register with Cereal])
101AS_IF([test "x$CALLOUT_CLASS_VERSION" == "x"],
102 [CALLOUT_CLASS_VERSION=1])
103AC_DEFINE_UNQUOTED([CALLOUT_CLASS_VERSION], [$CALLOUT_CLASS_VERSION],
104 [Callout Class version to register with Cereal])
105
Matt Spinlerb96fa322018-03-27 13:39:33 -0500106AC_CONFIG_FILES([Makefile test/Makefile])
Matt Spinlerc1d65772018-03-27 10:15:32 -0500107AC_OUTPUT