Awadhy Mohammed | 71bd937 | 2023-08-07 14:46:15 +0100 | [diff] [blame] | 1 | #------------------------------------------------------------------------------- |
Gergely Korcsák | 525d05c | 2024-05-13 17:40:27 +0200 | [diff] [blame] | 2 | # Copyright (c) 2023-2024, Arm Limited. All rights reserved. |
Awadhy Mohammed | 71bd937 | 2023-08-07 14:46:15 +0100 | [diff] [blame] | 3 | # |
| 4 | # SPDX-License-Identifier: BSD-3-Clause |
| 5 | # |
| 6 | #------------------------------------------------------------------------------- |
Nik Dewally | 4a063d7 | 2024-06-26 15:49:15 +0100 | [diff] [blame] | 7 | cmake_minimum_required(VERSION 3.21) |
Awadhy Mohammed | 71bd937 | 2023-08-07 14:46:15 +0100 | [diff] [blame] | 8 | |
| 9 | if (NOT DEFINED CONFIG_SPE_PATH OR NOT EXISTS ${CONFIG_SPE_PATH}) |
| 10 | message(FATAL_ERROR "CONFIG_SPE_PATH = ${CONFIG_SPE_PATH} is not defined or incorrect. Please provide full path to TF-M build artifacts using -DCONFIG_SPE_PATH=") |
| 11 | endif() |
| 12 | |
| 13 | list(APPEND CMAKE_MODULE_PATH ${CONFIG_SPE_PATH}/cmake) |
| 14 | |
| 15 | # A platform specific MCPU and architecture flags for NS side |
| 16 | include(${CONFIG_SPE_PATH}/platform/cpuarch.cmake) |
| 17 | # Include common configs exported from TF-M |
| 18 | include(${CONFIG_SPE_PATH}/cmake/spe_config.cmake) |
| 19 | |
Gergely Korcsák | 525d05c | 2024-05-13 17:40:27 +0200 | [diff] [blame] | 20 | # Select toolchain file if it is not specified via command line or the absolute path |
Awadhy Mohammed | 71bd937 | 2023-08-07 14:46:15 +0100 | [diff] [blame] | 21 | # is unavailable. |
| 22 | if (NOT DEFINED TFM_TOOLCHAIN_FILE) |
Gergely Korcsák | 525d05c | 2024-05-13 17:40:27 +0200 | [diff] [blame] | 23 | if (NOT DEFINED TFM_TOOLCHAIN) |
| 24 | set(TFM_TOOLCHAIN "GNUARM") |
| 25 | message(WARNING "TFM_TOOLCHAIN or TFM_TOOLCHAIN_FILE is not defined") |
| 26 | message(WARNING "TFM_TOOLCHAIN is set to ${TFM_TOOLCHAIN}") |
| 27 | endif() |
| 28 | set(TFM_TOOLCHAIN_FILE ${CONFIG_SPE_PATH}/cmake/toolchain_ns_${TFM_TOOLCHAIN}.cmake) |
Awadhy Mohammed | 71bd937 | 2023-08-07 14:46:15 +0100 | [diff] [blame] | 29 | endif() |
| 30 | |
| 31 | include(${TFM_TOOLCHAIN_FILE}) |
William Vinnicombe | e355943 | 2025-06-23 13:02:10 +0100 | [diff] [blame] | 32 | project("TF-M Example" LANGUAGES C ASM) |
Awadhy Mohammed | 71bd937 | 2023-08-07 14:46:15 +0100 | [diff] [blame] | 33 | |
Gergely Korcsák | 525d05c | 2024-05-13 17:40:27 +0200 | [diff] [blame] | 34 | add_executable(tfm_ns) |
| 35 | |
Awadhy Mohammed | 71bd937 | 2023-08-07 14:46:15 +0100 | [diff] [blame] | 36 | # The exported TF-M interfaces |
| 37 | add_subdirectory(${CONFIG_SPE_PATH} ${CMAKE_BINARY_DIR}/spe) |
| 38 | |
Gergely Korcsák | 525d05c | 2024-05-13 17:40:27 +0200 | [diff] [blame] | 39 | target_sources(tfm_ns |
| 40 | PRIVATE |
| 41 | main.c |
| 42 | ${CONFIG_SPE_PATH}/interface/src/os_wrapper/tfm_ns_interface_bare_metal.c |
| 43 | # GNU Arm compiler version greater equal than *11.3.Rel1* |
| 44 | # has a linker issue that required system calls are missing, |
| 45 | # such as _read and _write. Add stub functions of required |
| 46 | # system calls to solve this issue. |
| 47 | $<$<BOOL:${CONFIG_GNU_SYSCALL_STUB_ENABLED}>:syscalls_stub.c> |
Awadhy Mohammed | 71bd937 | 2023-08-07 14:46:15 +0100 | [diff] [blame] | 48 | ) |
| 49 | |
| 50 | target_link_libraries(tfm_ns |
| 51 | PRIVATE |
| 52 | tfm_api_ns |
| 53 | ) |
| 54 | |
Anton Komlev | 95add8a | 2024-05-09 14:33:11 +0100 | [diff] [blame] | 55 | if (CONFIG_TFM_USE_TRUSTZONE) |
| 56 | target_link_libraries(tfm_ns |
| 57 | PRIVATE |
| 58 | tfm_api_ns_tz |
| 59 | ) |
| 60 | endif() |
| 61 | |
Awadhy Mohammed | 71bd937 | 2023-08-07 14:46:15 +0100 | [diff] [blame] | 62 | set_target_properties(tfm_ns PROPERTIES |
| 63 | SUFFIX ".axf" |
| 64 | RUNTIME_OUTPUT_DIRECTORY "${CMAKE_BINARY_DIR}/bin" |
| 65 | ) |
| 66 | |
| 67 | target_add_scatter_file(tfm_ns ${CONFIG_SPE_PATH}/platform/linker_scripts) |
| 68 | |
| 69 | target_link_options(tfm_ns |
| 70 | PRIVATE |
| 71 | $<$<C_COMPILER_ID:GNU>:-Wl,-Map=${CMAKE_BINARY_DIR}/bin/tfm_ns.map> |
| 72 | $<$<C_COMPILER_ID:ARMClang>:--map> |
| 73 | $<$<C_COMPILER_ID:IAR>:--map\;${CMAKE_BINARY_DIR}/bin/tfm_ns.map> |
| 74 | ) |
| 75 | |
| 76 | add_convert_to_bin_target(tfm_ns) |