blob: ce9b8bb71821cd036e5b0fcae0f672242fe9f403 [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.
24 AX_CXX_COMPILE_STDCXX_14([noext])
25 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.
39 AX_PKG_CHECK_MODULES([SDBUSPLUS], [sdbusplus], [], [], [AC_MSG_ERROR(["sdbusplus required and not found."])])
40 AX_PKG_CHECK_MODULES([PHOSPHOR_DBUS_INTERFACES], [], [phosphor-dbus-interfaces], [], [AC_MSG_ERROR(["phosphor-dbus-interfaces required and not found."])])
41
42 # Check for sdbus++
43 AC_PATH_PROG([SDBUSPLUSPLUS], [sdbus++])
44 AS_IF([test "x$SDBUSPLUSPLUS" == "x"],
45 AC_MSG_ERROR(["Requires sdbus++"]))
46])
Adriana Kobylakf855c3e2016-09-29 20:48:08 -050047
Andrew Geissler328889d2016-10-10 12:43:48 -050048# Check/set gtest specific functions.
49AX_PTHREAD([GTEST_CPPFLAGS="-DGTEST_HAS_PTHREAD=1"],[GTEST_CPPFLAGS="-DGTEST_HAS_PTHREAD=0"])
50AC_SUBST(GTEST_CPPFLAGS)
51
52# Test cases require SDK so only build if we're told to (and SDK is available)
53AC_ARG_ENABLE([oe-sdk],
54 AS_HELP_STRING([--enable-oe-sdk], [Link testcases absolutely against OE SDK so they can be ran within it.])
55)
56AC_ARG_VAR(OECORE_TARGET_SYSROOT,
57 [Path to the OE SDK SYSROOT])
58AS_IF([test "x$enable_oe_sdk" == "xyes"],
59 AS_IF([test "x$OECORE_TARGET_SYSROOT" == "x"],
60 AC_MSG_ERROR([OECORE_TARGET_SYSROOT must be set with --enable-oe-sdk])
61 )
62 AC_MSG_NOTICE([Enabling OE-SDK at $OECORE_TARGET_SYSROOT])
63 [
64 testcase_flags="-Wl,-rpath,\${OECORE_TARGET_SYSROOT}/lib"
65 testcase_flags="${testcase_flags} -Wl,-rpath,\${OECORE_TARGET_SYSROOT}/usr/lib"
66 testcase_flags="${testcase_flags} -Wl,-dynamic-linker,`find \${OECORE_TARGET_SYSROOT}/lib/ld-*.so | sort -r -n | head -n1`"
67 ]
68 AC_SUBST([OESDK_TESTCASE_FLAGS], [$testcase_flags])
69)
70
Adriana Kobylakc0f05322017-01-12 13:27:49 -060071AC_DEFINE(BUSNAME_LOGGING, "xyz.openbmc_project.Logging", [The log manager DBus busname to own.])
Adriana Kobylak7c30f492017-02-23 09:38:45 -060072AC_DEFINE(OBJ_LOGGING, "/xyz/openbmc_project/logging", [The log manager DBus object path.])
73AC_DEFINE(OBJ_INTERNAL, "/xyz/openbmc_project/logging/internal/manager", [The private log manager DBus object path.])
74AC_DEFINE(OBJ_ENTRY, "/xyz/openbmc_project/logging/entry", [The log entry DBus object path.])
Deepak Kodihalli682326a2017-03-06 05:26:53 -060075AC_DEFINE(INVENTORY_ROOT, "/xyz/openbmc_project/inventory", [The inventory root.])
76AC_DEFINE(CALLOUT_FWD_ASSOCIATION, "callout", [The name of the callout's forward association.])
77AC_DEFINE(CALLOUT_REV_ASSOCIATION, "fault", [The name of the callout's reverse association.])
Matt Spinler1275bd12018-05-01 15:13:53 -050078AC_DEFINE(BMC_VERSION_FILE, "/etc/os-release", [The file that contains the BMC firmware version])
Matt Spinler375ac9b2018-05-01 15:20:55 -050079AC_DEFINE(FIRST_CEREAL_CLASS_VERSION_WITH_FWLEVEL, "2",
80 [First Cereal class version with the BMC code version persisted])
Adriana Kobylakebd59fa2017-02-06 20:55:39 -060081
82AC_ARG_VAR(YAML_DIR_TEST, [The path to the test error yaml files.])
83AS_IF([test "x$YAML_DIR_TEST" == "x"], \
84 [YAML_DIR_TEST="${srcdir}/tools/"])
85AC_ARG_VAR(YAML_DIR, [The path to the yaml error files.])
86AS_IF([test "x$YAML_DIR" == "x"], \
87 [YAML_DIR="None"])
Deepak Kodihallia3db0772017-03-02 09:15:51 -060088AC_ARG_VAR(CALLOUTS_YAML, [YAML filepath containing generated callouts.])
89AS_IF([test "x$CALLOUTS_YAML" == "x"], \
90 [CALLOUTS_YAML="callouts-example.yaml"])
Adriana Kobylakebd59fa2017-02-06 20:55:39 -060091
Nagaraju Goruganti477b7312018-06-25 23:28:58 -050092AC_ARG_VAR(ERRLOG_PERSIST_PATH, [Path of directory housing persisted errors.])\
93AS_IF([test "x$ERRLOG_PERSIST_PATH" == "x"],
94 AS_IF([test "x$enable_oe_sdk" == "xyes"], \
95 [ERRLOG_PERSIST_PATH="/tmp/errors"])
96 AS_IF([test "x$enable_oe_sdk" == "x"], \
97 [ERRLOG_PERSIST_PATH="/var/lib/phosphor-logging/errors"])
98 AC_DEFINE_UNQUOTED([ERRLOG_PERSIST_PATH], ["$ERRLOG_PERSIST_PATH"], \
99 [Path of directory housing persisted errors])
100)
Deepak Kodihalli72654f12017-06-12 04:33:29 -0500101
Deepak Kodihalli58f16f72017-03-28 07:32:12 -0500102# Compile error metadata handlers if we're asked to do so.
103AC_ARG_ENABLE([metadata-processing],
104 AS_HELP_STRING([--enable-metadata-processing], [Compile metadata handlers]),
105 [AX_APPEND_COMPILE_FLAGS([-DPROCESS_META], [CXXFLAGS])]
106)
107
Marri Devender Rao7656fba2017-08-06 05:42:52 -0500108AC_ARG_VAR(ERROR_CAP, [Max number of error entries allowed for commit])
Andrew Geissler4de76fb2017-12-15 09:03:51 -0600109AS_IF([test "x$ERROR_CAP" == "x"], [ERROR_CAP=200])
Marri Devender Rao7656fba2017-08-06 05:42:52 -0500110AC_DEFINE_UNQUOTED([ERROR_CAP], [$ERROR_CAP], [Max number of error entries allowed for commit])
111
Nagaraju Gorugantif8a5a792017-10-13 08:09:52 -0500112AC_ARG_VAR(ERROR_INFO_CAP, [Cap on informational (and below) severity errors])
113AS_IF([test "x$ERROR_INFO_CAP" == "x"], [ERROR_INFO_CAP=10])
114AC_DEFINE_UNQUOTED([ERROR_INFO_CAP], [$ERROR_INFO_CAP], \
115 [Cap on informational (and below) severity errors])
116
Vishwanatha Subbanna37af9ba2017-09-28 16:33:53 +0530117AC_ARG_VAR(CLASS_VERSION, [Class version to register with Cereal])
Matt Spinler375ac9b2018-05-01 15:20:55 -0500118AS_IF([test "x$CLASS_VERSION" == "x"], [CLASS_VERSION=2])
Vishwanatha Subbanna37af9ba2017-09-28 16:33:53 +0530119AC_DEFINE_UNQUOTED([CLASS_VERSION], [$CLASS_VERSION], [Class version to register with Cereal])
120
Deepak Kodihallic4966192018-08-23 02:19:58 -0500121AC_ARG_VAR(RSYSLOG_SERVER_CONFIG_FILE, \
122 [Path of config file containing server address])
123AS_IF([test "x$RSYSLOG_SERVER_CONFIG_FILE" == "x"], \
124 [RSYSLOG_SERVER_CONFIG_FILE="/etc/rsyslog.d/server.conf"])
125AC_DEFINE_UNQUOTED([RSYSLOG_SERVER_CONFIG_FILE], \
126 ["$RSYSLOG_SERVER_CONFIG_FILE"], \
127 [Path of config file containing server address])
128
129AC_ARG_VAR(BUSNAME_SYSLOG_CONFIG, \
130 [D-Bus busname of syslog config service])
131AS_IF([test "x$BUSNAME_SYSLOG_CONFIG" == "x"], \
132 [BUSNAME_SYSLOG_CONFIG="xyz.openbmc_project.Syslog.Config"])
133AC_DEFINE_UNQUOTED([BUSNAME_SYSLOG_CONFIG], \
134 ["$BUSNAME_SYSLOG_CONFIG"], \
135 [D-Bus busname of syslog config service])
136
137AC_ARG_VAR(BUSPATH_REMOTE_LOGGING_CONFIG, \
138 [D-Bus path of remote logging config object])
139AS_IF([test "x$BUSPATH_REMOTE_LOGGING_CONFIG" == "x"], \
140 [BUSPATH_REMOTE_LOGGING_CONFIG="/xyz/openbmc_project/logging/config/remote"])
141AC_DEFINE_UNQUOTED([BUSPATH_REMOTE_LOGGING_CONFIG], \
142 ["$BUSPATH_REMOTE_LOGGING_CONFIG"], \
143 [D-Bus path of remote logging config object])
144
145AC_DEFINE(SYSTEMD_BUSNAME, "org.freedesktop.systemd1", [systemd busname.])
146AC_DEFINE(SYSTEMD_PATH, "/org/freedesktop/systemd1", [systemd path.])
147AC_DEFINE(SYSTEMD_INTERFACE, "org.freedesktop.systemd1.Manager", [systemd interface.])
148
Adriana Kobylakf855c3e2016-09-29 20:48:08 -0500149AC_CONFIG_HEADERS([config.h])
Deepak Kodihallic4966192018-08-23 02:19:58 -0500150AC_CONFIG_FILES([Makefile test/Makefile phosphor-rsyslog-config/Makefile])
Brad Bishop9316b9a2017-02-10 14:21:37 -0500151AC_CONFIG_FILES([phosphor-logging.pc])
Adriana Kobylak8f7941e2016-11-14 14:46:23 -0600152AC_OUTPUT