blob: e6a2025fde30cb82f11c97c15b5b9234eb110b1f [file] [log] [blame]
Patrick Venturec7ca2912018-11-02 11:38:33 -07001# Initialization
2AC_PREREQ([2.69])
3AC_INIT([phosphor-ipmi-flash], [0.1], [https://github.com/openbmc/phosphor-ipmi-flash/issues])
4AC_LANG([C++])
5AC_CONFIG_HEADERS([config.h])
Patrick Venture30993b32018-11-28 14:52:00 -08006AC_CONFIG_MACRO_DIRS([m4])
Patrick Venturec7ca2912018-11-02 11:38:33 -07007AM_INIT_AUTOMAKE([subdir-objects -Wall -Werror foreign dist-xz])
8AM_SILENT_RULES([yes])
9
10# Checks for programs.
11AC_PROG_CXX
12AM_PROG_AR
13AC_PROG_INSTALL
14AC_PROG_MAKE_SET
15
16# Checks for typedefs, structures, and compiler characteristics.
17AX_CXX_COMPILE_STDCXX_17([noext])
18AX_APPEND_COMPILE_FLAGS([-Wall -Werror], [CXXFLAGS])
19
20# Checks for library functions.
21LT_INIT # Required for systemd linking
22
23# Checks for libraries.
Patrick Venture4b4ea212018-11-21 21:23:53 -080024PKG_CHECK_MODULES(
25 [SDBUSPLUS],
26 [sdbusplus],
27 [],
28 [AC_MSG_ERROR([The openbmc/sdbusplus package is required])]
29)
30PKG_CHECK_MODULES(
31 [PHOSPHOR_LOGGING],
32 [phosphor-logging],
33 [],
34 [AC_MSG_ERROR([Could not find phosphor-logging...openbmc/phosphor-logging package required])]
35)
36AC_CHECK_HEADER(
37 [blobs-ipmid],
38 [AC_MSG_ERROR(["phosphor-ipmi-blobs required and not found."])]
39)
Patrick Venturec7ca2912018-11-02 11:38:33 -070040AX_PTHREAD([], [AC_MSG_ERROR(["pthread required and not found"])])
41
Patrick Venturefa6c4d92018-11-02 18:34:53 -070042# Configurability
43# Enable static layout for firmware image staging.
44AC_ARG_ENABLE([static-layout],
45 AS_HELP_STRING([--enable-static-layout],
46 [Enable static layout firmware update via Blobs]))
47AS_IF([test "x$enable_static_layout" = "xyes"], [
48 AX_APPEND_COMPILE_FLAGS([-DENABLE_STATIC_LAYOUT], [CXXFLAGS])
49])
Patrick Ventured46b8112018-11-15 13:38:55 -080050# Enable tarball for firmware image staging.
51AC_ARG_ENABLE([tarball-ubi],
52 AS_HELP_STRING([--enable-tarball-ubi],
53 [Enable tarball firmware update via Blobs]))
54AS_IF([test "x$enanble_tarball_ubi" = "xyes"], [
55 AX_APPEND_COMPILE_FLAGS([-DENABLE_TARBALL_UBI], [CXXFLAGS])
56])
Patrick Venture002916a2018-11-15 10:38:07 -080057
Patrick Venture4306f682018-11-06 11:06:02 -080058# Enable P2A, and or LPC (block-transfer is always enabled).
Patrick Venture192d60f2018-11-06 11:11:59 -080059AC_ARG_ENABLE([pci-bridge],
60 AS_HELP_STRING([--enable-pci-bridge],
61 [Enable pci-bridge transport mechanism]))
62AS_IF([test "x$enable_pci_bridge" = "xyes"], [
63 AX_APPEND_COMPILE_FLAGS([-DENABLE_PCI_BRIDGE], [CXXFLAGS])
64])
65AC_ARG_ENABLE([lpc-bridge],
66 AS_HELP_STRING([--enable-lpc-bridge],
67 [Enable lpc-bridge transport mechanism]))
68AS_IF([test "x$enable_lpc_bridge" = "xyes"], [
69 AX_APPEND_COMPILE_FLAGS([-DENABLE_LPC_BRIDGE], [CXXFLAGS])
70])
Patrick Venturefa6c4d92018-11-02 18:34:53 -070071
Patrick Venture002916a2018-11-15 10:38:07 -080072# The address used for mapping P2A or LPC into the BMC's memory-space:
73# e.g. https://github.com/openbmc/linux/blob/1da2ce51886a3b2f5db2087f26c661e13ee13b84/arch/arm/boot/dts/aspeed-bmc-quanta-q71l.dts#L26
74# or https://github.com/openbmc/linux/blob/1da2ce51886a3b2f5db2087f26c661e13ee13b84/arch/arm/boot/dts/aspeed-bmc-opp-zaius.dts#L166
75# for PCI, this address is passed back to the host and is used directly.
76AC_ARG_VAR(MAPPED_ADDRESS, [The base address of the memory region reserved for mapping.])
77AS_IF([test "x$MAPPED_ADDRESS" == "x"],
78 [AC_DEFINE(MAPPED_ADDRESS, [0], [Default address to 0.])],
79 [AC_DEFINE(MAPPED_ADDRESS, [$MAPPED_ADDRESS], [Value for memory region mapping.])]
80)
81
Patrick Venturee7728422018-11-14 20:16:33 -080082AC_ARG_ENABLE([aspeed-lpc],
83 AS_HELP_STRING([--enable-aspeed-lpc],
84 [Enable external transfers using Aspeed LPC]))
85AS_IF([test "x$enable_aspeed_lpc" = "xyes"], [
86 AC_CHECK_HEADER(linux/aspeed-lpc-ctrl.h,
87 [HAVE_UAPI_LINUX_LPC_CTRL_H=""],
88 [HAVE_UAPI_LINUX_LPC_CTRL_H="-I linux/aspeed-lpc-ctrl.h"])
89 AS_IF([test "$HAVE_UAPI_LINUX_LPC_CTRL_H" != ""],
Patrick Venturee9ad2ec2018-12-13 19:11:39 -080090 AC_MSG_WARN([Could not find linux/aspeed-lpc-ctrl.h: Attempting to download locally for building from openbmc/linux/+/dev-4.18])
Patrick Venturee7728422018-11-14 20:16:33 -080091 AC_SUBST([BT_BMC_DL],
92 [`mkdir -p linux;wget https://raw.githubusercontent.com/openbmc/linux/dev-4.18/include/uapi/linux/aspeed-lpc-ctrl.h -O linux/aspeed-lpc-ctrl.h`])
93 )
94 AX_APPEND_COMPILE_FLAGS([-DASPEED_LPC], [CXXFLAGS])
95])
96AC_ARG_ENABLE([nuvoton-lpc],
97 AS_HELP_STRING([--enable-nuvoton-lpc],
98 [Enable external transfers using Nuvoton LPC SHM]))
99AS_IF([test "x$enable_nuvoton_lpc" = "xyes"], [
100 AX_APPEND_COMPILE_FLAGS([-DNUVOTON_LPC], [CXXFLAGS])
101])
102
Patrick Venture35a82f32018-11-15 13:34:22 -0800103AC_ARG_VAR(STATIC_HANDLER_STAGED_NAME, [The file to use for staging the firmware update.])
104AS_IF([test "x$STATIC_HANDLER_STAGED_NAME" == "x"], [STATIC_HANDLER_STAGED_NAME="/run/initramfs/bmc-image"])
105AC_DEFINE_UNQUOTED([STATIC_HANDLER_STAGED_NAME], ["$STATIC_HANDLER_STAGED_NAME"], [The file to use for staging the firmware update.])
106
Patrick Ventured46b8112018-11-15 13:38:55 -0800107AC_ARG_VAR(TARBALL_STAGED_NAME, [The file to use for staging the firmware update.])
108AS_IF([test "x$TARBALL_STAGED_NAME" == "x"], [TARBALL_STAGED_NAME="/tmp/image-update.tar"])
109AC_DEFINE_UNQUOTED([TARBALL_STAGED_NAME], ["$TARBALL_STAGED_NAME"], [The file to use for staging the firmware update.])
110
Patrick Venture35a82f32018-11-15 13:34:22 -0800111AC_ARG_VAR(HASH_FILENAME, [The file to use for the hash provided.])
112AS_IF([test "x$HASH_FILENAME" == "x"], [HASH_FILENAME="/tmp/bmc.sig"])
113AC_DEFINE_UNQUOTED([HASH_FILENAME], ["$HASH_FILENAME"], [The file to use for the hash provided.])
114
Patrick Venture440bc382018-12-13 19:10:55 -0800115AC_CHECK_HEADER(linux/ipmi.h, [HAVE_LINUX_IPMI_H=""], [HAVE_LINUX_IPMI_H="-I linux/ipmi.h"])
116AS_IF([test "$HAVE_LINUX_IPMI_H" != ""],
117 AC_MSG_WARN([Could not find linux/ipmi.h: Attempting to download locally for building from openbmc/linux/+/dev-4.18])
118 AC_SUBST([IPMI_BMC_DL],
119 [`mkdir -p linux;wget https://raw.githubusercontent.com/openbmc/linux/dev-4.18/include/uapi/linux/ipmi.h -O linux/ipmi.h`])
120)
121
122AC_CHECK_HEADER(linux/ipmi_msgdefs.h, [HAVE_LINUX_IPMIMSGDEFS_H=""], [HAVE_LINUX_IPMIMSGDEFS_H="-I linux/ipmi_msgdefs.h"])
123AS_IF([test "$HAVE_LINUX_IPMIMSGDEFS_H" != ""],
124 AC_MSG_WARN([Could not find linux/ipmi_msgdefs.h: Attempting to download locally for building from openbmc/linux/+/dev-4.18])
125 AC_SUBST([IPMIMSG_BMC_DL],
126 [`mkdir -p linux;wget https://raw.githubusercontent.com/openbmc/linux/dev-4.18/include/uapi/linux/ipmi_msgdefs.h -O linux/ipmi_msgdefs.h`])
127)
128
Patrick Venturec7ca2912018-11-02 11:38:33 -0700129# Check/set gtest specific functions.
130PKG_CHECK_MODULES([GTEST], [gtest], [], [AC_MSG_NOTICE([gtest not found, tests will not build])])
131PKG_CHECK_MODULES([GMOCK], [gmock], [], [AC_MSG_NOTICE([gmock not found, tests will not build])])
132PKG_CHECK_MODULES([GTEST_MAIN], [gtest_main], [], [AC_MSG_NOTICE([gtest_main not found, tests will not build])])
133
134# Add --enable-oe-sdk flag to configure script
135AC_ARG_ENABLE([oe-sdk],
136 AS_HELP_STRING([--enable-oe-sdk], [Link testcases absolutely against OE SDK so they can be ran within it.])
137)
138
139# Check for OECORE_TARGET_SYSROOT in the environment.
140AC_ARG_VAR(OECORE_TARGET_SYSROOT,
141 [Path to the OE SDK SYSROOT])
142
143# Configure OESDK_TESTCASE_FLAGS environment variable, which will be later
144# used in test/Makefile.am
145AS_IF([test "x$enable_oe_sdk" == "xyes"],
146 AS_IF([test "x$OECORE_TARGET_SYSROOT" == "x"],
147 AC_MSG_ERROR([OECORE_TARGET_SYSROOT must be set with --enable-oe-sdk])
148 )
149 AC_MSG_NOTICE([Enabling OE-SDK at $OECORE_TARGET_SYSROOT])
150 [
151 testcase_flags="-Wl,-rpath,\${OECORE_TARGET_SYSROOT}/lib"
152 testcase_flags="${testcase_flags} -Wl,-rpath,\${OECORE_TARGET_SYSROOT}/usr/lib"
153 testcase_flags="${testcase_flags} -Wl,-dynamic-linker,`find \${OECORE_TARGET_SYSROOT}/lib/ld-*.so | sort -r -n | head -n1`"
154 ]
155 AC_SUBST([OESDK_TESTCASE_FLAGS], [$testcase_flags])
156)
157
158# Create configured output
Patrick Venturebf58cd62018-12-11 09:05:46 -0800159AC_CONFIG_FILES([Makefile test/Makefile tools/Makefile])
Patrick Venturec7ca2912018-11-02 11:38:33 -0700160AC_OUTPUT