blob: f3dee4a07744f5bc4b264d241a7c8eb522dfae81 [file] [log] [blame]
Adriana Kobylak88d7cf82017-01-24 12:30:15 -06001# Initialization
Adriana Kobylakf855c3e2016-09-29 20:48:08 -05002AC_PREREQ([2.69])
3AC_INIT([phosphor-logging], [1.0], [https://github.com/openbmc/phosphor-logging/issues])
Andrew Geissler09a05492017-01-18 13:57:33 -06004AC_LANG([C++])
Adriana Kobylakf855c3e2016-09-29 20:48:08 -05005AM_INIT_AUTOMAKE([subdir-objects -Wall -Werror foreign dist-xz])
Adriana Kobylakf855c3e2016-09-29 20:48:08 -05006AM_SILENT_RULES([yes])
7
8# Checks for programs
9AC_PROG_CXX
Adriana Kobylak88d7cf82017-01-24 12:30:15 -060010AM_PROG_AR
Adriana Kobylakf855c3e2016-09-29 20:48:08 -050011AC_PROG_INSTALL #Checks/sets the install variable to be used
12AC_PROG_MAKE_SET
Adriana Kobylak1a7508b2017-02-13 22:51:40 -060013AC_PROG_MKDIR_P
14AC_CHECK_PROG([DIRNAME], dirname, dirname)
Adriana Kobylakf855c3e2016-09-29 20:48:08 -050015
Marri Devender Raob0562c42017-10-12 23:55:08 -050016# Check for compiler, packages only when install_scripts flag is disabled.
Marri Devender Raodd508462017-09-20 04:17:58 -050017AC_ARG_ENABLE([install_scripts],
18 AS_HELP_STRING([--enable-install_scripts],
19 [Enable installing parser and mako script]),
Marri Devender Raobd682732017-10-12 02:06:55 -050020 [], [install_scripts=no])
21AM_CONDITIONAL([INSTALL_SCRIPTS], [test "x$enable_install_scripts" = "xyes"])
Marri Devender Raodd508462017-09-20 04:17:58 -050022AS_IF([test "x$enable_install_scripts" != "xyes"], [
23 # Checks for typedefs, structures, and compiler characteristics.
Vernon Mauery93b1b7c2018-10-04 10:00:12 -070024 AX_CXX_COMPILE_STDCXX_17([noext])
Marri Devender Raodd508462017-09-20 04:17:58 -050025 AX_APPEND_COMPILE_FLAGS([-fpic -Wall -Werror], [CXXFLAGS])
Adriana Kobylakf855c3e2016-09-29 20:48:08 -050026
Marri Devender Raodd508462017-09-20 04:17:58 -050027 # Python
28 AM_PATH_PYTHON([2.7], [AC_SUBST([PYTHON], [echo "$PYTHON"])], [AC_MSG_ERROR(
29 [Could not find python-2.7 installed...python-2.7 is required])])
Brad Bishop9316b9a2017-02-10 14:21:37 -050030
Gunnar Mills4133daf2018-04-08 16:28:21 -050031 # Suppress the --with-libtool-sysroot error
Marri Devender Raodd508462017-09-20 04:17:58 -050032 LT_INIT
Adriana Kobylakf855c3e2016-09-29 20:48:08 -050033
Marri Devender Raodd508462017-09-20 04:17:58 -050034 # Checks for libraries.
35 AX_PKG_CHECK_MODULES([SYSTEMD], [], [libsystemd >= 221], [], [AC_MSG_ERROR(["systemd required and not found."])])
36
37 # sdbusplus is non-private because we have no library to link.
38 # If we ever have a library, move this to private.
Patrick Venture8024d1d2019-02-13 08:28:17 -080039 AX_PKG_CHECK_MODULES([SDBUSPLUS], [sdbusplus])
40 AX_PKG_CHECK_MODULES([PHOSPHOR_DBUS_INTERFACES], [phosphor-dbus-interfaces])
Matt Spinler8ebfd312019-06-03 12:43:59 -050041 PKG_CHECK_MODULES([SDEVENTPLUS], [sdeventplus])
Marri Devender Raodd508462017-09-20 04:17:58 -050042
43 # Check for sdbus++
44 AC_PATH_PROG([SDBUSPLUSPLUS], [sdbus++])
45 AS_IF([test "x$SDBUSPLUSPLUS" == "x"],
46 AC_MSG_ERROR(["Requires sdbus++"]))
47])
Adriana Kobylakf855c3e2016-09-29 20:48:08 -050048
Andrew Geissler328889d2016-10-10 12:43:48 -050049# Check/set gtest specific functions.
50AX_PTHREAD([GTEST_CPPFLAGS="-DGTEST_HAS_PTHREAD=1"],[GTEST_CPPFLAGS="-DGTEST_HAS_PTHREAD=0"])
51AC_SUBST(GTEST_CPPFLAGS)
52
53# Test cases require SDK so only build if we're told to (and SDK is available)
54AC_ARG_ENABLE([oe-sdk],
55 AS_HELP_STRING([--enable-oe-sdk], [Link testcases absolutely against OE SDK so they can be ran within it.])
56)
57AC_ARG_VAR(OECORE_TARGET_SYSROOT,
58 [Path to the OE SDK SYSROOT])
59AS_IF([test "x$enable_oe_sdk" == "xyes"],
60 AS_IF([test "x$OECORE_TARGET_SYSROOT" == "x"],
61 AC_MSG_ERROR([OECORE_TARGET_SYSROOT must be set with --enable-oe-sdk])
62 )
63 AC_MSG_NOTICE([Enabling OE-SDK at $OECORE_TARGET_SYSROOT])
64 [
65 testcase_flags="-Wl,-rpath,\${OECORE_TARGET_SYSROOT}/lib"
66 testcase_flags="${testcase_flags} -Wl,-rpath,\${OECORE_TARGET_SYSROOT}/usr/lib"
67 testcase_flags="${testcase_flags} -Wl,-dynamic-linker,`find \${OECORE_TARGET_SYSROOT}/lib/ld-*.so | sort -r -n | head -n1`"
68 ]
69 AC_SUBST([OESDK_TESTCASE_FLAGS], [$testcase_flags])
70)
71
Adriana Kobylakc0f05322017-01-12 13:27:49 -060072AC_DEFINE(BUSNAME_LOGGING, "xyz.openbmc_project.Logging", [The log manager DBus busname to own.])
Adriana Kobylak7c30f492017-02-23 09:38:45 -060073AC_DEFINE(OBJ_LOGGING, "/xyz/openbmc_project/logging", [The log manager DBus object path.])
74AC_DEFINE(OBJ_INTERNAL, "/xyz/openbmc_project/logging/internal/manager", [The private log manager DBus object path.])
75AC_DEFINE(OBJ_ENTRY, "/xyz/openbmc_project/logging/entry", [The log entry DBus object path.])
Deepak Kodihalli682326a2017-03-06 05:26:53 -060076AC_DEFINE(INVENTORY_ROOT, "/xyz/openbmc_project/inventory", [The inventory root.])
77AC_DEFINE(CALLOUT_FWD_ASSOCIATION, "callout", [The name of the callout's forward association.])
78AC_DEFINE(CALLOUT_REV_ASSOCIATION, "fault", [The name of the callout's reverse association.])
Matt Spinler1275bd12018-05-01 15:13:53 -050079AC_DEFINE(BMC_VERSION_FILE, "/etc/os-release", [The file that contains the BMC firmware version])
Matt Spinler375ac9b2018-05-01 15:20:55 -050080AC_DEFINE(FIRST_CEREAL_CLASS_VERSION_WITH_FWLEVEL, "2",
81 [First Cereal class version with the BMC code version persisted])
Adriana Kobylakebd59fa2017-02-06 20:55:39 -060082
83AC_ARG_VAR(YAML_DIR_TEST, [The path to the test error yaml files.])
84AS_IF([test "x$YAML_DIR_TEST" == "x"], \
85 [YAML_DIR_TEST="${srcdir}/tools/"])
86AC_ARG_VAR(YAML_DIR, [The path to the yaml error files.])
87AS_IF([test "x$YAML_DIR" == "x"], \
88 [YAML_DIR="None"])
Deepak Kodihallia3db0772017-03-02 09:15:51 -060089AC_ARG_VAR(CALLOUTS_YAML, [YAML filepath containing generated callouts.])
90AS_IF([test "x$CALLOUTS_YAML" == "x"], \
91 [CALLOUTS_YAML="callouts-example.yaml"])
Adriana Kobylakebd59fa2017-02-06 20:55:39 -060092
Nagaraju Goruganti477b7312018-06-25 23:28:58 -050093AC_ARG_VAR(ERRLOG_PERSIST_PATH, [Path of directory housing persisted errors.])\
94AS_IF([test "x$ERRLOG_PERSIST_PATH" == "x"],
95 AS_IF([test "x$enable_oe_sdk" == "xyes"], \
96 [ERRLOG_PERSIST_PATH="/tmp/errors"])
97 AS_IF([test "x$enable_oe_sdk" == "x"], \
98 [ERRLOG_PERSIST_PATH="/var/lib/phosphor-logging/errors"])
99 AC_DEFINE_UNQUOTED([ERRLOG_PERSIST_PATH], ["$ERRLOG_PERSIST_PATH"], \
100 [Path of directory housing persisted errors])
101)
Deepak Kodihalli72654f12017-06-12 04:33:29 -0500102
Deepak Kodihalli58f16f72017-03-28 07:32:12 -0500103# Compile error metadata handlers if we're asked to do so.
104AC_ARG_ENABLE([metadata-processing],
105 AS_HELP_STRING([--enable-metadata-processing], [Compile metadata handlers]),
106 [AX_APPEND_COMPILE_FLAGS([-DPROCESS_META], [CXXFLAGS])]
107)
108
Marri Devender Rao7656fba2017-08-06 05:42:52 -0500109AC_ARG_VAR(ERROR_CAP, [Max number of error entries allowed for commit])
Andrew Geissler4de76fb2017-12-15 09:03:51 -0600110AS_IF([test "x$ERROR_CAP" == "x"], [ERROR_CAP=200])
Marri Devender Rao7656fba2017-08-06 05:42:52 -0500111AC_DEFINE_UNQUOTED([ERROR_CAP], [$ERROR_CAP], [Max number of error entries allowed for commit])
112
Nagaraju Gorugantif8a5a792017-10-13 08:09:52 -0500113AC_ARG_VAR(ERROR_INFO_CAP, [Cap on informational (and below) severity errors])
114AS_IF([test "x$ERROR_INFO_CAP" == "x"], [ERROR_INFO_CAP=10])
115AC_DEFINE_UNQUOTED([ERROR_INFO_CAP], [$ERROR_INFO_CAP], \
116 [Cap on informational (and below) severity errors])
117
Vishwanatha Subbanna37af9ba2017-09-28 16:33:53 +0530118AC_ARG_VAR(CLASS_VERSION, [Class version to register with Cereal])
Matt Spinler375ac9b2018-05-01 15:20:55 -0500119AS_IF([test "x$CLASS_VERSION" == "x"], [CLASS_VERSION=2])
Vishwanatha Subbanna37af9ba2017-09-28 16:33:53 +0530120AC_DEFINE_UNQUOTED([CLASS_VERSION], [$CLASS_VERSION], [Class version to register with Cereal])
121
Deepak Kodihallic4966192018-08-23 02:19:58 -0500122AC_ARG_VAR(RSYSLOG_SERVER_CONFIG_FILE, \
123 [Path of config file containing server address])
124AS_IF([test "x$RSYSLOG_SERVER_CONFIG_FILE" == "x"], \
125 [RSYSLOG_SERVER_CONFIG_FILE="/etc/rsyslog.d/server.conf"])
126AC_DEFINE_UNQUOTED([RSYSLOG_SERVER_CONFIG_FILE], \
127 ["$RSYSLOG_SERVER_CONFIG_FILE"], \
128 [Path of config file containing server address])
129
130AC_ARG_VAR(BUSNAME_SYSLOG_CONFIG, \
131 [D-Bus busname of syslog config service])
132AS_IF([test "x$BUSNAME_SYSLOG_CONFIG" == "x"], \
133 [BUSNAME_SYSLOG_CONFIG="xyz.openbmc_project.Syslog.Config"])
134AC_DEFINE_UNQUOTED([BUSNAME_SYSLOG_CONFIG], \
135 ["$BUSNAME_SYSLOG_CONFIG"], \
136 [D-Bus busname of syslog config service])
137
138AC_ARG_VAR(BUSPATH_REMOTE_LOGGING_CONFIG, \
139 [D-Bus path of remote logging config object])
140AS_IF([test "x$BUSPATH_REMOTE_LOGGING_CONFIG" == "x"], \
141 [BUSPATH_REMOTE_LOGGING_CONFIG="/xyz/openbmc_project/logging/config/remote"])
142AC_DEFINE_UNQUOTED([BUSPATH_REMOTE_LOGGING_CONFIG], \
143 ["$BUSPATH_REMOTE_LOGGING_CONFIG"], \
144 [D-Bus path of remote logging config object])
145
146AC_DEFINE(SYSTEMD_BUSNAME, "org.freedesktop.systemd1", [systemd busname.])
147AC_DEFINE(SYSTEMD_PATH, "/org/freedesktop/systemd1", [systemd path.])
148AC_DEFINE(SYSTEMD_INTERFACE, "org.freedesktop.systemd1.Manager", [systemd interface.])
149
Matt Spinler99c2b402019-05-23 14:29:16 -0500150AC_ARG_ENABLE([openpower-pel-extension],
151 AS_HELP_STRING([--enable-openpower-pel-extension], [Create PELs])
152)
Matt Spinlerdf13bdb2019-07-10 16:54:13 -0500153
154AC_ARG_VAR(EXTENSION_PERSIST_DIR, [Base directory for extension persistent data])
155AS_IF([test "x$EXTENSION_PERSIST_DIR" == "x"], \
156 [EXTENSION_PERSIST_DIR="/var/lib/phosphor-logging/extensions"])
157AC_DEFINE_UNQUOTED([EXTENSION_PERSIST_DIR], ["$EXTENSION_PERSIST_DIR"], \
158 [Base directory for extension persistent data])
159
Matt Spinler99c2b402019-05-23 14:29:16 -0500160AM_CONDITIONAL([ENABLE_PEL_EXTENSION], [test "x$enable_openpower_pel_extension" == "xyes"])
161
Matt Spinler367144c2019-09-19 15:33:52 -0500162AS_IF([test "x$enable_openpower_pel_extension" == "xyes"],
163 [AC_CHECK_HEADER(
164 nlohmann/json.hpp,
165 [],
166 [AC_MSG_ERROR([Could not find nlohmann/json.hpp])]])
Matt Spinleracb7c102020-01-10 13:49:22 -0600167 [AC_CHECK_HEADER(
168 fifo_map.hpp,
169 [],
170 [AC_MSG_ERROR([Could not find fifo_map.hpp])]])
Matt Spinler367144c2019-09-19 15:33:52 -0500171)
172
Adriana Kobylakf855c3e2016-09-29 20:48:08 -0500173AC_CONFIG_HEADERS([config.h])
Deepak Kodihallic4966192018-08-23 02:19:58 -0500174AC_CONFIG_FILES([Makefile test/Makefile phosphor-rsyslog-config/Makefile])
Brad Bishop9316b9a2017-02-10 14:21:37 -0500175AC_CONFIG_FILES([phosphor-logging.pc])
Adriana Kobylak8f7941e2016-11-14 14:46:23 -0600176AC_OUTPUT