blob: 05a3bee9b48109c74944f96dfe767a4e0f242213 [file] [log] [blame]
Liam Girdwoodc0dfb4e2016-09-21 15:57:22 +01001AC_PREREQ([2.69])
Liam Girdwood6bb37832018-01-10 20:43:25 +00002AC_INIT([sof],[m4_esyscmd(./version.sh)],[sound-open-firmware@alsa-project.org])
Liam Girdwoodc0dfb4e2016-09-21 15:57:22 +01003AC_CONFIG_SRCDIR([src/init/init.c])
4AC_CONFIG_HEADERS([src/include/config.h])
5AC_CONFIG_MACRO_DIRS([m4])
6AM_INIT_AUTOMAKE([foreign 1.11 -Wall -Wno-portability subdir-objects silent-rules color-tests dist-xz tar-ustar])
7
8# Initialize maintainer mode
9AM_MAINTAINER_MODE([enable])
10
11# get version info from git
Liam Girdwood77bc0652016-12-22 16:01:21 +000012m4_define(reef_major, `cat .version | cut -dv -f2 | cut -d. -f1`)
13m4_define(reef_minor, `cat .version | cut -d. -f2 | cut -d- -f1`)
Liam Girdwood93d62e52018-01-10 20:26:08 +000014m4_define(reef_micro, `cat .version | cut -d. -f3 | cut -d- -f1`)
Liam Girdwoodc0dfb4e2016-09-21 15:57:22 +010015AC_DEFINE_UNQUOTED([REEF_MAJOR], reef_major, [Reef major version])
16AC_DEFINE_UNQUOTED([REEF_MINOR], reef_minor, [Reef minor version])
Liam Girdwood93d62e52018-01-10 20:26:08 +000017AC_DEFINE_UNQUOTED([REEF_MICRO], reef_micro, [Reef micro version])
Liam Girdwoodc0dfb4e2016-09-21 15:57:22 +010018
19AC_CANONICAL_HOST
20
21# General compiler flags
Pierre-Louis Bossartd46dd352017-09-25 14:55:09 -050022CFLAGS="${CFLAGS:+$CFLAGS } -O2 -g -Wall -Werror -Wl,-EL -fno-inline-functions -nostdlib -Wmissing-prototypes"
Liam Girdwoodc0dfb4e2016-09-21 15:57:22 +010023
Liam Girdwoodcc9fba32018-01-22 23:31:24 +000024# General assembler flags
25ASFLAGS="-DASSEMBLY"
26AC_SUBST(ASFLAGS)
27
Liam Girdwoodc0dfb4e2016-09-21 15:57:22 +010028# Cross compiler tool libgcc and headers
Liam Girdwood8855ce52016-10-18 17:18:16 +010029AC_ARG_WITH([root-dir],
30 AS_HELP_STRING([--with-root-dir], [Specify location of cross gcc libraries and headers]),
31 [], [with_root_dir=no])
Ranjani Sridharan05058232018-01-24 22:42:38 -080032
33# check if we are building FW image or library
34AC_ARG_ENABLE(library, [AS_HELP_STRING([--enable-library],[build library])], have_library=$enableval, have_library=no)
35if test "$have_library" = "yes"; then
36 AC_DEFINE([CONFIG_LIB], [1], [Configure for Shared Library])
37fi
38AM_CONDITIONAL(BUILD_LIB, test "$have_library" = "yes")
Liam Girdwoodc0dfb4e2016-09-21 15:57:22 +010039
40# Architecture support
41AC_ARG_WITH([arch],
42 AS_HELP_STRING([--with-arch], [Specify DSP architecture]),
43 [], [with_arch=no])
44
45case "$with_arch" in
46 xtensa*)
Liam Girdwoodc0dfb4e2016-09-21 15:57:22 +010047
48 ARCH_CFLAGS="-mtext-section-literals"
49 AC_SUBST(ARCH_CFLAGS)
50
51 ARCH_LDFLAGS="-nostdlib -Wl,--no-check-sections -u call_user_start -Wl,-static"
52 AC_SUBST(XTENSA_LDFLAGS)
53
54 # extra CFLAGS defined here otherwise configure working gcc tests fails.
55 CFLAGS="${CFLAGS:+$CFLAGS }-mlongcalls"
56 LDFLAGS="${LDFLAGS:+$LDFLAGS }-nostdlib"
57
58 #ARCH_ASFLAGS=""
59 AC_SUBST(ARCH_ASFLAGS)
60
61 ARCH="xtensa"
62 AC_SUBST(ARCH)
Ranjani Sridharan05058232018-01-24 22:42:38 -080063
64 AS_IF([test "x$with_root_dir" = xno],
65 AC_MSG_ERROR([Please specify cross compiler root header directory]),
66 [ROOT_DIR=$with_root_dir])
67 AC_SUBST(ROOT_DIR)
68 ;;
69 host*)
70
71 ARCH_CFLAGS="-g"
72 AC_SUBST(ARCH_CFLAGS)
73
74 # extra CFLAGS defined here otherwise configure working gcc tests fails.
75 CFLAGS="${CFLAGS:+$CFLAGS } -O3"
76 LDFLAGS="${LDFLAGS:+$LDFLAGS }-lpthread"
77
78 ARCH="host"
79 AC_SUBST(ARCH)
Liam Girdwoodc0dfb4e2016-09-21 15:57:22 +010080 ;;
81 *)
82 AC_MSG_ERROR([DSP architecture not specified])
83 ;;
84esac
85
Liam Girdwood2eab4672017-11-27 05:24:51 +080086AM_CONDITIONAL(BUILD_XTENSA, test "$ARCH" = "xtensa")
Ranjani Sridharan05058232018-01-24 22:42:38 -080087AM_CONDITIONAL(BUILD_HOST, test "$ARCH" = "host")
Liam Girdwoodc0dfb4e2016-09-21 15:57:22 +010088
89# Platform support
90AC_ARG_WITH([platform],
91 AS_HELP_STRING([--with-platform], [Specify Host Platform]),
92 [], [with_platform=no])
93
94case "$with_platform" in
95 baytrail*)
Liam Girdwoodc0dfb4e2016-09-21 15:57:22 +010096
97 PLATFORM_LDSCRIPT="baytrail.x"
98 AC_SUBST(PLATFORM_LDSCRIPT)
99
100 PLATFORM="baytrail"
101 AC_SUBST(PLATFORM)
102
103 FW_NAME="byt"
104 AC_SUBST(FW_NAME)
105
Liam Girdwoodf63c7892017-12-04 20:08:39 +0000106 XTENSA_CORE="hifiep_bd5"
Liam Girdwoodc0dfb4e2016-09-21 15:57:22 +0100107 AC_SUBST(XTENSA_CORE)
108
109 AC_DEFINE([CONFIG_BAYTRAIL], [1], [Configure for Baytrail])
Keyon Jiefb784212017-12-06 21:16:32 +0800110 AC_DEFINE([CONFIG_HOST_PTABLE], [1], [Configure handling host page table])
Liam Girdwoodc0dfb4e2016-09-21 15:57:22 +0100111 ;;
112 cherrytrail*)
Liam Girdwoodc0dfb4e2016-09-21 15:57:22 +0100113
114 PLATFORM_LDSCRIPT="baytrail.x"
115 AC_SUBST(PLATFORM_LDSCRIPT)
116
117 PLATFORM="baytrail"
118 AC_SUBST(PLATFORM)
119
120 FW_NAME="cht"
121 AC_SUBST(FW_NAME)
122
Liam Girdwoodf63c7892017-12-04 20:08:39 +0000123 XTENSA_CORE="hifiep_bd5"
Liam Girdwoodc0dfb4e2016-09-21 15:57:22 +0100124 AC_SUBST(XTENSA_CORE)
125
126 AC_DEFINE([CONFIG_CHERRYTRAIL], [1], [Configure for Cherrytrail])
Keyon Jiefb784212017-12-06 21:16:32 +0800127 AC_DEFINE([CONFIG_HOST_PTABLE], [1], [Configure handling host page table])
Liam Girdwoodc0dfb4e2016-09-21 15:57:22 +0100128 ;;
Liam Girdwood095c9072018-01-23 14:53:00 +0000129 apollolake*)
130
131 PLATFORM_LDSCRIPT="apollolake.x"
132 AC_SUBST(PLATFORM_LDSCRIPT)
133
134 PLATFORM="apollolake"
135 AC_SUBST(PLATFORM)
136
137 FW_NAME="apl"
138 AC_SUBST(FW_NAME)
139
140 XTENSA_CORE="hifi3_std"
141 AC_SUBST(XTENSA_CORE)
142
143 AC_DEFINE([CONFIG_APOLLOLAKE], [1], [Configure for Apololake])
144 AC_DEFINE([CONFIG_IRQ_MAP], [1], [Configure IRQ maps])
145 ;;
Liam Girdwoodf198ad92018-01-21 23:48:35 +0000146 haswell*)
147
148 PLATFORM_LDSCRIPT="haswell.x"
149 AC_SUBST(PLATFORM_LDSCRIPT)
150
151 PLATFORM="haswell"
152 AC_SUBST(PLATFORM)
153
154 FW_NAME="hsw"
155 AC_SUBST(FW_NAME)
156
157 XTENSA_CORE="hifiep_bd5"
158 AC_SUBST(XTENSA_CORE)
159
160 AC_DEFINE([CONFIG_HASWELL], [1], [Configure for Haswell])
161 AC_DEFINE([CONFIG_HOST_PTABLE], [1], [Configure handling host page table])
162 ;;
163 broadwell*)
164
165 PLATFORM_LDSCRIPT="broadwell.x"
166 AC_SUBST(PLATFORM_LDSCRIPT)
167
168 PLATFORM="haswell"
169 AC_SUBST(PLATFORM)
170
171 FW_NAME="bdw"
172 AC_SUBST(FW_NAME)
173
174 XTENSA_CORE="hifiep_bd5"
175 AC_SUBST(XTENSA_CORE)
176
177 AC_DEFINE([CONFIG_BROADWELL], [1], [Configure for Broadwell])
178 AC_DEFINE([CONFIG_HOST_PTABLE], [1], [Configure handling host page table])
179 ;;
Liam Girdwood17c6bcf2018-01-23 15:44:08 +0000180 cannonlake*)
181
182 PLATFORM_LDSCRIPT="cannonlake.x"
183 AC_SUBST(PLATFORM_LDSCRIPT)
184
185 PLATFORM="cannonlake"
186 AC_SUBST(PLATFORM)
187
188 FW_NAME="cnl"
189 AC_SUBST(FW_NAME)
190
191 XTENSA_CORE="hifi4_std"
192 AC_SUBST(XTENSA_CORE)
193
194 AC_DEFINE([CONFIG_CANNONLAKE], [1], [Configure for Cannonlake])
195 AC_DEFINE([CONFIG_IRQ_MAP], [1], [Configure IRQ maps])
196 ;;
Liam Girdwoodc0dfb4e2016-09-21 15:57:22 +0100197 *)
Ranjani Sridharan05058232018-01-24 22:42:38 -0800198 if test "$ARCH" = "host"; then
199 PLATFORM="host"
200 AC_SUBST(PLATFORM)
201 else
202 AC_MSG_ERROR([Host platform not specified])
203 fi
Liam Girdwoodc0dfb4e2016-09-21 15:57:22 +0100204 ;;
205esac
206
Liam Girdwood2eab4672017-11-27 05:24:51 +0800207AM_CONDITIONAL(BUILD_BAYTRAIL, test "$FW_NAME" = "byt")
208AM_CONDITIONAL(BUILD_CHERRYTRAIL, test "$FW_NAME" = "cht")
209AM_CONDITIONAL(BUILD_HASWELL, test "$FW_NAME" = "hsw")
210AM_CONDITIONAL(BUILD_BROADWELL, test "$FW_NAME" = "bdw")
211AM_CONDITIONAL(BUILD_APOLLOLAKE, test "$FW_NAME" = "apl")
Liam Girdwood17c6bcf2018-01-23 15:44:08 +0000212AM_CONDITIONAL(BUILD_CANNONLAKE, test "$FW_NAME" = "cnl")
213AM_CONDITIONAL(BUILD_BOOTLOADER, test "$FW_NAME" = "cnl")
Liam Girdwood095c9072018-01-23 14:53:00 +0000214AM_CONDITIONAL(BUILD_MODULE, test "$FW_NAME" = "apl" -o "$FW_NAME" = "cnl")
Liam Girdwoodf198ad92018-01-21 23:48:35 +0000215
Sebastien Guiriecca23f512016-11-02 08:44:19 +0100216# DSP core support (Optional)
217AC_ARG_WITH([dsp-core],
218 AS_HELP_STRING([--with-dsp-core], [Specify DSP Core]),
219 [], [with_dsp_core=no])
220
221case "$with_dsp_core" in
222 CHT_audio_hifiep*)
223 # BXT/CHT DSP Core
224 XTENSA_CORE="CHT_audio_hifiep"
225 AC_SUBST(XTENSA_CORE)
226 ;;
227
228esac
229
Keyon Jie0e420302017-12-06 21:16:30 +0800230# dma trace support (Optional), dma trace by default
231AC_ARG_ENABLE([dma-trace],
232 AS_HELP_STRING([--disable-dma-trace], [Disabled dma trace and use fallback mailbox trace]))
233
234AS_IF([test "x$enable_dma_trace" != "xno"], [
235 AC_DEFINE([CONFIG_DMA_TRACE], [1], [Configure DMA trace])
236 ])
237
Keyon Jie1a8a6532017-12-22 23:10:56 +0800238AM_CONDITIONAL(BUILD_DMA_TRACE, test "x$enable_dma_trace" != "xno")
239
Liam Girdwood17c6bcf2018-01-23 15:44:08 +0000240PLATFORM_BOOT_LDR_LDSCRIPT="boot_ldr.x"
241AC_SUBST(PLATFORM_BOOT_LDR_LDSCRIPT)
242
Ranjani Sridharan05058232018-01-24 22:42:38 -0800243# Optimisation settings and checks
244
245# SSE4_2 support
246AC_ARG_ENABLE(sse42, [AS_HELP_STRING([--enable-sse42],[enable SSE42 optimizations])], have_sse42=$enableval, have_sse42=yes)
247AX_CHECK_COMPILE_FLAG(-msse4.2, [SSE42_CFLAGS="-DOPS_SSE42 -msse4.2 -ffast-math -ftree-vectorizer-verbose=0"],
248 [have_sse42=no])
249if test "$have_sse42" = "yes"; then
250 AC_DEFINE(HAVE_SSE42,1,[Define to enable SSE42 optimizations.])
251fi
252AM_CONDITIONAL(HAVE_SSE42, test "$have_sse42" = "yes")
253AC_SUBST(SSE42_CFLAGS)
254
255# AVX support
256AC_ARG_ENABLE(avx, [AS_HELP_STRING([--enable-avx],[enable AVX optimizations])], have_avx=$enableval, have_avx=yes)
257AX_CHECK_COMPILE_FLAG(-mavx, [AVX_CFLAGS="-DOPS_AVX -mavx -ffast-math -ftree-vectorizer-verbose=0"],
258 [have_avx=no])
259if test "$have_avx" = "yes"; then
260 AC_DEFINE(HAVE_AVX,1,[Define to enable AVX optimizations.])
261fi
262AM_CONDITIONAL(HAVE_AVX, test "$have_avx" = "yes")
263AC_SUBST(AVX_CFLAGS)
264
265
266# AVX2 support
267AC_ARG_ENABLE(avx2, [AS_HELP_STRING([--enable-avx2],[enable AVX2 optimizations])], have_avx2=$enableval, have_avx2=yes)
268AX_CHECK_COMPILE_FLAG(-mavx2, [AVX2_CFLAGS="-DOPS_AVX2 -mavx2 -ffast-math -ftree-vectorizer-verbose=0"],
269 [have_avx2=no])
270if test "$have_avx2" = "yes"; then
271 AC_DEFINE(HAVE_AVX2,1,[Define to enable AVX2 optimizations.])
272fi
273AM_CONDITIONAL(HAVE_AVX2, test "$have_avx2" = "yes")
274AC_SUBST(AVX2_CFLAGS)
275
276
277# FMA support
278AC_ARG_ENABLE(fma, [AS_HELP_STRING([--enable-fma],[enable FMA optimizations])], have_fma=$enableval, have_fma=yes)
279AX_CHECK_COMPILE_FLAG(-mfma, [FMA_CFLAGS="-DOPS_FMA -mfma -ffast-math -ftree-vectorizer-verbose=0"],
280 [have_fma=no])
281if test "$have_fma" = "yes"; then
282 AC_DEFINE(HAVE_FMA,1,[Define to enable FMA optimizations.])
283fi
284AM_CONDITIONAL(HAVE_FMA, test "$have_fma" = "yes")
285AC_SUBST(FMA_CFLAGS)
286
287# Hifi2EP
288AC_ARG_ENABLE(hifi2ep, [AS_HELP_STRING([--enable-hifi2ep],[enable HiFi2EP optimizations])], have_hifi2ep=$enableval, have_hifi2ep=yes)
289AX_CHECK_COMPILE_FLAG(-mhifi2ep, [FMA_CFLAGS="-DOPS_HIFI2EP -mhifi2ep -ffast-math -ftree-vectorizer-verbose=0"],
290 [have_hifi2ep=no])
291if test "$have_hifi2ep" = "yes"; then
292 AC_DEFINE(HAVE_HIFI2EP,1,[Define to enable Hifi2 EP optimizations.])
293fi
294AM_CONDITIONAL(HAVE_HIFI2EP, test "$have_hifi2ep" = "yes")
295AC_SUBST(HIFI2EP_CFLAGS)
296
297# Hifi3
298AC_ARG_ENABLE(hifi3, [AS_HELP_STRING([--enable-hifi3],[enable HiFi3 optimizations])], have_hifi3=$enableval, have_hifi3=yes)
299AX_CHECK_COMPILE_FLAG(-mhihi3, [FMA_CFLAGS="-DOPS_HIFI3 -mhifi3 -ffast-math -ftree-vectorizer-verbose=0"],
300 [have_hifi3=no])
301if test "$have_hifi3" = "yes"; then
302 AC_DEFINE(HAVE_HIFI3,1,[Define to enable Hifi3 optimizations.])
303fi
304AM_CONDITIONAL(HAVE_HIFI3, test "$have_hifi3" = "yes")
305AC_SUBST(HIFI3_CFLAGS)
306
Liam Girdwoodc0dfb4e2016-09-21 15:57:22 +0100307# Test after CFLAGS set othewise test of cross compiler fails.
308AM_PROG_AS
309AM_PROG_AR
310AC_PROG_CC
311LT_INIT
312AC_CHECK_TOOL([OBJCOPY], [objcopy], [])
313AC_CHECK_TOOL([OBJDUMP], [objdump], [])
314
315AM_EXTRA_RECURSIVE_TARGETS([bin])
316
317AM_EXTRA_RECURSIVE_TARGETS([vminstall])
318
319AC_CONFIG_FILES([
320 Makefile
321 src/Makefile
322 src/tasks/Makefile
323 src/init/Makefile
324 src/arch/Makefile
325 src/arch/xtensa/Makefile
326 src/arch/xtensa/include/Makefile
Liam Girdwoodb14e8522018-01-10 17:36:41 +0000327 src/arch/xtensa/include/arch/Makefile
328 src/arch/xtensa/include/xtensa/Makefile
329 src/arch/xtensa/include/xtensa/config/Makefile
Liam Girdwoodc0dfb4e2016-09-21 15:57:22 +0100330 src/arch/xtensa/hal/Makefile
331 src/arch/xtensa/xtos/Makefile
Ranjani Sridharan05058232018-01-24 22:42:38 -0800332 src/arch/host/Makefile
333 src/arch/host/include/Makefile
334 src/arch/host/include/arch/Makefile
Liam Girdwoodc0dfb4e2016-09-21 15:57:22 +0100335 src/audio/Makefile
Seppo Ingalsuo6a274832017-06-07 14:17:55 +0300336 src/math/Makefile
Liam Girdwoodc0dfb4e2016-09-21 15:57:22 +0100337 src/drivers/Makefile
338 src/include/Makefile
339 src/include/reef/Makefile
340 src/include/reef/audio/Makefile
Liam Girdwoodb14e8522018-01-10 17:36:41 +0000341 src/include/reef/audio/coefficients/Makefile
342 src/include/reef/audio/coefficients/src/Makefile
343 src/include/reef/math/Makefile
Liam Girdwoodc0dfb4e2016-09-21 15:57:22 +0100344 src/include/uapi/Makefile
345 src/ipc/Makefile
Ranjani Sridharan05058232018-01-24 22:42:38 -0800346 src/library/Makefile
347 src/library/include/Makefile
348 src/library/include/platform/Makefile
Liam Girdwoodc0dfb4e2016-09-21 15:57:22 +0100349 src/lib/Makefile
350 src/platform/Makefile
351 src/platform/baytrail/Makefile
352 src/platform/baytrail/include/Makefile
353 src/platform/baytrail/include/platform/Makefile
354 src/platform/baytrail/include/xtensa/Makefile
355 src/platform/baytrail/include/xtensa/config/Makefile
Liam Girdwood095c9072018-01-23 14:53:00 +0000356 src/platform/apollolake/Makefile
357 src/platform/apollolake/include/Makefile
358 src/platform/apollolake/include/platform/Makefile
359 src/platform/apollolake/include/xtensa/Makefile
360 src/platform/apollolake/include/xtensa/config/Makefile
Liam Girdwoodf198ad92018-01-21 23:48:35 +0000361 src/platform/haswell/Makefile
362 src/platform/haswell/include/Makefile
363 src/platform/haswell/include/platform/Makefile
364 src/platform/haswell/include/xtensa/Makefile
365 src/platform/haswell/include/xtensa/config/Makefile
Liam Girdwood17c6bcf2018-01-23 15:44:08 +0000366 src/platform/cannonlake/Makefile
367 src/platform/cannonlake/include/Makefile
368 src/platform/cannonlake/include/platform/Makefile
369 src/platform/cannonlake/include/xtensa/Makefile
370 src/platform/cannonlake/include/xtensa/config/Makefile
Liam Girdwoodc0dfb4e2016-09-21 15:57:22 +0100371])
372AC_OUTPUT
373
374echo "
375---{ $PACKAGE_NAME $VERSION }---
376
377Target Architecture: ${ARCH}
378Target Platform: ${PLATFORM}
Sebastien Guiriecca23f512016-11-02 08:44:19 +0100379Target Core: ${XTENSA_CORE}
Liam Girdwoodc0dfb4e2016-09-21 15:57:22 +0100380
381Compiler: ${CC}
382CFLAGS: ${CFLAGS}
383LDFLAGS: ${LDFLAGS}
384ARCH_CFLAGS: ${ARCH_CFLAGS}
385ARCH_LDFLAGS: ${ARCH_LDFLAGS}
386"
387