sof/zephyr/CMakeLists.txt

946 lines
26 KiB
CMake

# This is still WIP - Not fully validated on any platform.
# When west is installed, Zephyr's CMake invokes west to list and try to
# compile every Zephyr module that can be found.
if(CONFIG_SOF)
if(CONFIG_LIBRARY)
set(PLATFORM "library")
set(ARCH host)
zephyr_include_directories(../src/platform/library/include)
elseif(CONFIG_ZEPHYR_POSIX)
set(ARCH host)
set(PLATFORM "posix")
else()
# firmware build supports only xtensa arch for now
set(ARCH xtensa)
endif()
# Appends literal with path of the source file relative to the project root
# It is useful if sources in given target need deterministic relative path
# to the actually compiled file.
# __FILE is not always suitable as C standard states that __FILE__ expands to
# input file name, that usually is absolute path what will cause f.e. .rodata
# size to be dependent on where project is physically located on the disk.
function(sof_append_relative_path_definitions target)
get_target_property(sources ${target} SOURCES)
foreach(src ${sources})
get_filename_component(ABS_PATH ${src} ABSOLUTE)
file(RELATIVE_PATH rel ${PROJECT_SOURCE_DIR} ${ABS_PATH})
set_property(
SOURCE ${src}
APPEND
PROPERTY COMPILE_DEFINITIONS
RELATIVE_FILE="${rel}")
endforeach()
endfunction()
# Initial SOF module will contain
#
# 1. Application logic - pipeline, audio components, IPC processing, topology
# 2. IP drivers - SSP, DMIC, PM, IPC will transition to Zephyr directly over
# time and be removed from the SOF repo.
# 3. Platform IP - PM, init, clocks, IRQs will transition directly to Zephyr
# over time and be removed from SOF repo.
# 4. RTOS logic - scheduler, allocator, notifier - as with 2 & 3.
zephyr_interface_library_named(SOF)
# SOF source paths.
set(SOF_SRC_PATH "../src")
set(SOF_PLATFORM_PATH "${SOF_SRC_PATH}/platform")
set(SOF_AUDIO_PATH "${SOF_SRC_PATH}/audio")
set(SOF_AUDIO_MODULES_PATH "${SOF_SRC_PATH}/audio/module_adapter/module")
set(SOF_SAMPLES_PATH "${SOF_SRC_PATH}/samples")
set(SOF_LIB_PATH "${SOF_SRC_PATH}/lib")
set(SOF_DRIVERS_PATH "${SOF_SRC_PATH}/drivers")
set(SOF_IPC_PATH "${SOF_SRC_PATH}/ipc")
set(SOF_DEBUG_PATH "${SOF_SRC_PATH}/debug")
set(SOF_MATH_PATH "${SOF_SRC_PATH}/math")
set(SOF_TRACE_PATH "${SOF_SRC_PATH}/trace")
# Save path to rimage configuration files in cmake cache for later use by
# rimage during the "west sign" stage
get_filename_component(RIMAGE_CONFIG "../rimage/config" ABSOLUTE)
set(RIMAGE_CONFIG_PATH ${RIMAGE_CONFIG} CACHE PATH
" Path to rimage board configuration files")
include(ExternalProject)
ExternalProject_Add(smex_ep
SOURCE_DIR "${ZEPHYR_SOF_MODULE_DIR}/smex/"
# The default paths are very "deep"
PREFIX "${PROJECT_BINARY_DIR}/smex_ep"
BINARY_DIR "${PROJECT_BINARY_DIR}/smex_ep/build"
BUILD_ALWAYS 1
INSTALL_COMMAND "" # need smex only at build time
)
ExternalProject_Add(sof_logger_ep
SOURCE_DIR "${ZEPHYR_SOF_MODULE_DIR}/tools/"
# The default paths are very "deep"
PREFIX "${PROJECT_BINARY_DIR}/sof-logger_ep"
BINARY_DIR "${PROJECT_BINARY_DIR}/sof-logger_ep/build"
BUILD_COMMAND cmake --build . --target sof-logger
BUILD_ALWAYS 1
INSTALL_COMMAND ""
)
# default SOF includes
target_include_directories(SOF INTERFACE ../rimage/src/include)
target_include_directories(SOF INTERFACE ${SOF_SRC_PATH}/include)
target_include_directories(SOF INTERFACE ${SOF_SRC_PATH}/arch/${ARCH}/include)
# TODO: Zephyr should not need xtos headers: FIX.
if (CONFIG_SOF_ZEPHYR_STRICT_HEADERS)
target_include_directories(SOF INTERFACE ${SOF_SRC_PATH}/../zephyr/include)
else()
# include Zephyr before xtos to flag up any errors in SOF
target_include_directories(SOF INTERFACE ${SOF_SRC_PATH}/../zephyr/include)
target_include_directories(SOF INTERFACE ${SOF_SRC_PATH}/../xtos/include)
endif()
# SOF module init
zephyr_library_named(modules_sof)
zephyr_include_directories(
include
)
# SOC level sources
# Files that are commented may not be needed.
# Intel APL, KBL, SKL CAVS 1.5 platforms
if (CONFIG_SOC_SERIES_INTEL_CAVS_V15)
# Driver sources
zephyr_library_sources(
${SOF_DRIVERS_PATH}/intel/cavs/ipc.c
)
zephyr_library_sources_ifdef(CONFIG_INTEL_HDA
${SOF_DRIVERS_PATH}/intel/hda/hda-dma.c
)
if (NOT CONFIG_ZEPHYR_NATIVE_DRIVERS)
zephyr_library_sources(
${SOF_DRIVERS_PATH}/intel/cavs/timestamp.c
)
zephyr_library_sources_ifdef(CONFIG_INTEL_HDA
${SOF_DRIVERS_PATH}/intel/hda/hda.c
)
zephyr_library_sources_ifdef(CONFIG_INTEL_MN
${SOF_DRIVERS_PATH}/intel/ssp/mn.c
)
zephyr_library_sources_ifdef(CONFIG_INTEL_SSP
${SOF_DRIVERS_PATH}/intel/ssp/ssp.c
)
zephyr_library_sources_ifdef(CONFIG_INTEL_ALH
${SOF_DRIVERS_PATH}/intel/alh.c
)
zephyr_library_sources_ifdef(CONFIG_INTEL_DMIC
${SOF_DRIVERS_PATH}/intel/dmic/dmic.c
)
zephyr_library_sources_ifdef(CONFIG_INTEL_DMIC_TPLG_PARAMS
${SOF_DRIVERS_PATH}/intel/dmic/dmic_computed.c
)
zephyr_library_sources_ifdef(CONFIG_INTEL_DMIC_NHLT
${SOF_DRIVERS_PATH}/intel/dmic/dmic_nhlt.c
)
zephyr_library_sources(
${SOF_PLATFORM_PATH}/intel/cavs/lib/dai.c
)
endif()
# Platform sources
zephyr_library_sources(
${SOF_PLATFORM_PATH}/intel/cavs/platform.c
${SOF_PLATFORM_PATH}/intel/cavs/lib/mem_window.c
${SOF_PLATFORM_PATH}/intel/cavs/lib/pm_runtime.c
${SOF_PLATFORM_PATH}/intel/cavs/lib/pm_memory.c
${SOF_PLATFORM_PATH}/intel/cavs/lib/clk.c
${SOF_PLATFORM_PATH}/intel/cavs/lib/dma.c
${SOF_PLATFORM_PATH}/apollolake/lib/power_down.S
${SOF_PLATFORM_PATH}/apollolake/lib/clk.c
)
# SOF core infrastructure - runs on top of Zephyr
zephyr_library_sources(
${SOF_SRC_PATH}/schedule/zephyr_ll.c
)
set_source_files_properties(${SOF_PLATFORM_PATH}/apollolake/lib/power_down.S PROPERTIES COMPILE_FLAGS -DASSEMBLY)
set(PLATFORM "apollolake")
zephyr_include_directories(${SOF_PLATFORM_PATH}/intel/cavs/include)
endif()
# Intel CNL and CAVS 1.8 platfroms
if (CONFIG_SOC_SERIES_INTEL_CAVS_V18)
# Driver sources
zephyr_library_sources(
${SOF_DRIVERS_PATH}/intel/cavs/ipc.c
)
zephyr_library_sources_ifdef(CONFIG_INTEL_HDA
${SOF_DRIVERS_PATH}/intel/hda/hda-dma.c
)
if (NOT CONFIG_ZEPHYR_NATIVE_DRIVERS)
zephyr_library_sources(
${SOF_DRIVERS_PATH}/intel/cavs/timestamp.c
)
# Sue Creek - S100 only - already in Zephyr.
#${SOF_DRIVERS_PATH}/intel/cavs/sue-ipc.c
#${SOF_DRIVERS_PATH}/intel/cavs/sue-iomux.c
zephyr_library_sources_ifdef(CONFIG_INTEL_HDA
${SOF_DRIVERS_PATH}/intel/hda/hda.c
)
zephyr_library_sources_ifdef(CONFIG_INTEL_MN
${SOF_DRIVERS_PATH}/intel/ssp/mn.c
)
zephyr_library_sources_ifdef(CONFIG_INTEL_SSP
${SOF_DRIVERS_PATH}/intel/ssp/ssp.c
)
zephyr_library_sources_ifdef(CONFIG_INTEL_ALH
${SOF_DRIVERS_PATH}/intel/alh.c
)
zephyr_library_sources_ifdef(CONFIG_INTEL_DMIC
${SOF_DRIVERS_PATH}/intel/dmic/dmic.c
)
zephyr_library_sources_ifdef(CONFIG_INTEL_DMIC_TPLG_PARAMS
${SOF_DRIVERS_PATH}/intel/dmic/dmic_computed.c
)
zephyr_library_sources_ifdef(CONFIG_INTEL_DMIC_NHLT
${SOF_DRIVERS_PATH}/intel/dmic/dmic_nhlt.c
)
zephyr_library_sources(
${SOF_PLATFORM_PATH}/intel/cavs/lib/dai.c
)
endif()
# Platform sources
zephyr_library_sources(
${SOF_PLATFORM_PATH}/intel/cavs/platform.c
${SOF_PLATFORM_PATH}/intel/cavs/lib/mem_window.c
${SOF_PLATFORM_PATH}/cannonlake/lib/clk.c
${SOF_PLATFORM_PATH}/intel/cavs/lib/power_down.S
${SOF_PLATFORM_PATH}/intel/cavs/lib/pm_runtime.c
${SOF_PLATFORM_PATH}/intel/cavs/lib/pm_memory.c
${SOF_PLATFORM_PATH}/intel/cavs/lib/clk.c
${SOF_PLATFORM_PATH}/intel/cavs/lib/dma.c
#${SOF_PLATFORM_PATH}/intel/cavs/lps_pic_restore_vector.S
)
# SOF core infrastructure - runs on top of Zephyr
zephyr_library_sources(
${SOF_SRC_PATH}/schedule/zephyr_ll.c
)
zephyr_library_sources_ifdef(CONFIG_CAVS_LPS
${SOF_PLATFORM_PATH}/intel/cavs/lps_wait.c
)
set_source_files_properties(${SOF_PLATFORM_PATH}/intel/cavs/lib/power_down.S PROPERTIES COMPILE_FLAGS -DASSEMBLY)
set_source_files_properties(${SOF_PLATFORM_PATH}/intel/cavs/lps_pic_restore_vector.S PROPERTIES COMPILE_FLAGS -DASSEMBLY)
set(PLATFORM "cannonlake")
zephyr_include_directories(${SOF_PLATFORM_PATH}/intel/cavs/include)
endif()
# Intel ICL and CAVS 2.0 platforms
if (CONFIG_SOC_SERIES_INTEL_CAVS_V20)
# Driver sources
zephyr_library_sources(
${SOF_DRIVERS_PATH}/intel/cavs/ipc.c
)
zephyr_library_sources_ifdef(CONFIG_INTEL_HDA
${SOF_DRIVERS_PATH}/intel/hda/hda-dma.c
)
if (NOT CONFIG_ZEPHYR_NATIVE_DRIVERS)
zephyr_library_sources(
${SOF_DRIVERS_PATH}/intel/cavs/timestamp.c
)
zephyr_library_sources_ifdef(CONFIG_INTEL_HDA
${SOF_DRIVERS_PATH}/intel/hda/hda.c
)
zephyr_library_sources_ifdef(CONFIG_INTEL_MN
${SOF_DRIVERS_PATH}/intel/ssp/mn.c
)
zephyr_library_sources_ifdef(CONFIG_INTEL_SSP
${SOF_DRIVERS_PATH}/intel/ssp/ssp.c
)
zephyr_library_sources_ifdef(CONFIG_INTEL_ALH
${SOF_DRIVERS_PATH}/intel/alh.c
)
zephyr_library_sources_ifdef(CONFIG_INTEL_DMIC
${SOF_DRIVERS_PATH}/intel/dmic/dmic.c
)
zephyr_library_sources_ifdef(CONFIG_INTEL_DMIC_TPLG_PARAMS
${SOF_DRIVERS_PATH}/intel/dmic/dmic_computed.c
)
zephyr_library_sources_ifdef(CONFIG_INTEL_DMIC_NHLT
${SOF_DRIVERS_PATH}/intel/dmic/dmic_nhlt.c
)
zephyr_library_sources(
${SOF_PLATFORM_PATH}/intel/cavs/lib/dai.c
)
endif()
# Platform sources
zephyr_library_sources(
${SOF_PLATFORM_PATH}/intel/cavs/platform.c
${SOF_PLATFORM_PATH}/intel/cavs/lib/mem_window.c
${SOF_PLATFORM_PATH}/icelake/lib/clk.c
${SOF_PLATFORM_PATH}/intel/cavs/lib/power_down.S
${SOF_PLATFORM_PATH}/intel/cavs/lib/pm_runtime.c
${SOF_PLATFORM_PATH}/intel/cavs/lib/pm_memory.c
${SOF_PLATFORM_PATH}/intel/cavs/lib/clk.c
${SOF_PLATFORM_PATH}/intel/cavs/lib/dma.c
#${SOF_PLATFORM_PATH}/intel/cavs/lps_pic_restore_vector.S
)
# SOF core infrastructure - runs on top of Zephyr
zephyr_library_sources(
${SOF_SRC_PATH}/schedule/zephyr_ll.c
)
zephyr_library_sources_ifdef(CONFIG_CAVS_LPS
${SOF_PLATFORM_PATH}/intel/cavs/lps_wait.c
)
set_source_files_properties(${SOF_PLATFORM_PATH}/intel/cavs/lib/power_down.S PROPERTIES COMPILE_FLAGS -DASSEMBLY)
set_source_files_properties(${SOF_PLATFORM_PATH}/intel/cavs/lps_pic_restore_vector.S PROPERTIES COMPILE_FLAGS -DASSEMBLY)
set(PLATFORM "icelake")
zephyr_include_directories(${SOF_PLATFORM_PATH}/intel/cavs/include)
endif()
# Intel TGL and CAVS 2.5 platforms
if (CONFIG_SOC_SERIES_INTEL_CAVS_V25)
# Driver sources
if (CONFIG_IPC_MAJOR_4 AND CONFIG_ZEPHYR_NATIVE_DRIVERS)
zephyr_library_sources(
${SOF_IPC_PATH}/ipc-zephyr.c
)
else()
zephyr_library_sources(
${SOF_DRIVERS_PATH}/intel/cavs/ipc.c
)
endif()
zephyr_library_sources_ifdef(CONFIG_INTEL_HDA
${SOF_DRIVERS_PATH}/intel/hda/hda-dma.c
)
if (NOT CONFIG_ZEPHYR_NATIVE_DRIVERS)
zephyr_library_sources(
${SOF_DRIVERS_PATH}/intel/cavs/timestamp.c
)
zephyr_library_sources_ifdef(CONFIG_INTEL_HDA
${SOF_DRIVERS_PATH}/intel/hda/hda.c
)
zephyr_library_sources_ifdef(CONFIG_INTEL_MN
${SOF_DRIVERS_PATH}/intel/ssp/mn.c
)
zephyr_library_sources_ifdef(CONFIG_INTEL_SSP
${SOF_DRIVERS_PATH}/intel/ssp/ssp.c
)
zephyr_library_sources_ifdef(CONFIG_INTEL_ALH
${SOF_DRIVERS_PATH}/intel/alh.c
)
zephyr_library_sources_ifdef(CONFIG_INTEL_DMIC
${SOF_DRIVERS_PATH}/intel/dmic/dmic.c
)
zephyr_library_sources_ifdef(CONFIG_INTEL_DMIC_TPLG_PARAMS
${SOF_DRIVERS_PATH}/intel/dmic/dmic_computed.c
)
zephyr_library_sources_ifdef(CONFIG_INTEL_DMIC_NHLT
${SOF_DRIVERS_PATH}/intel/dmic/dmic_nhlt.c
)
zephyr_library_sources(
${SOF_PLATFORM_PATH}/intel/cavs/lib/dai.c
)
endif()
# Platform sources
zephyr_library_sources(
${SOF_PLATFORM_PATH}/intel/cavs/platform.c
${SOF_PLATFORM_PATH}/intel/cavs/lib/mem_window.c
${SOF_PLATFORM_PATH}/tigerlake/lib/clk.c
${SOF_PLATFORM_PATH}/intel/cavs/lib/power_down.S
${SOF_PLATFORM_PATH}/intel/cavs/lib/pm_runtime.c
${SOF_PLATFORM_PATH}/intel/cavs/lib/pm_memory.c
${SOF_PLATFORM_PATH}/intel/cavs/lib/clk.c
${SOF_PLATFORM_PATH}/intel/cavs/lib/dma.c
#${SOF_PLATFORM_PATH}/intel/cavs/lps_pic_restore_vector.S
)
# SOF core infrastructure - runs on top of Zephyr
zephyr_library_sources(
${SOF_SRC_PATH}/schedule/zephyr_ll.c
)
zephyr_library_sources_ifdef(CONFIG_CAVS_LPS
${SOF_PLATFORM_PATH}/intel/cavs/lps_wait.c
)
set_source_files_properties(${SOF_PLATFORM_PATH}/intel/cavs/lib/power_down.S PROPERTIES COMPILE_FLAGS -DASSEMBLY)
set_source_files_properties(${SOF_PLATFORM_PATH}/intel/cavs/lps_pic_restore_vector.S PROPERTIES COMPILE_FLAGS -DASSEMBLY)
set(PLATFORM "tigerlake")
zephyr_include_directories(${SOF_PLATFORM_PATH}/intel/cavs/include)
endif()
# Intel ACE 1.5 and newer platforms
if (CONFIG_ACE_VERSION_1_5)
# Driver sources
zephyr_library_sources(
${SOF_IPC_PATH}/ipc-zephyr.c
)
# Platform sources
zephyr_library_sources(
${SOF_PLATFORM_PATH}/intel/ace/platform.c
${SOF_PLATFORM_PATH}/meteorlake/lib/clk.c
${SOF_PLATFORM_PATH}/intel/ace/lib/pm_runtime.c
${SOF_PLATFORM_PATH}/intel/ace/lib/clk.c
${SOF_PLATFORM_PATH}/intel/ace/lib/dma.c
)
# SOF core infrastructure - runs on top of Zephyr
zephyr_library_sources(
${SOF_SRC_PATH}/schedule/zephyr_ll.c
)
# Sources for virtual heap management
zephyr_library_sources(
lib/regions_mm.c
)
zephyr_library_sources_ifdef(CONFIG_CAVS_LPS
${SOF_PLATFORM_PATH}/intel/ace/lps_wait.c
)
zephyr_library_sources_ifdef(CONFIG_LL_WATCHDOG
${SOF_PLATFORM_PATH}/intel/ace/lib/watchdog.c
)
set(PLATFORM "meteorlake")
zephyr_include_directories(${SOF_PLATFORM_PATH}/intel/ace/include)
zephyr_include_directories(${SOF_PLATFORM_PATH}/meteorlake/include)
endif()
# NXP IMX8 platforms
if (CONFIG_SOC_SERIES_NXP_IMX8)
zephyr_library_sources(
${SOF_DRIVERS_PATH}/generic/dummy-dma.c
${SOF_DRIVERS_PATH}/imx/edma.c
${SOF_DRIVERS_PATH}/imx/sai.c
${SOF_DRIVERS_PATH}/imx/ipc.c
${SOF_DRIVERS_PATH}/imx/esai.c
${SOF_DRIVERS_PATH}/imx/interrupt-irqsteer.c
)
# Platform sources
zephyr_library_sources(
${SOF_PLATFORM_PATH}/imx8/platform.c
${SOF_PLATFORM_PATH}/imx8/lib/clk.c
${SOF_PLATFORM_PATH}/imx8/lib/dai.c
${SOF_PLATFORM_PATH}/imx8/lib/dma.c
${SOF_PLATFORM_PATH}/imx8/lib/memory.c
)
# SOF core infrastructure - runs on top of Zephyr
zephyr_library_sources(
${SOF_SRC_PATH}/drivers/interrupt.c
)
# Zephyr DMA domain should only be used with zephyr_ll
if (NOT(CONFIG_DMA_DOMAIN))
zephyr_library_sources(${SOF_SRC_PATH}/schedule/ll_schedule.c)
else()
zephyr_library_sources(${SOF_SRC_PATH}/schedule/zephyr_ll.c)
endif()
set(PLATFORM "imx8")
endif()
if (CONFIG_SOC_SERIES_NXP_IMX8M)
zephyr_library_sources(
${SOF_DRIVERS_PATH}/generic/dummy-dma.c
${SOF_DRIVERS_PATH}/imx/sdma.c
${SOF_DRIVERS_PATH}/imx/sai.c
${SOF_DRIVERS_PATH}/imx/ipc.c
${SOF_DRIVERS_PATH}/imx/interrupt-irqsteer.c
)
# Platform sources
zephyr_library_sources(
${SOF_PLATFORM_PATH}/imx8m/platform.c
${SOF_PLATFORM_PATH}/imx8m/lib/clk.c
${SOF_PLATFORM_PATH}/imx8m/lib/memory.c
${SOF_PLATFORM_PATH}/imx8m/lib/dai.c
${SOF_PLATFORM_PATH}/imx8m/lib/dma.c
)
# SOF core infrastructure - runs on top of Zephyr
zephyr_library_sources(
${SOF_SRC_PATH}/drivers/interrupt.c
)
# Zephyr DMA domain should only be used with zephyr_ll
if (NOT(CONFIG_DMA_DOMAIN))
zephyr_library_sources(${SOF_SRC_PATH}/schedule/ll_schedule.c)
else()
zephyr_library_sources(${SOF_SRC_PATH}/schedule/zephyr_ll.c)
endif()
set(PLATFORM "imx8m")
endif()
# Building for native_posix-based whole-OS host emulator
zephyr_library_sources_ifdef(CONFIG_ZEPHYR_POSIX
${SOF_SRC_PATH}/schedule/zephyr_ll.c
${SOF_PLATFORM_PATH}/posix/dma.c
${SOF_PLATFORM_PATH}/posix/dai.c
${SOF_PLATFORM_PATH}/posix/ipc.c
${SOF_PLATFORM_PATH}/posix/posix.c
)
zephyr_library_sources_ifdef(CONFIG_LIBRARY
${SOF_PLATFORM_PATH}/library/platform.c
${SOF_PLATFORM_PATH}/library/lib/dai.c
${SOF_DRIVERS_PATH}/host/ipc.c
)
zephyr_include_directories(${SOF_PLATFORM_PATH}/${PLATFORM}/include)
# Mandatory Files used on all platforms.
# Commented files will be added/removed as integration dictates.
zephyr_library_sources(
${SOF_IPC_PATH}/dma-copy.c
${SOF_IPC_PATH}/ipc-common.c
${SOF_IPC_PATH}/ipc-helper.c
# SOF math utilities
${SOF_MATH_PATH}/decibels.c
${SOF_MATH_PATH}/numbers.c
${SOF_MATH_PATH}/trig.c
# SOF library - parts to transition to Zephyr over time
${SOF_LIB_PATH}/clk.c
${SOF_LIB_PATH}/notifier.c
${SOF_LIB_PATH}/pm_runtime.c
${SOF_LIB_PATH}/cpu-clk-manager.c
${SOF_LIB_PATH}/dma.c
${SOF_LIB_PATH}/dai.c
# SOF mandatory audio processing
${SOF_AUDIO_PATH}/channel_map.c
${SOF_AUDIO_PATH}/pcm_converter/pcm_converter_hifi3.c
${SOF_AUDIO_PATH}/pcm_converter/pcm_converter.c
${SOF_AUDIO_PATH}/pcm_converter/pcm_converter_generic.c
${SOF_AUDIO_PATH}/buffer.c
${SOF_AUDIO_PATH}/component.c
${SOF_AUDIO_PATH}/pipeline/pipeline-graph.c
${SOF_AUDIO_PATH}/pipeline/pipeline-params.c
${SOF_AUDIO_PATH}/pipeline/pipeline-schedule.c
${SOF_AUDIO_PATH}/pipeline/pipeline-stream.c
${SOF_AUDIO_PATH}/pipeline/pipeline-xrun.c
# SOF core infrastructure - runs on top of Zephyr
${SOF_SRC_PATH}/init/init.c
${SOF_SRC_PATH}/init/ext_manifest.c
${SOF_SRC_PATH}/arch/xtensa/drivers/cache_attr.c
${SOF_SRC_PATH}/schedule/zephyr_domain.c
${SOF_SRC_PATH}/schedule/schedule.c
${SOF_SRC_PATH}/idc/zephyr_idc.c
${SOF_SRC_PATH}/lib-zephyr/cpu.c
# Bridge wrapper between SOF and Zephyr APIs - Will shrink over time.
wrapper.c
edf_schedule.c
schedule.c
lib/alloc.c
# Common library functions - Will be moved to Zephyr over time
lib.c
)
if(CONFIG_SCHEDULE_DMA_SINGLE_CHANNEL AND NOT(CONFIG_DMA_DOMAIN))
zephyr_library_sources(${SOF_SRC_PATH}/schedule/dma_single_chan_domain.c)
endif()
if(CONFIG_SCHEDULE_DMA_MULTI_CHANNEL AND NOT(CONFIG_DMA_DOMAIN))
zephyr_library_sources(${SOF_SRC_PATH}/schedule/dma_multi_chan_domain.c)
endif()
if (CONFIG_DMA_DOMAIN)
zephyr_library_sources(${SOF_SRC_PATH}/schedule/zephyr_dma_domain.c)
endif()
if(CONFIG_COMP_BLOB)
zephyr_library_sources(
${SOF_AUDIO_PATH}/data_blob.c
)
endif()
if(CONFIG_ZEPHYR_NATIVE_DRIVERS)
zephyr_library_sources(
${SOF_AUDIO_PATH}/host-zephyr.c
)
else()
zephyr_library_sources(
${SOF_AUDIO_PATH}/host-legacy.c
)
endif()
zephyr_library_sources_ifdef(CONFIG_IPC_MAJOR_3
${SOF_IPC_PATH}/ipc3/handler.c
${SOF_IPC_PATH}/ipc3/helper.c
${SOF_IPC_PATH}/ipc3/dai.c
${SOF_IPC_PATH}/ipc3/host-page-table.c
)
zephyr_library_sources_ifdef(CONFIG_IPC_MAJOR_4
${SOF_IPC_PATH}/ipc4/handler.c
${SOF_IPC_PATH}/ipc4/helper.c
${SOF_IPC_PATH}/ipc4/dai.c
${SOF_IPC_PATH}/ipc4/logging.c
)
zephyr_library_sources_ifdef(CONFIG_TRACE
${SOF_SRC_PATH}/trace/dma-trace.c
${SOF_SRC_PATH}/trace/trace.c)
zephyr_library_sources_ifdef(CONFIG_LOG_BACKEND_SOF_PROBE
${SOF_SRC_PATH}/logging/log_backend_probe.c)
# Optional SOF sources - depends on Kconfig - WIP
zephyr_library_sources_ifdef(CONFIG_COMP_FIR
${SOF_AUDIO_PATH}/eq_fir/eq_fir_hifi3.c
${SOF_AUDIO_PATH}/eq_fir/eq_fir_hifi2ep.c
${SOF_AUDIO_PATH}/eq_fir/eq_fir_generic.c
${SOF_AUDIO_PATH}/eq_fir/eq_fir.c
${SOF_MATH_PATH}/fir_generic.c
${SOF_MATH_PATH}/fir_hifi2ep.c
${SOF_MATH_PATH}/fir_hifi3.c
)
zephyr_library_sources_ifdef(CONFIG_COMP_IIR
${SOF_AUDIO_PATH}/eq_iir/eq_iir.c
)
zephyr_library_sources_ifdef(CONFIG_MATH_IIR_DF1
${SOF_MATH_PATH}/iir_df1_generic.c
${SOF_MATH_PATH}/iir_df1_hifi3.c
${SOF_MATH_PATH}/iir_df1.c
)
zephyr_library_sources_ifdef(CONFIG_MATH_IIR_DF2T
${SOF_MATH_PATH}/iir_df2t_generic.c
${SOF_MATH_PATH}/iir_df2t_hifi3.c
${SOF_MATH_PATH}/iir_df2t.c
)
zephyr_library_sources_ifdef(CONFIG_COMP_ASRC
${SOF_AUDIO_PATH}/asrc/asrc.c
${SOF_AUDIO_PATH}/asrc/asrc_farrow_hifi3.c
${SOF_AUDIO_PATH}/asrc/asrc_farrow.c
${SOF_AUDIO_PATH}/asrc/asrc_farrow_generic.c
)
zephyr_library_sources_ifdef(CONFIG_COMP_DCBLOCK
${SOF_AUDIO_PATH}/dcblock/dcblock_generic.c
${SOF_AUDIO_PATH}/dcblock/dcblock.c
)
zephyr_library_sources_ifdef(CONFIG_COMP_SEL
${SOF_AUDIO_PATH}/selector/selector_generic.c
${SOF_AUDIO_PATH}/selector/selector.c
)
zephyr_library_sources_ifdef(CONFIG_COMP_KPB
${SOF_AUDIO_PATH}/kpb.c
)
zephyr_library_sources_ifdef(CONFIG_COMP_SWITCH
${SOF_AUDIO_PATH}/switch.c
)
if(CONFIG_IPC_MAJOR_3)
zephyr_library_sources_ifdef(CONFIG_COMP_MIXER
${SOF_AUDIO_PATH}/mixer/mixer.c
${SOF_AUDIO_PATH}/mixer/mixer_generic.c
${SOF_AUDIO_PATH}/mixer/mixer_hifi3.c
)
elseif(CONFIG_IPC_MAJOR_4)
zephyr_library_sources_ifdef(CONFIG_COMP_MIXER
${SOF_AUDIO_PATH}/mixin_mixout/mixin_mixout.c
${SOF_AUDIO_PATH}/mixin_mixout/mixin_mixout_generic.c
${SOF_AUDIO_PATH}/mixin_mixout/mixin_mixout_hifi3.c
)
endif()
zephyr_library_sources_ifdef(CONFIG_COMP_TONE
${SOF_AUDIO_PATH}/tone.c
)
if(CONFIG_ZEPHYR_NATIVE_DRIVERS)
zephyr_library_sources_ifdef(CONFIG_COMP_DAI
${SOF_AUDIO_PATH}/dai-zephyr.c
)
else()
zephyr_library_sources_ifdef(CONFIG_COMP_DAI
${SOF_AUDIO_PATH}/dai-legacy.c
)
endif()
zephyr_library_sources_ifdef(CONFIG_IPC4_GATEWAY
${SOF_AUDIO_PATH}/ipcgtw.c
)
zephyr_library_sources_ifdef(CONFIG_SAMPLE_KEYPHRASE
${SOF_SAMPLES_PATH}/audio/detect_test.c
)
zephyr_library_sources_ifdef(CONFIG_COMP_VOLUME
${SOF_AUDIO_MODULES_PATH}/volume/volume_hifi3.c
${SOF_AUDIO_MODULES_PATH}/volume/volume_generic.c
${SOF_AUDIO_MODULES_PATH}/volume/volume.c
)
zephyr_library_sources_ifdef(CONFIG_COMP_MODULE_ADAPTER
${SOF_AUDIO_PATH}/module_adapter/module_adapter.c
${SOF_AUDIO_PATH}/module_adapter/module/generic.c
)
zephyr_library_sources_ifdef(CONFIG_LIBRARY_MANAGER
${SOF_SRC_PATH}/library_manager/lib_manager.c
${SOF_SRC_PATH}/library_manager/lib_notification.c
)
zephyr_include_directories_ifdef(CONFIG_INTEL_MODULES
${SOF_SRC_PATH}/include/sof/audio/module_adapter/iadk/
)
zephyr_library_sources_ifdef(CONFIG_INTEL_MODULES
${SOF_AUDIO_PATH}/module_adapter/module/iadk_modules.c
${SOF_AUDIO_PATH}/module_adapter/iadk/system_service.c
${SOF_AUDIO_PATH}/module_adapter/iadk/module_initial_settings_concrete.cpp
${SOF_AUDIO_PATH}/module_adapter/iadk/iadk_module_adapter.cpp
${SOF_AUDIO_PATH}/module_adapter/iadk/system_agent.cpp
)
if (CONFIG_COMP_MODULE_ADAPTER)
zephyr_library_sources_ifdef(CONFIG_CADENCE_CODEC
${SOF_AUDIO_PATH}/module_adapter/module/cadence.c
)
if (CONFIG_CADENCE_CODEC_MP3_DEC)
zephyr_library_import(xa_mp3_dec ${CONFIG_CADENCE_CODEC_MP3_DEC_LIB})
endif()
if (CONFIG_CADENCE_CODEC_AAC_DEC)
zephyr_library_import(xa_aac_dec ${CONFIG_CADENCE_CODEC_AAC_DEC_LIB})
endif()
zephyr_library_sources_ifdef(CONFIG_PASSTHROUGH_CODEC
${SOF_AUDIO_MODULES_PATH}/passthrough.c
)
endif()
zephyr_library_sources_ifdef(CONFIG_COMP_CHAIN_DMA
${SOF_AUDIO_PATH}/chain_dma.c
)
zephyr_library_sources_ifdef(CONFIG_COMP_SRC
${SOF_AUDIO_PATH}/src/src_hifi2ep.c
${SOF_AUDIO_PATH}/src/src_generic.c
${SOF_AUDIO_PATH}/src/src_hifi3.c
${SOF_AUDIO_PATH}/src/src_hifi4.c
${SOF_AUDIO_PATH}/src/src.c
)
zephyr_library_sources_ifdef(CONFIG_COMP_BASEFW_IPC4
${SOF_AUDIO_PATH}/base_fw.c
)
zephyr_library_sources_ifdef(CONFIG_COMP_COPIER
${SOF_AUDIO_PATH}/copier/copier_generic.c
${SOF_AUDIO_PATH}/copier/copier_hifi.c
${SOF_AUDIO_PATH}/copier/copier.c
)
zephyr_library_sources_ifdef(CONFIG_MAXIM_DSM
${SOF_AUDIO_PATH}/smart_amp/smart_amp.c
${SOF_AUDIO_PATH}/smart_amp/smart_amp_generic.c
${SOF_AUDIO_PATH}/smart_amp/smart_amp_maxim_dsm.c
)
zephyr_library_sources_ifdef(CONFIG_COMP_ARIA
${SOF_AUDIO_PATH}/aria/aria.c
)
zephyr_library_sources_ifdef(CONFIG_COMP_CROSSOVER
${SOF_AUDIO_PATH}/crossover/crossover.c
${SOF_AUDIO_PATH}/crossover/crossover_generic.c
)
zephyr_library_sources_ifdef(CONFIG_COMP_DRC
${SOF_AUDIO_PATH}/drc/drc.c
${SOF_AUDIO_PATH}/drc/drc_generic.c
${SOF_AUDIO_PATH}/drc/drc_math_generic.c
${SOF_AUDIO_PATH}/drc/drc_hifi3.c
${SOF_AUDIO_PATH}/drc/drc_math_hifi3.c
)
zephyr_library_sources_ifdef(CONFIG_COMP_MULTIBAND_DRC
${SOF_AUDIO_PATH}/multiband_drc/multiband_drc.c
${SOF_AUDIO_PATH}/multiband_drc/multiband_drc_generic.c
)
zephyr_library_sources_ifdef(CONFIG_COMP_GOOGLE_RTC_AUDIO_PROCESSING
${SOF_AUDIO_PATH}/google_rtc_audio_processing.c
)
zephyr_library_sources_ifdef(CONFIG_COMP_IGO_NR
${SOF_AUDIO_PATH}/igo_nr/igo_nr.c
)
zephyr_library_sources_ifdef(CONFIG_COMP_RTNR
${SOF_AUDIO_PATH}/rtnr/rtnr.c
)
zephyr_library_sources_ifdef(CONFIG_SAMPLE_SMART_AMP
${SOF_SAMPLES_PATH}/audio/smart_amp_test.c
)
zephyr_library_sources_ifdef(CONFIG_COMP_TDFB
${SOF_AUDIO_PATH}/tdfb/tdfb.c
${SOF_AUDIO_PATH}/tdfb/tdfb_direction.c
${SOF_AUDIO_PATH}/tdfb/tdfb_generic.c
${SOF_AUDIO_PATH}/tdfb/tdfb_hifiep.c
${SOF_AUDIO_PATH}/tdfb/tdfb_hifi3.c
)
zephyr_library_sources_ifdef(CONFIG_SQRT_FIXED
${SOF_MATH_PATH}/sqrt_int16.c
)
zephyr_library_sources_ifdef(CONFIG_COMP_UP_DOWN_MIXER
${SOF_AUDIO_PATH}/up_down_mixer/up_down_mixer.c
${SOF_AUDIO_PATH}/up_down_mixer/up_down_mixer_hifi3.c
)
zephyr_library_sources_ifdef(CONFIG_COMP_MUX
${SOF_AUDIO_PATH}/mux/mux.c
${SOF_AUDIO_PATH}/mux/mux_generic.c
)
zephyr_library_sources_ifdef(CONFIG_COMP_GOOGLE_HOTWORD_DETECT
${SOF_AUDIO_PATH}/google_hotword_detect.c
)
zephyr_library_sources_ifdef(CONFIG_DTS_CODEC
${SOF_AUDIO_PATH}/module_adapter/module/dts.c
)
zephyr_library_sources_ifdef(CONFIG_WAVES_CODEC
${SOF_AUDIO_PATH}/module_adapter/module/waves.c
)
zephyr_library_sources_ifdef(CONFIG_PROBE
${SOF_SRC_PATH}/probe/probe.c
)
zephyr_library_sources_ifdef(CONFIG_MULTICORE
${SOF_SRC_PATH}/idc/idc.c
)
zephyr_library_sources_ifdef(CONFIG_HAVE_AGENT
${SOF_LIB_PATH}/agent.c
)
zephyr_library_sources_ifdef(CONFIG_GDB_DEBUG
${SOF_DEBUG_PATH}/gdb/gdb.c
${SOF_DEBUG_PATH}/gdb/ringbuffer.c
)
zephyr_library_sources_ifdef(CONFIG_DW_DMA
${SOF_DRIVERS_PATH}/dw/dma.c
)
zephyr_library_link_libraries(SOF)
target_link_libraries(SOF INTERFACE zephyr_interface)
# Setup SOF directories
set(SOF_ROOT_SOURCE_DIRECTORY ${CMAKE_CURRENT_SOURCE_DIR}/..)
set(SOF_ROOT_BINARY_DIRECTORY ${CMAKE_CURRENT_BINARY_DIR})
# This generated/ directory is shared with Zephyr.
# PROJECT_BINARY_DIR is build/zephyr/
set(GENERATED_DIRECTORY ${PROJECT_BINARY_DIR}/include/generated)
set(VERSION_H_PATH ${GENERATED_DIRECTORY}/sof_versions.h)
find_package(Python3 COMPONENTS Interpreter)
set(PYTHON3 "${Python3_EXECUTABLE}")
# We don't know why we have this https://github.com/thesofproject/sof/issues/5212
target_compile_options(SOF INTERFACE -fno-inline-functions)
# SOF needs `typeof`, `__VA_ARGS__` and maybe other GNU C99
# extensions. TODO other flags required ?
target_compile_options(SOF INTERFACE $<$<COMPILE_LANGUAGE:C,ASM>: -std=gnu99>)
# Toolchain info
add_definitions(-DXCC_TOOLS_VERSION="${ZEPHYR_TOOLCHAIN_VARIANT}" -DCC_OPTIMIZE_FLAGS="${OPTIMIZATION_FLAG}")
# create version information
include(../scripts/cmake/version.cmake)
# Create Trace realtive file paths
sof_append_relative_path_definitions(modules_sof)
endif() # CONFIG_SOF