blob: bbfab1660628d47daa50fa37100bed8d9e36c874 [file] [log] [blame]
Raef Coles9ec67e62020-07-10 09:40:35 +01001#-------------------------------------------------------------------------------
David Hu1feb4b12022-02-23 17:22:07 +08002# Copyright (c) 2020-2022, Arm Limited. All rights reserved.
Raef Coles9ec67e62020-07-10 09:40:35 +01003#
4# SPDX-License-Identifier: BSD-3-Clause
5#
6#-------------------------------------------------------------------------------
7
Tamas Ban69219202020-10-27 08:13:18 +00008set(TFM_PROFILE profile_small CACHE STRING "Profile to use")
Tamas Ban69219202020-10-27 08:13:18 +00009set(TFM_ISOLATION_LEVEL 1 CACHE STRING "Isolation level")
Raef Coles9ec67e62020-07-10 09:40:35 +010010
11########################## BL2 #################################################
12
Tamas Ban69219202020-10-27 08:13:18 +000013set(MCUBOOT_IMAGE_NUMBER 1 CACHE STRING "Whether to combine S and NS into either 1 image, or sign each seperately")
Raef Coles9ec67e62020-07-10 09:40:35 +010014
15############################ Partitions ########################################
16
Tamas Ban69219202020-10-27 08:13:18 +000017set(TFM_PARTITION_PROTECTED_STORAGE OFF CACHE BOOL "Enable Protected Storage partition")
Raef Coles9ec67e62020-07-10 09:40:35 +010018
Tamas Ban69219202020-10-27 08:13:18 +000019set(ITS_BUF_SIZE 32 CACHE STRING "Size of the ITS internal data transfer buffer (defaults to ITS_MAX_ASSET_SIZE if not set)")
Raef Coles9ec67e62020-07-10 09:40:35 +010020
David Hu327bc842021-05-13 16:29:33 +080021set(CRYPTO_CONC_OPER_NUM 4 CACHE STRING "The max number of concurrent operations that can be active (allocated) at any time in Crypto")
22# Profile Small assigns a much smller heap size for backend crypto library as
23# asymmetric cryptography is not enabled.
24# Assign 0x200 bytes for each operation and totally 0x800 byets for max 4
25# concurrent operation as set in CRYPTO_CONC_OPER_NUM above
26set(CRYPTO_ENGINE_BUF_SIZE 0x800 CACHE STRING "Heap size for the crypto backend")
David Hu0c250bc2021-05-12 10:55:53 +080027set(CRYPTO_ASYM_SIGN_MODULE_DISABLED ON CACHE BOOL "Disable PSA Crypto asymmetric key signature module")
28set(CRYPTO_ASYM_ENCRYPT_MODULE_DISABLED ON CACHE BOOL "Disable PSA Crypto asymmetric key encryption module")
Raef Coles9ec67e62020-07-10 09:40:35 +010029
Tamas Ban69219202020-10-27 08:13:18 +000030set(SYMMETRIC_INITIAL_ATTESTATION ON CACHE BOOL "Use symmetric crypto for inital attestation")
Raef Coles9ec67e62020-07-10 09:40:35 +010031
Tamas Ban69219202020-10-27 08:13:18 +000032set(TFM_PARTITION_PLATFORM OFF CACHE BOOL "Enable Platform partition")
Raef Coles9ec67e62020-07-10 09:40:35 +010033
Sherry Zhang07b42412021-01-07 14:19:41 +080034set(TFM_PARTITION_FIRMWARE_UPDATE OFF CACHE BOOL "Enable firmware update partition")
35
Tamas Ban69219202020-10-27 08:13:18 +000036set(TFM_PARTITION_AUDIT_LOG OFF CACHE BOOL "Enable Audit Log partition")
Raef Coles9ec67e62020-07-10 09:40:35 +010037
Raef Coles9ec67e62020-07-10 09:40:35 +010038################################## Dependencies ################################
39
Tamas Ban69219202020-10-27 08:13:18 +000040set(TFM_MBEDCRYPTO_CONFIG_PATH "${CMAKE_SOURCE_DIR}/lib/ext/mbedcrypto/mbedcrypto_config/tfm_mbedcrypto_config_profile_small.h" CACHE PATH "Config to use for Mbed Crypto")
Raef Coles9ec67e62020-07-10 09:40:35 +010041
David Hu1feb4b12022-02-23 17:22:07 +080042# If it is specified to select SFN model in build command, enable SFN model in
43# Profile Small.
44# Otherwise, enable Library model in Profile Small by default.
45if (NOT DEFINED CONFIG_TFM_SPM_BACKEND)
46 set(TFM_LIB_MODEL ON CACHE BOOL "Use secure library model instead of IPC model")
47endif()