blob: a83479e0ecfd120a4b9207b7cb3c740c5d7ccce2 [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 Venture9dc342a2019-03-18 08:43:36 -07007AM_INIT_AUTOMAKE([subdir-objects -Wall -Wno-portability -Werror foreign dist-xz])
Patrick Venturec7ca2912018-11-02 11:38:33 -07008AM_SILENT_RULES([yes])
9
Patrick Venture2f3b4b62019-03-08 13:22:40 -080010# Make sure the default CFLAGS of `-O2 -g` don't override CODE_COVERAGE_CFLAGS
11# It is important that this comes before AC_PROG_C{C,XX}, as we are attempting
12# to stop them from populating default CFLAGS and CXXFLAGS.
13AS_IF([test "x$enable_tests" = "xno"], [enable_code_coverage=no])
14AS_IF([test "x$enable_code_coverage" != "xno"], [
15 AS_IF([test "x${CXXFLAGS+set}" != "xset"], [
16 AC_SUBST(CXXFLAGS, [""])
17 ])
18 AS_IF([test "x${CFLAGS+set}" != "xset"], [
19 AC_SUBST(CFLAGS, [""])
20 ])
21])
22
Patrick Venturec7ca2912018-11-02 11:38:33 -070023# Checks for programs.
24AC_PROG_CXX
25AM_PROG_AR
26AC_PROG_INSTALL
27AC_PROG_MAKE_SET
28
29# Checks for typedefs, structures, and compiler characteristics.
30AX_CXX_COMPILE_STDCXX_17([noext])
31AX_APPEND_COMPILE_FLAGS([-Wall -Werror], [CXXFLAGS])
32
33# Checks for library functions.
34LT_INIT # Required for systemd linking
35
36# Checks for libraries.
Patrick Venture4b4ea212018-11-21 21:23:53 -080037PKG_CHECK_MODULES(
38 [SDBUSPLUS],
39 [sdbusplus],
Patrick Ventureac11ae92019-01-16 12:43:00 -080040 [AC_DEFINE(HAVE_SDBUSPLUS, [1], [Found openbmc/sdbusplus package])],
Patrick Venture4b4ea212018-11-21 21:23:53 -080041 [AC_MSG_ERROR([The openbmc/sdbusplus package is required])]
42)
Patrick Venture4845a722019-02-13 07:45:57 -080043PKG_CHECK_MODULES([PHOSPHOR_LOGGING], [phosphor-logging])
Patrick Venture8b3b3252019-03-07 07:50:13 -080044PKG_CHECK_MODULES(
45 [IPMIBLOB],
46 [ipmiblob],
47 [],
48 [AC_MSG_ERROR(
49 [Could not find ipmiblob...openbmc/ipmi-blob-tool package required])
50 ]
51)
Patrick Venture4b4ea212018-11-21 21:23:53 -080052AC_CHECK_HEADER(
53 [blobs-ipmid],
54 [AC_MSG_ERROR(["phosphor-ipmi-blobs required and not found."])]
55)
Patrick Venturec7ca2912018-11-02 11:38:33 -070056AX_PTHREAD([], [AC_MSG_ERROR(["pthread required and not found"])])
57
Patrick Venturefa6c4d92018-11-02 18:34:53 -070058# Configurability
59# Enable static layout for firmware image staging.
60AC_ARG_ENABLE([static-layout],
61 AS_HELP_STRING([--enable-static-layout],
62 [Enable static layout firmware update via Blobs]))
63AS_IF([test "x$enable_static_layout" = "xyes"], [
64 AX_APPEND_COMPILE_FLAGS([-DENABLE_STATIC_LAYOUT], [CXXFLAGS])
65])
Patrick Ventured46b8112018-11-15 13:38:55 -080066# Enable tarball for firmware image staging.
67AC_ARG_ENABLE([tarball-ubi],
68 AS_HELP_STRING([--enable-tarball-ubi],
69 [Enable tarball firmware update via Blobs]))
70AS_IF([test "x$enanble_tarball_ubi" = "xyes"], [
71 AX_APPEND_COMPILE_FLAGS([-DENABLE_TARBALL_UBI], [CXXFLAGS])
72])
Patrick Venture002916a2018-11-15 10:38:07 -080073
Patrick Venture4306f682018-11-06 11:06:02 -080074# Enable P2A, and or LPC (block-transfer is always enabled).
Patrick Venture192d60f2018-11-06 11:11:59 -080075AC_ARG_ENABLE([pci-bridge],
76 AS_HELP_STRING([--enable-pci-bridge],
77 [Enable pci-bridge transport mechanism]))
78AS_IF([test "x$enable_pci_bridge" = "xyes"], [
79 AX_APPEND_COMPILE_FLAGS([-DENABLE_PCI_BRIDGE], [CXXFLAGS])
80])
81AC_ARG_ENABLE([lpc-bridge],
82 AS_HELP_STRING([--enable-lpc-bridge],
83 [Enable lpc-bridge transport mechanism]))
84AS_IF([test "x$enable_lpc_bridge" = "xyes"], [
85 AX_APPEND_COMPILE_FLAGS([-DENABLE_LPC_BRIDGE], [CXXFLAGS])
86])
Patrick Venturefa6c4d92018-11-02 18:34:53 -070087
Patrick Venture002916a2018-11-15 10:38:07 -080088# The address used for mapping P2A or LPC into the BMC's memory-space:
89# e.g. https://github.com/openbmc/linux/blob/1da2ce51886a3b2f5db2087f26c661e13ee13b84/arch/arm/boot/dts/aspeed-bmc-quanta-q71l.dts#L26
90# or https://github.com/openbmc/linux/blob/1da2ce51886a3b2f5db2087f26c661e13ee13b84/arch/arm/boot/dts/aspeed-bmc-opp-zaius.dts#L166
91# for PCI, this address is passed back to the host and is used directly.
92AC_ARG_VAR(MAPPED_ADDRESS, [The base address of the memory region reserved for mapping.])
93AS_IF([test "x$MAPPED_ADDRESS" == "x"],
Patrick Venturece6b8742019-01-15 12:11:02 -080094 [AC_DEFINE_UNQUOTED(MAPPED_ADDRESS, [0], [Default address to 0.])],
95 [AC_DEFINE_UNQUOTED(MAPPED_ADDRESS, [$MAPPED_ADDRESS], [Value for memory region mapping.])]
Patrick Venture002916a2018-11-15 10:38:07 -080096)
97
Patrick Venturee7728422018-11-14 20:16:33 -080098AC_ARG_ENABLE([aspeed-lpc],
99 AS_HELP_STRING([--enable-aspeed-lpc],
100 [Enable external transfers using Aspeed LPC]))
101AS_IF([test "x$enable_aspeed_lpc" = "xyes"], [
102 AC_CHECK_HEADER(linux/aspeed-lpc-ctrl.h,
103 [HAVE_UAPI_LINUX_LPC_CTRL_H=""],
104 [HAVE_UAPI_LINUX_LPC_CTRL_H="-I linux/aspeed-lpc-ctrl.h"])
105 AS_IF([test "$HAVE_UAPI_LINUX_LPC_CTRL_H" != ""],
Patrick Venturee9ad2ec2018-12-13 19:11:39 -0800106 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 -0800107 AC_SUBST([BT_BMC_DL],
108 [`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`])
109 )
110 AX_APPEND_COMPILE_FLAGS([-DASPEED_LPC], [CXXFLAGS])
111])
112AC_ARG_ENABLE([nuvoton-lpc],
113 AS_HELP_STRING([--enable-nuvoton-lpc],
114 [Enable external transfers using Nuvoton LPC SHM]))
115AS_IF([test "x$enable_nuvoton_lpc" = "xyes"], [
116 AX_APPEND_COMPILE_FLAGS([-DNUVOTON_LPC], [CXXFLAGS])
117])
118
Patrick Venture35a82f32018-11-15 13:34:22 -0800119AC_ARG_VAR(STATIC_HANDLER_STAGED_NAME, [The file to use for staging the firmware update.])
120AS_IF([test "x$STATIC_HANDLER_STAGED_NAME" == "x"], [STATIC_HANDLER_STAGED_NAME="/run/initramfs/bmc-image"])
121AC_DEFINE_UNQUOTED([STATIC_HANDLER_STAGED_NAME], ["$STATIC_HANDLER_STAGED_NAME"], [The file to use for staging the firmware update.])
122
Patrick Ventured46b8112018-11-15 13:38:55 -0800123AC_ARG_VAR(TARBALL_STAGED_NAME, [The file to use for staging the firmware update.])
124AS_IF([test "x$TARBALL_STAGED_NAME" == "x"], [TARBALL_STAGED_NAME="/tmp/image-update.tar"])
125AC_DEFINE_UNQUOTED([TARBALL_STAGED_NAME], ["$TARBALL_STAGED_NAME"], [The file to use for staging the firmware update.])
126
Patrick Venture35a82f32018-11-15 13:34:22 -0800127AC_ARG_VAR(HASH_FILENAME, [The file to use for the hash provided.])
128AS_IF([test "x$HASH_FILENAME" == "x"], [HASH_FILENAME="/tmp/bmc.sig"])
129AC_DEFINE_UNQUOTED([HASH_FILENAME], ["$HASH_FILENAME"], [The file to use for the hash provided.])
130
Patrick Venture440bc382018-12-13 19:10:55 -0800131AC_CHECK_HEADER(linux/ipmi.h, [HAVE_LINUX_IPMI_H=""], [HAVE_LINUX_IPMI_H="-I linux/ipmi.h"])
132AS_IF([test "$HAVE_LINUX_IPMI_H" != ""],
133 AC_MSG_WARN([Could not find linux/ipmi.h: Attempting to download locally for building from openbmc/linux/+/dev-4.18])
134 AC_SUBST([IPMI_BMC_DL],
135 [`mkdir -p linux;wget https://raw.githubusercontent.com/openbmc/linux/dev-4.18/include/uapi/linux/ipmi.h -O linux/ipmi.h`])
136)
137
138AC_CHECK_HEADER(linux/ipmi_msgdefs.h, [HAVE_LINUX_IPMIMSGDEFS_H=""], [HAVE_LINUX_IPMIMSGDEFS_H="-I linux/ipmi_msgdefs.h"])
139AS_IF([test "$HAVE_LINUX_IPMIMSGDEFS_H" != ""],
140 AC_MSG_WARN([Could not find linux/ipmi_msgdefs.h: Attempting to download locally for building from openbmc/linux/+/dev-4.18])
141 AC_SUBST([IPMIMSG_BMC_DL],
142 [`mkdir -p linux;wget https://raw.githubusercontent.com/openbmc/linux/dev-4.18/include/uapi/linux/ipmi_msgdefs.h -O linux/ipmi_msgdefs.h`])
143)
144
Patrick Venture6bc04f92019-03-06 13:49:21 -0800145# Make it possible for users to choose if they want test support
146# explicitly or not at all
147AC_ARG_ENABLE([tests], AC_HELP_STRING([--disable-tests],
148 [Build test cases]))
149
Patrick Venturec7ca2912018-11-02 11:38:33 -0700150# Check/set gtest specific functions.
Patrick Venture6bc04f92019-03-06 13:49:21 -0800151AS_IF([test "x$enable_tests" != "xno"], [
152 PKG_CHECK_MODULES([GTEST], [gtest], [], [true])
153 PKG_CHECK_MODULES([GMOCK], [gmock], [], [true])
154 AX_PTHREAD
155
156 AX_SAVE_FLAGS_WITH_PREFIX(OLD, [CPPFLAGS])
157 AX_APPEND_COMPILE_FLAGS([$GTEST_CFLAGS], [CPPFLAGS])
158 AC_LANG_PUSH([C++])
159 AC_CHECK_HEADERS([gtest/gtest.h], [
160 AS_IF([test "x$GTEST_CFLAGS" = "x"], [
161 AS_IF([test "x$PTHREAD_CFLAGS" = "x"], [
162 AX_APPEND_COMPILE_FLAGS(["-DGTEST_HAS_PTHREAD=0"], [GTEST_CFLAGS])
163 ], [
164 AX_APPEND_COMPILE_FLAGS(["-DGTEST_HAS_PTHREAD=1"], [GTEST_CFLAGS])
165 AX_APPEND_COMPILE_FLAGS([$PTHREAD_CFLAGS], [GTEST_CFLAGS])
166 ])
167 ])
168 ], [
169 AS_IF([test "x$enable_tests" = "xyes"], [
170 AC_MSG_ERROR([Testing enabled but could not find gtest/gtest.h])
171 ])
172 ])
173 AC_LANG_POP([C++])
174 AX_RESTORE_FLAGS_WITH_PREFIX(OLD, [CPPFLAGS])
175
176 AX_SAVE_FLAGS_WITH_PREFIX(OLD, [CPPFLAGS])
177 AX_APPEND_COMPILE_FLAGS([$GMOCK_CFLAGS], [CPPFLAGS])
178 AC_LANG_PUSH([C++])
179 AC_CHECK_HEADERS([gmock/gmock.h], [], [
180 AS_IF([test "x$enable_tests" = "xyes"], [
181 AC_MSG_ERROR([Testing enabled but could not find gmock/gmock.h])
182 ])
183 ])
184 AC_LANG_POP([C++])
185 AX_RESTORE_FLAGS_WITH_PREFIX(OLD, [CPPFLAGS])
186
187 AX_SAVE_FLAGS_WITH_PREFIX(OLD, [LDFLAGS])
188 AX_APPEND_COMPILE_FLAGS([$GTEST_LIBS], [LDFLAGS])
189 AC_CHECK_LIB([gtest], [main], [
190 AS_IF([test "x$GTEST_LIBS" = "x"], [
191 AX_APPEND_COMPILE_FLAGS([-lgtest], [GTEST_LIBS])
192 ])
193 ], [
194 AS_IF([test "x$enable_tests" = "xyes"], [
195 AC_MSG_ERROR([Testing enabled but couldn't find gtest libs])
196 ])
197 ])
198 AX_RESTORE_FLAGS_WITH_PREFIX(OLD, [LDFLAGS])
199
200 AX_SAVE_FLAGS_WITH_PREFIX(OLD, [LDFLAGS])
201 AX_APPEND_COMPILE_FLAGS([$GMOCK_LIBS], [LDFLAGS])
202 AC_CHECK_LIB([gmock], [main], [
203 AS_IF([test "x$GMOCK_LIBS" = "x"], [
204 AX_APPEND_COMPILE_FLAGS([-lgmock], [GMOCK_LIBS])
205 ])
206 ], [
207 AS_IF([test "x$enable_tests" = "xyes"], [
208 AC_MSG_ERROR([Testing enabled but couldn't find gmock libs])
209 ])
210 ])
211 AX_RESTORE_FLAGS_WITH_PREFIX(OLD, [LDFLAGS])
212])
Patrick Venturec7ca2912018-11-02 11:38:33 -0700213
Patrick Venture2f3b4b62019-03-08 13:22:40 -0800214# Code coverage
215AX_CODE_COVERAGE
Patrick Venture2f3b4b62019-03-08 13:22:40 -0800216AS_IF([test "x$CODE_COVERAGE_ENABLED" = "xyes"], [
217 AX_APPEND_COMPILE_FLAGS([-DHAVE_GCOV], [CODE_COVERAGE_CPPFLAGS])
218])
Patrick Venture9dc342a2019-03-18 08:43:36 -0700219m4_ifdef([_AX_CODE_COVERAGE_RULES],
220 [AM_CONDITIONAL(AUTOCONF_CODE_COVERAGE_2019_01_06, [true])],
221 [AM_CONDITIONAL(AUTOCONF_CODE_COVERAGE_2019_01_06, [false])])
222AX_ADD_AM_MACRO_STATIC([])
Patrick Venture2f3b4b62019-03-08 13:22:40 -0800223
Patrick Venturec7ca2912018-11-02 11:38:33 -0700224# Add --enable-oe-sdk flag to configure script
225AC_ARG_ENABLE([oe-sdk],
226 AS_HELP_STRING([--enable-oe-sdk], [Link testcases absolutely against OE SDK so they can be ran within it.])
227)
228
229# Check for OECORE_TARGET_SYSROOT in the environment.
230AC_ARG_VAR(OECORE_TARGET_SYSROOT,
231 [Path to the OE SDK SYSROOT])
232
233# Configure OESDK_TESTCASE_FLAGS environment variable, which will be later
234# used in test/Makefile.am
235AS_IF([test "x$enable_oe_sdk" == "xyes"],
236 AS_IF([test "x$OECORE_TARGET_SYSROOT" == "x"],
237 AC_MSG_ERROR([OECORE_TARGET_SYSROOT must be set with --enable-oe-sdk])
238 )
239 AC_MSG_NOTICE([Enabling OE-SDK at $OECORE_TARGET_SYSROOT])
240 [
241 testcase_flags="-Wl,-rpath,\${OECORE_TARGET_SYSROOT}/lib"
242 testcase_flags="${testcase_flags} -Wl,-rpath,\${OECORE_TARGET_SYSROOT}/usr/lib"
243 testcase_flags="${testcase_flags} -Wl,-dynamic-linker,`find \${OECORE_TARGET_SYSROOT}/lib/ld-*.so | sort -r -n | head -n1`"
244 ]
245 AC_SUBST([OESDK_TESTCASE_FLAGS], [$testcase_flags])
246)
247
248# Create configured output
Patrick Venturebf58cd62018-12-11 09:05:46 -0800249AC_CONFIG_FILES([Makefile test/Makefile tools/Makefile])
Patrick Venturec7ca2912018-11-02 11:38:33 -0700250AC_OUTPUT