blob: 3c8fadc48d339954af5df39e66d6591845e17f11 [file] [log] [blame]
Matthew Barth3cff7ed2016-07-27 14:50:51 -05001# Initialization
2AC_PREREQ([2.69])
3AC_INIT([phosphor-host-ipmid], [1.0], [https://github.com/openbmc/phosphor-host-ipmid/issues])
4AC_CONFIG_HEADERS([config.h])
5AM_INIT_AUTOMAKE([subdir-objects -Wall -Werror foreign dist-xz])
Matthew Barth00b1e5b2016-09-09 12:15:46 -05006AM_SILENT_RULES([yes])
Matthew Barth3cff7ed2016-07-27 14:50:51 -05007
8# Checks for programs.
9AC_PROG_CXX
Matthew Barth3cff7ed2016-07-27 14:50:51 -050010AC_PROG_CC
Patrick Williams686df742016-09-02 17:52:59 -050011AM_PROG_AR
Matthew Barth3cff7ed2016-07-27 14:50:51 -050012AC_PROG_INSTALL
13AC_PROG_MAKE_SET
14
Vishwanatha Subbanna506aa0f2017-01-24 14:58:25 +053015# softoff dir specific ones
16AC_ARG_ENABLE([softoff],
17 AS_HELP_STRING([--enable-softoff], [Builds soft power off])
18)
19AS_IF([test "x$enable_softoff" != "xno"],
20 [AC_PROG_MKDIR_P]
21 [AC_CHECK_PROG([DIRNAME], dirname, dirname)]
22)
23
Matthew Barth3cff7ed2016-07-27 14:50:51 -050024# Checks for libraries.
Matthew Barth80f714b2016-11-09 15:04:48 -060025AC_CHECK_LIB([mapper], [mapper_get_service], ,[AC_MSG_ERROR([Could not find libmapper...openbmc/phosphor-objmgr package required])])
Vishwanatha Subbanna506aa0f2017-01-24 14:58:25 +053026PKG_CHECK_MODULES([SYSTEMD], [libsystemd >= 221], [], [AC_MSG_ERROR(["systemd required and not found"])])
Adriana Kobylak2efb3e72017-02-06 21:43:59 -060027PKG_CHECK_MODULES([PHOSPHOR_LOGGING], [phosphor-logging],, [AC_MSG_ERROR([Could not find phosphor-logging...openbmc/phosphor-logging package required])])
Vishwanatha Subbannab12b0c02017-03-07 18:17:19 +053028PKG_CHECK_MODULES([PHOSPHOR_DBUS_INTERFACES], [phosphor-dbus-interfaces],, [AC_MSG_ERROR([Could not find phosphor-dbus-interfaces...openbmc/phosphor-dbus-interfaces package required])])
Matthew Barth3cff7ed2016-07-27 14:50:51 -050029
Vishwanatha Subbanna506aa0f2017-01-24 14:58:25 +053030AS_IF([test "x$enable_softoff" != "xno"],
31 # Check for sdbusplus
32 PKG_CHECK_MODULES([SDBUSPLUS], [sdbusplus],, [AC_MSG_ERROR(["sdbusplus packaged required and not found"])])
33
34 # Check for sdbus++ tool
35 [AC_PATH_PROG([SDBUSPLUSPLUS], [sdbus++])]
36 AS_IF([test "x$SDBUSPLUSPLUS" == "x"],
37 AC_MSG_ERROR([Cannot find sdbus++]))
38)
Matthew Barth3cff7ed2016-07-27 14:50:51 -050039
40# Checks for typedefs, structures, and compiler characteristics.
Matthew Barth00b1e5b2016-09-09 12:15:46 -050041AX_CXX_COMPILE_STDCXX_14([noext])
42AX_APPEND_COMPILE_FLAGS([-Wall -Werror], [CFLAGS])
43AX_APPEND_COMPILE_FLAGS([-Wall -Werror], [CXXFLAGS])
Matthew Barth3cff7ed2016-07-27 14:50:51 -050044
45# Checks for library functions.
Patrick Williams686df742016-09-02 17:52:59 -050046LT_INIT([dlopen disable-static shared])
Matthew Barth3cff7ed2016-07-27 14:50:51 -050047LT_LIB_DLLOAD
Matthew Barth3cff7ed2016-07-27 14:50:51 -050048
Matthew Barth00b1e5b2016-09-09 12:15:46 -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
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
Tom Joseph51cb8ee2017-02-21 16:22:33 +053071AC_ARG_VAR(WHITELIST_CONF, [Paths to IPMI whitelisted commands conf files. (default = ${srcdir}/host-ipmid-whitelist.conf)])
72if test -z "$WHITELIST_CONF"; then
73 WHITELIST_CONF=${srcdir}/host-ipmid-whitelist.conf
74fi
75
Ratan Gupta28c2e732017-03-04 08:53:52 +053076AS_IF([test "x$SENSOR_YAML_GEN" == "x"], [SENSOR_YAML_GEN="sensor-example.yaml"])
77SENSORGEN="$PYTHON ${srcdir}/scripts/sensor_gen.py -i $SENSOR_YAML_GEN"
78AC_SUBST(SENSORGEN)
79
Vishwanatha Subbanna506aa0f2017-01-24 14:58:25 +053080# Soft Power off related.
81AS_IF([test "x$enable_softoff" != "xno"],
82 # Dbus service name
83 [AC_ARG_VAR(SOFTOFF_BUSNAME, [The Dbus busname to own])]
84 AS_IF([test "x$SOFTOFF_BUSNAME" == "x"],
85 [SOFTOFF_BUSNAME="xyz.openbmc_project.Ipmi.Internal.SoftPowerOff"])
86 [AC_DEFINE_UNQUOTED([SOFTOFF_BUSNAME], ["$SOFTOFF_BUSNAME"], [The Dbus busname to own])]
87
88 # Service dbus root
89 [AC_ARG_VAR(SOFTOFF_OBJPATH, [The SoftPowerOff Dbus root])]
90 AS_IF([test "x$SOFTOFF_OBJPATH" == "x"],
91 [SOFTOFF_OBJPATH="/xyz/openbmc_project/ipmi/internal/softpoweroff"])
92 [AC_DEFINE_UNQUOTED([SOFTOFF_OBJPATH], ["$SOFTOFF_OBJPATH"], [The SoftPowerOff Dbus root])]
Vishwanatha Subbannad27e71e2017-02-01 18:02:38 +053093
94 # Timeouts in SECONDS for SoftPowerOff protocol
95 [AC_ARG_VAR(IPMI_SMS_ATN_ACK_TIMEOUT_SECS, [Initial timeout for host to ack SMS_ATN from BMC])]
96 [AC_DEFINE_UNQUOTED([IPMI_SMS_ATN_ACK_TIMEOUT_SECS], [3], [Initial timeout for host to ack SMS_ATN from BMC])]
Vishwanatha Subbanna31272b82017-02-01 18:53:14 +053097
98 [AC_ARG_VAR(IPMI_HOST_SHUTDOWN_COMPLETE_TIMEOUT_SECS, [Wait time until Host can quiesce])]
99 [AC_DEFINE_UNQUOTED([IPMI_HOST_SHUTDOWN_COMPLETE_TIMEOUT_SECS], [45*60], [Wait time until Host can quiesce])]
Vishwanatha Subbanna506aa0f2017-01-24 14:58:25 +0530100)
101
Matthew Barth00b1e5b2016-09-09 12:15:46 -0500102# Create configured output
Vishwanatha Subbanna506aa0f2017-01-24 14:58:25 +0530103AC_CONFIG_FILES([Makefile test/Makefile softoff/Makefile])
Matthew Barth3cff7ed2016-07-27 14:50:51 -0500104AC_OUTPUT