blob: d7040c8f1d92e5049b61c8510032b3fae0731cbd [file] [log] [blame]
Minos Galanakisf4ca6ac2017-12-11 02:39:21 +01001#!/usr/bin/env python3
2
3""" builtin_configs.py:
4
5 Default configuration files used as reference """
6
7from __future__ import print_function
8
9__copyright__ = """
10/*
Gergely Korcsákba0c5212024-04-03 18:21:49 +020011 * Copyright (c) 2018-2024, Arm Limited. All rights reserved.
Minos Galanakisf4ca6ac2017-12-11 02:39:21 +010012 *
13 * SPDX-License-Identifier: BSD-3-Clause
14 *
15 */
16 """
Karl Zhang08681e62020-10-30 13:56:03 +080017
18__author__ = "tf-m@lists.trustedfirmware.org"
Minos Galanakisf4ca6ac2017-12-11 02:39:21 +010019__project__ = "Trusted Firmware-M Open CI"
Xinyu Zhang06286a92021-07-22 14:00:51 +080020__version__ = "1.4.0"
Minos Galanakisf4ca6ac2017-12-11 02:39:21 +010021
Paul Sokolovsky3e8fce02022-04-07 01:23:30 +030022from copy import deepcopy
23
24
Minos Galanakisea421232019-06-20 17:11:28 +010025# common parameters for tf-m build system
26# This configuration template will be passed into the tfm-builder module after
27# the template evaluation is converted to a command
28
29_common_tfm_builder_cfg = {
30 "config_type": "tf-m",
31 "codebase_root_dir": "tf-m",
32 # Order to which the variants are evaluated. This affects the name of
33 # variant configuration and the wildcard replacement logic in invalid
34 # configuration tuples
Xinyu Zhangb708f572020-09-15 11:43:46 +080035 "sort_order": ["tfm_platform",
Xinyu Zhang433771e2022-04-01 16:49:17 +080036 "compiler",
Xinyu Zhangb708f572020-09-15 11:43:46 +080037 "isolation_level",
38 "test_regression",
39 "test_psa_api",
Minos Galanakisea421232019-06-20 17:11:28 +010040 "cmake_build_type",
Xinyu Zhangb708f572020-09-15 11:43:46 +080041 "with_bl2",
Xinyu Zhang9fd74242020-10-22 11:30:50 +080042 "profile",
Xinyu Zhangfd2e1152021-12-17 18:09:01 +080043 "extra_params"],
Minos Galanakisea421232019-06-20 17:11:28 +010044
45 # Keys for the templace will come from the combinations of parameters
46 # provided in the seed dictionary.
47
Xinyu Zhanga88a2eb2023-08-15 17:43:51 +080048 "spe_config_template": "cmake -G Ninja " + \
Jianliang Shen7905e5d2023-11-07 10:40:47 +080049 "-S %(spe_root_dir)s " + \
Xinyu Zhanga88a2eb2023-08-15 17:43:51 +080050 "-B %(ci_build_root_dir)s/spe " + \
Xinyu Zhangb708f572020-09-15 11:43:46 +080051 "-DTFM_PLATFORM=%(tfm_platform)s " + \
Xinyu Zhang85588522023-10-31 13:58:04 +080052 "-DTFM_TOOLCHAIN_FILE=%(codebase_root_dir)s/%(s_compiler)s " + \
Xinyu Zhangb708f572020-09-15 11:43:46 +080053 "-DTFM_ISOLATION_LEVEL=%(isolation_level)s " + \
Xinyu Zhangb18ae742023-04-25 14:33:27 +080054 "%(test_regression)s " + \
Xinyu Zhangb708f572020-09-15 11:43:46 +080055 "-DCMAKE_BUILD_TYPE=%(cmake_build_type)s " + \
Xinyu Zhang0aebb3d2022-04-11 18:27:12 +080056 "-DTEST_PSA_API=%(test_psa_api)s " + \
Xinyu Zhangb708f572020-09-15 11:43:46 +080057 "-DBL2=%(with_bl2)s " + \
Xinyu Zhang0aebb3d2022-04-11 18:27:12 +080058 "-DTFM_PROFILE=%(profile)s " + \
Xinyu Zhang0aebb3d2022-04-11 18:27:12 +080059 "%(extra_params)s " + \
Xinyu Zhanga88a2eb2023-08-15 17:43:51 +080060 "-DCONFIG_TFM_SOURCE_PATH=%(codebase_root_dir)s " + \
Xinyu Zhangb708f572020-09-15 11:43:46 +080061 "-DMBEDCRYPTO_PATH=%(codebase_root_dir)s/../mbedtls " + \
62 "-DPSA_ARCH_TESTS_PATH=%(codebase_root_dir)s/../psa-arch-tests " + \
63 "-DMCUBOOT_PATH=%(codebase_root_dir)s/../mcuboot " + \
Xinyu Zhang1f21cb22023-06-26 17:56:49 +080064 "-DQCBOR_PATH=%(codebase_root_dir)s/../qcbor " + \
Xinyu Zhanga88a2eb2023-08-15 17:43:51 +080065 "-DTFM_EXTRAS_REPO_PATH=%(codebase_root_dir)s/../tf-m-extras ",
66
67 "nspe_config_template": "cmake -G Ninja " + \
Jianliang Shen7905e5d2023-11-07 10:40:47 +080068 "-S %(nspe_root_dir)s " + \
Xinyu Zhanga88a2eb2023-08-15 17:43:51 +080069 "-B %(ci_build_root_dir)s/nspe " + \
70 "-DCONFIG_SPE_PATH=%(ci_build_root_dir)s/spe/api_ns " + \
Xinyu Zhang85588522023-10-31 13:58:04 +080071 "-DTFM_TOOLCHAIN_FILE=%(ci_build_root_dir)s/spe/api_ns/cmake/%(ns_compiler)s " + \
Xinyu Zhanga88a2eb2023-08-15 17:43:51 +080072 "%(extra_params)s " + \
73 "-DQCBOR_PATH=%(codebase_root_dir)s/../qcbor ",
74
75 # CMake build commands will be executed for every build.
76 "spe_cmake_build": "cmake --build %(ci_build_root_dir)s/spe -- install",
77 "nspe_cmake_build": "cmake --build %(ci_build_root_dir)s/nspe --",
Karl Zhangaff558a2020-05-15 14:28:23 +010078
Xinyu Zhang433771e2022-04-01 16:49:17 +080079 "set_compiler_path": "export PATH=$PATH:$%(compiler)s_PATH",
80
Minos Galanakisea421232019-06-20 17:11:28 +010081 # A small subset of string substitution params is allowed in commands.
82 # tfm_build_manager will replace %(_tbm_build_dir_)s, %(_tbm_code_dir_)s,
83 # _tbm_target_platform_ with the paths set when building
84
Xinyu Zhanga88a2eb2023-08-15 17:43:51 +080085 "artifact_capture_rex": (r'%(ci_build_root_dir)s/nspe'
Minos Galanakisea421232019-06-20 17:11:28 +010086 r'/(\w+\.(?:axf|bin|hex))$'),
87
Xinyu Zhang46b37182023-06-30 15:36:44 +080088 # Keys will append extra commands when matching target_platform
Xinyu Zhanga88a2eb2023-08-15 17:43:51 +080089 "post_build": {"arm/corstone1000": ("dd conv=notrunc bs=1 if=%(ci_build_root_dir)s/spe/bin/bl1_1.bin of=%(ci_build_root_dir)s/spe/bin/bl1.bin seek=0;"
90 "dd conv=notrunc bs=1 if=%(ci_build_root_dir)s/spe/bin/bl1_provisioning_bundle.bin of=%(ci_build_root_dir)s/spe/bin/bl1.bin seek=40960;"
Xinyu Zhang09acfbf2023-10-30 18:30:48 +080091 "%(codebase_root_dir)s/platform/ext/target/arm/corstone1000/create-flash-image.sh %(ci_build_root_dir)s/spe/bin/ cs1000.bin;"),
Emekcan Aras6df7d552023-08-15 09:54:42 +010092 "arm/musca_b1": ("srec_cat "
Xinyu Zhanga88a2eb2023-08-15 17:43:51 +080093 "%(ci_build_root_dir)s/spe/bin/"
94 "bl2.bin "
95 "-Binary -offset 0xA000000 "
96 "-fill 0xFF 0xA000000 0xA020000 "
97 "%(ci_build_root_dir)s/nspe/"
98 "tfm_s_ns_signed.bin "
99 "-Binary -offset 0xA020000 "
100 "-fill 0xFF 0xA020000 0xA200000 "
101 "-o %(ci_build_root_dir)s/"
102 "spe/bin/tfm.hex -Intel"),
Xinyu Zhang46b37182023-06-30 15:36:44 +0800103 "arm/musca_s1": ("srec_cat "
Xinyu Zhanga88a2eb2023-08-15 17:43:51 +0800104 "%(ci_build_root_dir)s/spe/bin/"
105 "bl2.bin "
106 "-Binary -offset 0xA000000 "
107 "-fill 0xFF 0xA000000 0xA020000 "
108 "%(ci_build_root_dir)s/nspe/"
109 "tfm_s_ns_signed.bin "
110 "-Binary -offset 0xA020000 "
111 "-fill 0xFF 0xA020000 0xA200000 "
112 "-o %(ci_build_root_dir)s/"
113 "spe/bin/tfm.hex -Intel"),
Xinyu Zhang46b37182023-06-30 15:36:44 +0800114 "stm/stm32l562e_dk": ("echo 'STM32L562E-DK board post process';"
Xinyu Zhanga88a2eb2023-08-15 17:43:51 +0800115 "%(ci_build_root_dir)s/spe/api_ns/postbuild.sh;"
116 "pushd %(ci_build_root_dir)s/spe/api_ns;"
117 "mkdir -p image_signing/scripts ;"
118 "cp %(ci_build_root_dir)s/nspe/bin/tfm_ns_signed.bin image_signing/scripts ;"
119 "tar jcf ./bin/stm32l562e-dk-tfm.tar.bz2 regression.sh TFM_UPDATE.sh "
120 "bin/bl2.bin "
121 "bin/tfm_s_signed.bin "
122 "image_signing/scripts/tfm_ns_signed.bin ;"
Xinyu Zhang46b37182023-06-30 15:36:44 +0800123 "popd"),
124 "stm/b_u585i_iot02a": ("echo 'STM32U5 board post process';"
Xinyu Zhanga88a2eb2023-08-15 17:43:51 +0800125 "%(ci_build_root_dir)s/spe/api_ns/postbuild.sh;"
126 "pushd %(ci_build_root_dir)s/spe/api_ns;"
127 "mkdir -p image_signing/scripts ;"
128 "cp %(ci_build_root_dir)s/nspe/bin/tfm_ns_signed.bin image_signing/scripts ;"
129 "tar jcf ./bin/b_u585i_iot02a-tfm.tar.bz2 regression.sh TFM_UPDATE.sh "
130 "bin/bl2.bin "
131 "bin/tfm_s_signed.bin "
132 "image_signing/scripts/tfm_ns_signed.bin ;"
Xinyu Zhang46b37182023-06-30 15:36:44 +0800133 "popd"),
Anton Komlev4164ab62024-02-23 10:59:56 +0100134 "stm/stm32h573i_dk": ("echo 'STM32H573I-DK board post process';"
135 "%(ci_build_root_dir)s/spe/api_ns/postbuild.sh;"
136 "pushd %(ci_build_root_dir)s/spe/api_ns;"
137 "mkdir -p image_signing/scripts ;"
138 "cp %(ci_build_root_dir)s/nspe/bin/tfm_ns_signed.bin image_signing/scripts ;"
139 "tar jcf ./bin/stm32h573i_dk-tfm.tar.bz2 regression.sh TFM_UPDATE.sh "
140 "bin/bl2.bin "
141 "bin/tfm_s_signed.bin "
142 "image_signing/scripts/tfm_ns_signed.bin ;"
143 "popd"),
Matthew Dalzelle1605c12024-04-17 16:58:34 +0100144# "nxp/lpcxpresso55s69": ("echo 'LPCXpresso55S69 board post process\n'; "
145# "python3 -m pip install --upgrade pip; "
146# "pip install libusb; " # this should not go here, remove after test
147# "pyocd list; "
148# "lsusb -v; "
149# "pyocd erase --mass -t lpc55s69 --no-wait; "
150# "if [ -f \"%(ci_build_root_dir)s/spe/bin/bl2.hex\" ]; then "
151# "pyocd flash %(ci_build_root_dir)s/spe/bin/bl2.hex -t lpc55s69 --no-wait; "
152# "pyocd flash %(ci_build_root_dir)s/nspe/bin/tfm_s_ns_signed.bin --base-address 0x8000 -t lpc55s69 --no-wait; "
153# "else "
154# "pyocd flash %(ci_build_root_dir)s/spe/bin/tfm_s.hex %(ci_build_root_dir)s/nspe/bin/tfm_ns.hex -t lpc55s69 --no-wait; "
155# "fi;"),
156# "nxp/lpcxpresso55s69": ("echo 'LPCXpresso55S69 bo.ard post process\n';"
157# "if [ -f \"%(ci_build_root_dir)s/spe/bin/bl2.hex\" ]; then FLASH_FILE='flash_bl2_JLink.py'; else FLASH_FILE='flash_JLink.py'; fi;"
158# "mkdir -p %(codebase_root_dir)s/build/bin ;"
159# # Workaround for flash_JLink.py
160# "cp %(ci_build_root_dir)s/spe/bin/tfm_s.hex %(codebase_root_dir)s/build/bin ;"
161# "cp %(ci_build_root_dir)s/nspe/bin/tfm_ns.hex %(codebase_root_dir)s/build/bin ;"
162# "pushd %(codebase_root_dir)s/platform/ext/target/nxp/lpcxpresso55s69/scripts;"
163# "LN=$(grep -n 'JLinkExe' ${FLASH_FILE}|awk -F: '{print $1}');"
164# "sed -i \"${LN}s/.*/ print('flash.jlink generated')/\" ${FLASH_FILE};"
165# "python3 ./${FLASH_FILE};"
166# "cd %(codebase_root_dir)s/build/bin;"
167# "BIN_FILES=$(grep loadfile flash.jlink | awk '{print $2}');"
168# "tar jcf lpcxpresso55s69-tfm.tar.bz2 flash.jlink ${BIN_FILES};"
169# "mv lpcxpresso55s69-tfm.tar.bz2 %(ci_build_root_dir)s/nspe/bin ;"
170# "popd"),
171 "nxp/lpcxpresso55s69": ("echo 'LPCXpresso55S69 bo.ard post process\n';"
172 "mkdir -p %(codebase_root_dir)s/build/bin ;"
173 # Workaround for flash_JLink.py
174 "cp %(ci_build_root_dir)s/spe/bin/tfm_s.hex %(codebase_root_dir)s/build/bin ;"
175 "cp %(ci_build_root_dir)s/nspe/bin/tfm_ns.hex %(codebase_root_dir)s/build/bin ;"
Matthew Dalzellc25869b2024-04-17 17:19:11 +0100176 "cd %(codebase_root_dir)s/build/bin;"
Matthew Dalzell68789f62024-04-16 16:11:37 +0100177 "if [ -f \"%(ci_build_root_dir)s/spe/bin/bl2.hex\" ]; then "
Matthew Dalzelle1605c12024-04-17 16:58:34 +0100178 "echo r >> flash.jlink; echo erase >> flash.jlink; echo loadfile bl2.hex >> flash.jlink; echo loadfile tfm_s_ns_signed.bin -0x8000 >> flash.jlink; echo r >> flash.jlink; echo go >> flash.jlink; echo exit >> flash.jlink; "
Matthew Dalzell444eef72024-04-17 12:15:00 +0100179 "else "
Matthew Dalzelle1605c12024-04-17 16:58:34 +0100180 "echo r >> flash.jlink; echo erase >> flash.jlink; echo loadfile tfm_s.hex >> flash.jlink; echo loadfile tfm_ns.hex >> flash.jlink; echo r >> flash.jlink; echo go >> flash.jlink; echo exit >> flash.jlink; "
181 "fi;"
Matthew Dalzelle1605c12024-04-17 16:58:34 +0100182 "BIN_FILES=$(grep loadfile flash.jlink | awk '{print $2}');"
183 "tar jcf lpcxpresso55s69-tfm.tar.bz2 flash.jlink ${BIN_FILES};"
184 "mv lpcxpresso55s69-tfm.tar.bz2 %(ci_build_root_dir)s/nspe/bin ;"
185 "BIN_FILES=$(grep loadfile flash.jlink | awk '{print $2}');"),
Xinyu Zhang46b37182023-06-30 15:36:44 +0800186 "cypress/psoc64": ("echo 'Sign binaries for Cypress PSoC64 platform';"
Xinyu Zhanga88a2eb2023-08-15 17:43:51 +0800187 "pushd %(codebase_root_dir)s/;"
Arthur She87602dc2022-02-06 14:42:18 -0800188 "sudo /usr/local/bin/cysecuretools "
189 "--policy platform/ext/target/cypress/psoc64/security/policy/policy_multi_CM0_CM4_tfm.json "
190 "--target cy8ckit-064s0s2-4343w "
191 "sign-image "
Xinyu Zhanga88a2eb2023-08-15 17:43:51 +0800192 "--hex %(ci_build_root_dir)s/spe/bin/tfm_s.hex "
Arthur She87602dc2022-02-06 14:42:18 -0800193 "--image-type BOOT --image-id 1;"
194 "sudo /usr/local/bin/cysecuretools "
195 "--policy platform/ext/target/cypress/psoc64/security/policy/policy_multi_CM0_CM4_tfm.json "
196 "--target cy8ckit-064s0s2-4343w "
197 "sign-image "
Xinyu Zhanga88a2eb2023-08-15 17:43:51 +0800198 "--hex %(ci_build_root_dir)s/nspe/bin/tfm_ns.hex "
Arthur She87602dc2022-02-06 14:42:18 -0800199 "--image-type BOOT --image-id 16;"
Xinyu Zhanga88a2eb2023-08-15 17:43:51 +0800200 "mv %(ci_build_root_dir)s/spe/bin/tfm_s.hex %(ci_build_root_dir)s/spe/bin/tfm_s_signed.hex;"
201 "mv %(ci_build_root_dir)s/nspe/bin/tfm_ns.hex %(ci_build_root_dir)s/nspe/bin/tfm_ns_signed.hex;"
Xinyu Zhang46b37182023-06-30 15:36:44 +0800202 "popd")
Minos Galanakisea421232019-06-20 17:11:28 +0100203 },
204
205 # (Optional) If set will fail if those artefacts are missing post build
206 "required_artefacts": {"all": [
Xinyu Zhanga88a2eb2023-08-15 17:43:51 +0800207 "%(ci_build_root_dir)s/spe/bin/"
Xinyu Zhangb708f572020-09-15 11:43:46 +0800208 "tfm_s.bin",
Xinyu Zhanga88a2eb2023-08-15 17:43:51 +0800209 "%(ci_build_root_dir)s/nspe/"
Xinyu Zhangb708f572020-09-15 11:43:46 +0800210 "tfm_ns.bin"],
Mark Horvathef57baa2022-09-12 13:36:36 +0200211 "arm/musca_b1": [
Xinyu Zhanga88a2eb2023-08-15 17:43:51 +0800212 "%(ci_build_root_dir)s/tfm.hex",
213 "%(ci_build_root_dir)s/spe/bin/"
Xinyu Zhang694eb492020-11-04 18:29:08 +0800214 "bl2.bin",
Xinyu Zhanga88a2eb2023-08-15 17:43:51 +0800215 "%(ci_build_root_dir)s/spe/bin/"
Xinyu Zhangb708f572020-09-15 11:43:46 +0800216 "tfm_sign.bin"],
Summer Qin3c2b5722021-05-26 10:43:45 +0800217 "arm/musca_s1": [
Xinyu Zhanga88a2eb2023-08-15 17:43:51 +0800218 "%(ci_build_root_dir)s/tfm.hex",
219 "%(ci_build_root_dir)s/spe/bin/"
Xinyu Zhang694eb492020-11-04 18:29:08 +0800220 "bl2.bin",
Xinyu Zhanga88a2eb2023-08-15 17:43:51 +0800221 "%(ci_build_root_dir)s/spe/bin/"
Xinyu Zhangb708f572020-09-15 11:43:46 +0800222 "tfm_sign.bin"]
Minos Galanakisea421232019-06-20 17:11:28 +0100223 }
224}
Minos Galanakisf4ca6ac2017-12-11 02:39:21 +0100225
Xinyu Zhangb708f572020-09-15 11:43:46 +0800226# List of all build configs that are impossible under all circumstances
227_common_tfm_invalid_configs = [
Xinyu Zhang459a1982021-07-21 22:34:49 +0800228 # LR_CODE size exceeds limit on MUSCA_B1 & MUSCA_S1 with regression tests in Debug mode built with ARMCLANG
Paul Sokolovsky253ed722023-11-07 11:08:46 +0300229 ("arm/musca_b1", "ARMCLANG_6_21", "*", "RegBL2, RegS, RegNS", "OFF", "Debug", "*", "", "*"),
230 ("arm/musca_s1", "ARMCLANG_6_21", "*", "RegBL2, RegS, RegNS", "OFF", "Debug", "*", "", "*"),
Karl Zhangc858a722021-03-22 21:38:19 +0800231 # Load range overlap on Musca for IPC Debug type: T895
Paul Sokolovsky253ed722023-11-07 11:08:46 +0300232 ("arm/musca_b1", "ARMCLANG_6_21", "*", "*", "IPC", "Debug", "*", "*", "*"),
233 ("arm/musca_s1", "ARMCLANG_6_21", "*", "*", "IPC", "Debug", "*", "*", "*"),
Paul Sokolovsky75f67e82022-05-02 15:39:41 +0300234 # FF does not support L3
Summer Qin379abb62022-10-08 16:41:54 +0800235 ("*", "*", "3", "*", "IPC", "*", "*", "*", "*"),
Xinyu Zhang9fd74242020-10-22 11:30:50 +0800236 # Musca requires BL2
Summer Qin379abb62022-10-08 16:41:54 +0800237 ("arm/musca_b1", "*", "*", "*", "*", "*", False, "*", "*"),
238 ("arm/musca_s1", "*", "*", "*", "*", "*", False, "*", "*"),
Xinyu Zhangb1c550f2020-10-28 15:32:38 +0800239 # Only AN521 and MUSCA_B1 support Isolation Level 3
Summer Qin379abb62022-10-08 16:41:54 +0800240 ("arm/mps2/an519", "*", "3", "*", "*", "*", "*", "*", "*"),
241 ("arm/mps3/an524", "*", "3", "*", "*", "*", "*", "*", "*"),
242 ("arm/musca_s1", "*", "3", "*", "*", "*", "*", "*", "*"),
Xinyu Zhangb708f572020-09-15 11:43:46 +0800243 ]
244
Minos Galanakisf4ca6ac2017-12-11 02:39:21 +0100245# Configure build manager to build several combinations
Xinyu Zhang0aebb3d2022-04-11 18:27:12 +0800246# Config group for per-patch job
247config_pp_test = {"seed_params": {
Xinyu Zhang66e22ff2023-04-25 15:56:29 +0800248 # AN519_ARMCLANG_IPC_1_RegBL2_RegS_RegNS_Debug_BL2
Xinyu Zhang0aebb3d2022-04-11 18:27:12 +0800249 "tfm_platform": ["arm/mps2/an519"],
Paul Sokolovsky253ed722023-11-07 11:08:46 +0300250 "compiler": ["ARMCLANG_6_21"],
Xinyu Zhangfcb6aad2021-08-25 16:24:11 +0800251 "isolation_level": ["1"],
Xinyu Zhang66e22ff2023-04-25 15:56:29 +0800252 "test_regression": ["RegBL2, RegS, RegNS"],
Xinyu Zhangfcb6aad2021-08-25 16:24:11 +0800253 "test_psa_api": ["OFF"],
254 "cmake_build_type": ["Debug"],
Xinyu Zhangfcb6aad2021-08-25 16:24:11 +0800255 "with_bl2": [True],
Xinyu Zhangfcb6aad2021-08-25 16:24:11 +0800256 "profile": [""],
Xinyu Zhang0aebb3d2022-04-11 18:27:12 +0800257 "extra_params": [""]
Xinyu Zhangfcb6aad2021-08-25 16:24:11 +0800258 },
259 "common_params": _common_tfm_builder_cfg,
Xinyu Zhang0aebb3d2022-04-11 18:27:12 +0800260 "valid": [
Xinyu Zhang66e22ff2023-04-25 15:56:29 +0800261 # AN519_ARMCLANG_2_RegBL2_RegS_RegNS_Release_BL2
Paul Sokolovsky253ed722023-11-07 11:08:46 +0300262 ("arm/mps2/an519", "ARMCLANG_6_21", "2",
Xinyu Zhang66e22ff2023-04-25 15:56:29 +0800263 "RegBL2, RegS, RegNS", "OFF", "Release", True, "", ""),
264 # AN519_GCC_1_RegBL2_RegS_RegNS_Debug_BL2
Summer Qin379abb62022-10-08 16:41:54 +0800265 ("arm/mps2/an519", "GCC_10_3", "1",
Xinyu Zhang66e22ff2023-04-25 15:56:29 +0800266 "RegBL2, RegS, RegNS", "OFF", "Debug", True, "", ""),
267 # AN519_GCC_2_RegBL2_RegS_RegNS_Release_BL2
Summer Qin379abb62022-10-08 16:41:54 +0800268 ("arm/mps2/an519", "GCC_10_3", "2",
Xinyu Zhang66e22ff2023-04-25 15:56:29 +0800269 "RegBL2, RegS, RegNS", "OFF", "Release", True, "", ""),
270 # AN519_GCC_1_RegBL2_RegS_RegNS_Debug_BL2
Summer Qin379abb62022-10-08 16:41:54 +0800271 ("arm/mps2/an519", "GCC_10_3", "1",
Xinyu Zhang66e22ff2023-04-25 15:56:29 +0800272 "RegBL2, RegS, RegNS", "OFF", "Debug", True, "", ""),
273 # AN521_ARMCLANG_1_RegBL2_RegS_RegNS_Debug_BL2_SMALL_PSOFF
Paul Sokolovsky253ed722023-11-07 11:08:46 +0300274 ("arm/mps2/an521", "ARMCLANG_6_21", "1",
Xinyu Zhang66e22ff2023-04-25 15:56:29 +0800275 "RegBL2, RegS, RegNS", "OFF", "Debug", True, "profile_small", "PSOFF"),
276 # AN521_ARMCLANG_1_RegBL2_RegS_RegNS_Debug_BL2
Paul Sokolovsky253ed722023-11-07 11:08:46 +0300277 ("arm/mps2/an521", "ARMCLANG_6_21", "1",
Xinyu Zhang66e22ff2023-04-25 15:56:29 +0800278 "RegBL2, RegS, RegNS", "OFF", "Debug", True, "", ""),
Jianliang Shen6984bef2023-07-25 10:36:56 +0800279 # AN521_ARMCLANG_1_RegBL2_RegS_RegNS_Debug_BL2_IPC
Paul Sokolovsky253ed722023-11-07 11:08:46 +0300280 ("arm/mps2/an521", "ARMCLANG_6_21", "1",
Jianliang Shen6984bef2023-07-25 10:36:56 +0800281 "RegBL2, RegS, RegNS", "OFF", "Debug", True, "", "IPC"),
Xinyu Zhang66e22ff2023-04-25 15:56:29 +0800282 # AN521_ARMCLANG_2_RegBL2_RegS_RegNS_Release_BL2
Paul Sokolovsky253ed722023-11-07 11:08:46 +0300283 ("arm/mps2/an521", "ARMCLANG_6_21", "2",
Xinyu Zhang66e22ff2023-04-25 15:56:29 +0800284 "RegBL2, RegS, RegNS", "OFF", "Release", True, "", ""),
285 # AN521_ARMCLANG_3_RegBL2_RegS_RegNS_Minsizerel_BL2
Paul Sokolovsky253ed722023-11-07 11:08:46 +0300286 ("arm/mps2/an521", "ARMCLANG_6_21", "3",
Xinyu Zhang66e22ff2023-04-25 15:56:29 +0800287 "RegBL2, RegS, RegNS", "OFF", "Minsizerel", True, "", ""),
288 # AN521_ARMCLANG_1_RegBL2_RegS_RegNS_Debug_BL2_SMALL_PSOFF
Paul Sokolovsky253ed722023-11-07 11:08:46 +0300289 ("arm/mps2/an521", "ARMCLANG_6_21", "1",
Xinyu Zhang66e22ff2023-04-25 15:56:29 +0800290 "RegBL2, RegS, RegNS", "OFF", "Debug", True, "profile_small", "PSOFF"),
291 # AN521_GCC_1_RegBL2_RegS_RegNS_Debug_BL2
Summer Qin379abb62022-10-08 16:41:54 +0800292 ("arm/mps2/an521", "GCC_10_3", "1",
Xinyu Zhang66e22ff2023-04-25 15:56:29 +0800293 "RegBL2, RegS, RegNS", "OFF", "Debug", True, "", ""),
Summer Qin379abb62022-10-08 16:41:54 +0800294 # AN521_GCC_2_Debug_BL2_MEDIUM
295 ("arm/mps2/an521", "GCC_10_3", "2",
Xinyu Zhang66e22ff2023-04-25 15:56:29 +0800296 "RegBL2, RegS, RegNS", "OFF", "Debug", True, "profile_medium", ""),
297 # AN521_GCC_2_RegBL2_RegS_RegNS_Release_BL2
Summer Qin379abb62022-10-08 16:41:54 +0800298 ("arm/mps2/an521", "GCC_10_3", "2",
Xinyu Zhang66e22ff2023-04-25 15:56:29 +0800299 "RegBL2, RegS, RegNS", "OFF", "Release", True, "", ""),
300 # AN521_GCC_3_RegBL2_RegS_RegNS_Minsizerel_BL2
Summer Qin379abb62022-10-08 16:41:54 +0800301 ("arm/mps2/an521", "GCC_10_3", "3",
Xinyu Zhang66e22ff2023-04-25 15:56:29 +0800302 "RegBL2, RegS, RegNS", "OFF", "Minsizerel", True, "", ""),
303 # AN521_GCC_1_RegBL2_RegS_RegNS_Debug_BL2
Summer Qin379abb62022-10-08 16:41:54 +0800304 ("arm/mps2/an521", "GCC_10_3", "1",
Xinyu Zhang66e22ff2023-04-25 15:56:29 +0800305 "RegBL2, RegS, RegNS", "OFF", "Debug", True, "", ""),
Xinyu Zhang280f5ab2023-10-31 16:17:21 +0800306 # AN521_GCC_1_FF_Release_BL2
307 ("arm/mps2/an521", "GCC_10_3", "1",
308 "OFF", "IPC", "Release", True, "", ""),
309 # AN521_ARMCLANG_2_STORAGE_Debug_BL2
Paul Sokolovsky253ed722023-11-07 11:08:46 +0300310 ("arm/mps2/an521", "ARMCLANG_6_21", "2",
Xinyu Zhang280f5ab2023-10-31 16:17:21 +0800311 "OFF", "STORAGE", "Debug", True, "", ""),
Bence Balogh1aa8d582023-08-29 13:10:02 +0200312 # CS300_FVP_GNUARM_2_RegBL2_RegS_RegNS_Debug_BL2
313 ("arm/mps3/corstone300/fvp", "GCC_10_3", "2",
Xinyu Zhang66e22ff2023-04-25 15:56:29 +0800314 "RegBL2, RegS, RegNS", "OFF", "Debug", True, "", ""),
Bence Balogh1aa8d582023-08-29 13:10:02 +0200315 # CS300_FVP_GNUARM_2_RegBL2_RegS_RegNS_Release_BL2
316 ("arm/mps3/corstone300/fvp", "GCC_10_3", "2",
Xinyu Zhang66e22ff2023-04-25 15:56:29 +0800317 "RegBL2, RegS, RegNS", "OFF", "Release", True, "", ""),
Xinyu Zhang5c4f2182023-10-31 16:26:45 +0800318 # corstone1000_GCC_2_RegS_Debug_BL2_NSOFF_CS1K_TEST_FVP
319 ("arm/corstone1000", "GCC_10_3", "2",
320 "RegS", "OFF", "Debug", True, "", "NSOFF, CS1K_TEST, FVP"),
Xinyu Zhang66e22ff2023-04-25 15:56:29 +0800321 # MUSCA_B1_GCC_1_RegBL2_RegS_RegNS_Minsizerel_BL2
Summer Qin379abb62022-10-08 16:41:54 +0800322 ("arm/musca_b1", "GCC_10_3", "1",
Xinyu Zhang66e22ff2023-04-25 15:56:29 +0800323 "RegBL2, RegS, RegNS", "OFF", "Minsizerel", True, "", ""),
324 # MUSCA_S1_ARMCLANG_2_RegBL2_RegS_RegNS_Release_BL2
Paul Sokolovsky253ed722023-11-07 11:08:46 +0300325 ("arm/musca_s1", "ARMCLANG_6_21", "2",
Xinyu Zhang66e22ff2023-04-25 15:56:29 +0800326 "RegBL2, RegS, RegNS", "OFF", "Release", True, "", ""),
327 # MUSCA_S1_GCC_1_RegBL2_RegS_RegNS_Debug_BL2
Summer Qin379abb62022-10-08 16:41:54 +0800328 ("arm/musca_s1", "GCC_10_3", "1",
Xinyu Zhang66e22ff2023-04-25 15:56:29 +0800329 "RegBL2, RegS, RegNS", "OFF", "Debug", True, "", ""),
330 # MUSCA_S1_GCC_2_RegBL2_RegS_RegNS_Release_BL2
Summer Qin379abb62022-10-08 16:41:54 +0800331 ("arm/musca_s1", "GCC_10_3", "2",
Xinyu Zhang66e22ff2023-04-25 15:56:29 +0800332 "RegBL2, RegS, RegNS", "OFF", "Release", True, "", ""),
333 # MUSCA_S1_GCC_1_RegBL2_RegS_RegNS_Debug_BL2
Summer Qin379abb62022-10-08 16:41:54 +0800334 ("arm/musca_s1", "GCC_10_3", "1",
Xinyu Zhang66e22ff2023-04-25 15:56:29 +0800335 "RegBL2, RegS, RegNS", "OFF", "Debug", True, "", ""),
336 # MUSCA_S1_GCC_1_RegBL2_RegS_RegNS_Release_BL2_CC_DRIVER_PSA
Summer Qin379abb62022-10-08 16:41:54 +0800337 ("arm/musca_s1", "GCC_10_3", "1",
Xinyu Zhang66e22ff2023-04-25 15:56:29 +0800338 "RegBL2, RegS, RegNS", "OFF", "Release", True, "", "CC_DRIVER_PSA"),
Jamie Fox5ae6fa42024-02-19 15:11:00 +0000339 # RSE_TC_GCC_2_Release_BL2_PSOFF
340 ("arm/rse/tc", "GCC_10_3", "2",
Xinyu Zhangeddc68a2023-11-07 12:08:26 +0800341 "RegS, RegNS", "OFF", "Release", True, "", "PSOFF"),
Joel Goddard2dd81a12024-01-23 15:10:08 +0000342 # RSE_RDFremont_GCC_2_Release_BL2_NSOFF_PSOFF_CFG0
343 ("arm/rse/rdfremont", "GCC_10_3", "2",
344 "OFF", "OFF", "Release", True, "", "NSOFF, PSOFF, CFG0"),
Xinyu Zhangb18ae742023-04-25 14:33:27 +0800345 # stm32l562e_dk_ARMCLANG_1_RegS_RegNS_Release_BL2_CRYPTO_OFF
Paul Sokolovsky253ed722023-11-07 11:08:46 +0300346 ("stm/stm32l562e_dk", "ARMCLANG_6_21", "1",
Xinyu Zhangb18ae742023-04-25 14:33:27 +0800347 "RegS, RegNS", "OFF", "Release", True, "", "CRYPTO_OFF"),
348 # stm32l562e_dk_GCC_2_Release_BL2_CRYPTO_ON
Summer Qin379abb62022-10-08 16:41:54 +0800349 ("stm/stm32l562e_dk", "GCC_10_3", "2",
Xinyu Zhangb18ae742023-04-25 14:33:27 +0800350 "OFF", "OFF", "Release", True, "", "CRYPTO_ON"),
351 # stm32l562e_dk_GCC_3_RegS_RegNS_Release_BL2_CRYPTO_OFF
Summer Qin379abb62022-10-08 16:41:54 +0800352 ("stm/stm32l562e_dk", "GCC_10_3", "3",
Xinyu Zhang66e22ff2023-04-25 15:56:29 +0800353 "RegBL2, RegS, RegNS", "OFF", "Release", True, "", "CRYPTO_OFF"),
Arthur She4f08c152023-05-15 15:29:14 -0700354 # b_u585i_iot02a_GCC_1_RegS_RegNS_Release_BL2
355 ("stm/b_u585i_iot02a", "GCC_10_3", "1",
356 "RegS, RegNS", "OFF", "Release", True, "", ""),
357 # b_u585i_iot02a_ARMCLANG_2_RegS_RegNS_Release_BL2
Paul Sokolovsky253ed722023-11-07 11:08:46 +0300358 ("stm/b_u585i_iot02a", "ARMCLANG_6_21", "2",
Arthur She4f08c152023-05-15 15:29:14 -0700359 "RegS, RegNS", "OFF", "Release", True, "", ""),
Anton Komlev4164ab62024-02-23 10:59:56 +0100360 # stm32h573i_dk_GCC_1_RegS_RegNS_Release_BL2
361 ("stm/stm32h573i_dk", "GCC_10_3", "1",
362 "RegS, RegNS", "OFF", "Release", True, "", ""),
363 # stm32h573i_dk_ARMCLANG_2_RegS_RegNS_Release_BL2
364 ("stm/stm32h573i_dk", "ARMCLANG_6_21", "2",
365 "RegS, RegNS", "OFF", "Release", True, "", ""),
Xinyu Zhangb18ae742023-04-25 14:33:27 +0800366 # psoc64_GCC_2_RegS_RegNS_Release
Summer Qin379abb62022-10-08 16:41:54 +0800367 ("cypress/psoc64", "GCC_10_3", "2",
Xinyu Zhangb18ae742023-04-25 14:33:27 +0800368 "RegS, RegNS", "OFF", "Release", False, "", ""),
Xinyu Zhang0aebb3d2022-04-11 18:27:12 +0800369 ],
Xinyu Zhangfcb6aad2021-08-25 16:24:11 +0800370 "invalid": _common_tfm_invalid_configs + []
371 }
372
Xinyu Zhang0aebb3d2022-04-11 18:27:12 +0800373# Config group for nightly job
374config_nightly_test = {"seed_params": {
375 "tfm_platform": ["arm/mps2/an519",
376 "arm/mps2/an521",
377 "arm/mps3/an524",
378 "arm/musca_s1",
Mark Horvathef57baa2022-09-12 13:36:36 +0200379 "arm/musca_b1"],
Paul Sokolovsky253ed722023-11-07 11:08:46 +0300380 "compiler": ["GCC_10_3", "ARMCLANG_6_21"],
Xinyu Zhang0aebb3d2022-04-11 18:27:12 +0800381 "isolation_level": ["1", "2", "3"],
Xinyu Zhang66e22ff2023-04-25 15:56:29 +0800382 "test_regression": ["OFF", "RegBL2, RegS, RegNS"],
Xinyu Zhangb708f572020-09-15 11:43:46 +0800383 "test_psa_api": ["OFF"],
Xinyu Zhang0aebb3d2022-04-11 18:27:12 +0800384 "cmake_build_type": ["Debug", "Release", "Minsizerel"],
Xinyu Zhang0aebb3d2022-04-11 18:27:12 +0800385 "with_bl2": [True],
Xinyu Zhangb708f572020-09-15 11:43:46 +0800386 "profile": [""],
Xinyu Zhangfd2e1152021-12-17 18:09:01 +0800387 "extra_params": [""]
Minos Galanakisea421232019-06-20 17:11:28 +0100388 },
389 "common_params": _common_tfm_builder_cfg,
Xinyu Zhangb708f572020-09-15 11:43:46 +0800390 "invalid": _common_tfm_invalid_configs + []
Minos Galanakisea421232019-06-20 17:11:28 +0100391 }
392
Xinyu Zhang0aebb3d2022-04-11 18:27:12 +0800393# Config group for release job
394config_release_test = {"seed_params": {
395 "tfm_platform": ["arm/mps2/an519",
396 "arm/mps2/an521",
397 "arm/mps3/an524",
Mark Horvathef57baa2022-09-12 13:36:36 +0200398 "arm/musca_b1",
Xinyu Zhang0aebb3d2022-04-11 18:27:12 +0800399 "arm/musca_s1"],
Paul Sokolovsky253ed722023-11-07 11:08:46 +0300400 "compiler": ["GCC_10_3", "ARMCLANG_6_21"],
Xinyu Zhang6922b7a2020-11-05 15:21:27 +0800401 "isolation_level": ["1", "2", "3"],
Xinyu Zhang66e22ff2023-04-25 15:56:29 +0800402 "test_regression": ["OFF", "RegBL2, RegS, RegNS"],
Xinyu Zhangb708f572020-09-15 11:43:46 +0800403 "test_psa_api": ["OFF"],
404 "cmake_build_type": ["Debug", "Release", "Minsizerel"],
Xinyu Zhang5564d8b2020-11-13 10:22:27 +0800405 "with_bl2": [True],
Xinyu Zhangb708f572020-09-15 11:43:46 +0800406 "profile": [""],
David Vinczed78e2622022-11-24 15:04:00 +0100407 "extra_params": ["TEST_CBOR"]
Xinyu Zhangb708f572020-09-15 11:43:46 +0800408 },
409 "common_params": _common_tfm_builder_cfg,
Xinyu Zhang47bfc0e2022-04-06 17:26:59 +0800410 "valid": [
411 # sanity test for GCC v11.2
Xinyu Zhang66e22ff2023-04-25 15:56:29 +0800412 # AN521_GCC_3_RegBL2_RegS_RegNS_Relwithdebinfo_BL2
Xinyu Zhang47bfc0e2022-04-06 17:26:59 +0800413 ("arm/mps2/an521", "GCC_11_2",
Xinyu Zhang66e22ff2023-04-25 15:56:29 +0800414 "3", "RegBL2, RegS, RegNS", "OFF", "Relwithdebinfo",
Xinyu Zhangdf88e302022-09-19 11:27:57 +0800415 True, "", ""),
Xinyu Zhang47bfc0e2022-04-06 17:26:59 +0800416 ],
Xinyu Zhangb708f572020-09-15 11:43:46 +0800417 "invalid": _common_tfm_invalid_configs + []
418 }
Karl Zhang14573bc2020-06-08 09:23:21 +0800419
Xinyu Zhang0aebb3d2022-04-11 18:27:12 +0800420# Config groups for TF-M features
421config_profile_s = {"seed_params": {
David Huda27ae72022-03-28 15:32:19 +0800422 "tfm_platform": ["arm/mps2/an519", "arm/mps2/an521"],
Paul Sokolovsky253ed722023-11-07 11:08:46 +0300423 "compiler": ["GCC_10_3", "ARMCLANG_6_21"],
David Huda27ae72022-03-28 15:32:19 +0800424 "isolation_level": ["1"],
Xinyu Zhang66e22ff2023-04-25 15:56:29 +0800425 "test_regression": ["OFF", "RegBL2, RegS, RegNS"],
David Huda27ae72022-03-28 15:32:19 +0800426 "test_psa_api": ["OFF"],
427 "cmake_build_type": ["Debug", "Release", "Minsizerel"],
David Huda27ae72022-03-28 15:32:19 +0800428 "with_bl2": [True],
David Huda27ae72022-03-28 15:32:19 +0800429 "profile": ["profile_small"],
Xinyu Zhangdf88e302022-09-19 11:27:57 +0800430 "extra_params": ["PSOFF"]
David Huda27ae72022-03-28 15:32:19 +0800431 },
432 "common_params": _common_tfm_builder_cfg,
David Huda27ae72022-03-28 15:32:19 +0800433 "invalid": _common_tfm_invalid_configs + [
Summer Qin379abb62022-10-08 16:41:54 +0800434 ("arm/mps2/an519", "GCC_10_3", "*", "*",
Xinyu Zhangdf88e302022-09-19 11:27:57 +0800435 "*", "Minsizerel", "*", "*", "*")
David Huda27ae72022-03-28 15:32:19 +0800436 ]
437 }
438
Xinyu Zhang0aebb3d2022-04-11 18:27:12 +0800439config_profile_m = {"seed_params": {
440 "tfm_platform": ["arm/mps2/an519",
441 "arm/mps2/an521",
Mark Horvathef57baa2022-09-12 13:36:36 +0200442 "arm/musca_b1"],
Paul Sokolovsky253ed722023-11-07 11:08:46 +0300443 "compiler": ["GCC_10_3", "ARMCLANG_6_21"],
Xinyu Zhang0aebb3d2022-04-11 18:27:12 +0800444 "isolation_level": ["2"],
Xinyu Zhang66e22ff2023-04-25 15:56:29 +0800445 "test_regression": ["OFF", "RegBL2, RegS, RegNS"],
Xinyu Zhangb708f572020-09-15 11:43:46 +0800446 "test_psa_api": ["OFF"],
447 "cmake_build_type": ["Debug", "Release", "Minsizerel"],
Xinyu Zhang0aebb3d2022-04-11 18:27:12 +0800448 "with_bl2": [True],
Xinyu Zhang0aebb3d2022-04-11 18:27:12 +0800449 "profile": ["profile_medium"],
Xinyu Zhangdf88e302022-09-19 11:27:57 +0800450 "extra_params": ["", "PSOFF"]
Xinyu Zhang0aebb3d2022-04-11 18:27:12 +0800451 },
452 "common_params": _common_tfm_builder_cfg,
453 "invalid": _common_tfm_invalid_configs + []
454 }
455
David Hu3d333762022-10-27 18:12:33 +0800456config_profile_m_arotless = {"seed_params": {
457 "tfm_platform": ["arm/musca_b1"],
Paul Sokolovsky253ed722023-11-07 11:08:46 +0300458 "compiler": ["GCC_10_3", "ARMCLANG_6_21"],
David Hu3d333762022-10-27 18:12:33 +0800459 "isolation_level": ["1"],
Xinyu Zhang66e22ff2023-04-25 15:56:29 +0800460 "test_regression": ["OFF", "RegBL2, RegS, RegNS"],
David Hu3d333762022-10-27 18:12:33 +0800461 "test_psa_api": ["OFF"],
462 "cmake_build_type": ["Debug", "Release", "Minsizerel"],
463 "with_bl2": [True],
464 "profile": ["profile_medium_arotless"],
465 "extra_params": ["", "PSOFF"]
466 },
467 "common_params": _common_tfm_builder_cfg,
468 "invalid": _common_tfm_invalid_configs + []
469 }
470
Xinyu Zhang0aebb3d2022-04-11 18:27:12 +0800471config_profile_l = {"seed_params": {
472 "tfm_platform": ["arm/mps2/an521"],
Paul Sokolovsky253ed722023-11-07 11:08:46 +0300473 "compiler": ["GCC_10_3", "ARMCLANG_6_21"],
Xinyu Zhang0aebb3d2022-04-11 18:27:12 +0800474 "isolation_level": ["3"],
Xinyu Zhang66e22ff2023-04-25 15:56:29 +0800475 "test_regression": ["OFF", "RegBL2, RegS, RegNS"],
Xinyu Zhang0aebb3d2022-04-11 18:27:12 +0800476 "test_psa_api": ["OFF"],
477 "cmake_build_type": ["Debug", "Release", "Minsizerel"],
Xinyu Zhang0aebb3d2022-04-11 18:27:12 +0800478 "with_bl2": [True],
Xinyu Zhang0aebb3d2022-04-11 18:27:12 +0800479 "profile": ["profile_large"],
Xinyu Zhangdf88e302022-09-19 11:27:57 +0800480 "extra_params": ["", "PSOFF"]
Xinyu Zhang0aebb3d2022-04-11 18:27:12 +0800481 },
482 "common_params": _common_tfm_builder_cfg,
483 "invalid": _common_tfm_invalid_configs + []
484 }
485
Xinyu Zhang88b965c2022-11-21 17:50:33 +0800486config_ipc_backend = {"seed_params": {
487 "tfm_platform": ["arm/mps2/an519",
488 "arm/mps2/an521",
489 "arm/musca_s1",
490 "arm/musca_b1"],
Paul Sokolovsky253ed722023-11-07 11:08:46 +0300491 "compiler": ["GCC_10_3", "ARMCLANG_6_21"],
Xinyu Zhang88b965c2022-11-21 17:50:33 +0800492 "isolation_level": ["1"],
Xinyu Zhang66e22ff2023-04-25 15:56:29 +0800493 "test_regression": ["OFF", "RegBL2, RegS, RegNS"],
Xinyu Zhang88b965c2022-11-21 17:50:33 +0800494 "test_psa_api": ["OFF"],
495 "cmake_build_type": ["Debug", "Release", "Minsizerel"],
496 "with_bl2": [True],
497 "profile": [""],
498 "extra_params": ["IPC"]
499 },
500 "common_params": _common_tfm_builder_cfg,
501 "invalid": _common_tfm_invalid_configs + []
502 }
503
Xinyu Zhang0aebb3d2022-04-11 18:27:12 +0800504config_cc_driver_psa = {"seed_params": {
Mark Horvathef57baa2022-09-12 13:36:36 +0200505 "tfm_platform": ["arm/musca_b1",
Xinyu Zhang0aebb3d2022-04-11 18:27:12 +0800506 "arm/musca_s1"],
Xinyu Zhang16a218e2022-10-11 17:21:39 +0800507 "compiler": ["GCC_10_3"],
Xinyu Zhang0aebb3d2022-04-11 18:27:12 +0800508 "isolation_level": ["1"],
Xinyu Zhang66e22ff2023-04-25 15:56:29 +0800509 "test_regression": ["RegBL2, RegS, RegNS"],
Xinyu Zhang0aebb3d2022-04-11 18:27:12 +0800510 "test_psa_api": ["OFF"],
511 "cmake_build_type": ["Release"],
Xinyu Zhangb708f572020-09-15 11:43:46 +0800512 "with_bl2": [True],
Xinyu Zhangb708f572020-09-15 11:43:46 +0800513 "profile": [""],
Xinyu Zhang0aebb3d2022-04-11 18:27:12 +0800514 "extra_params": ["CC_DRIVER_PSA"]
Xinyu Zhangb708f572020-09-15 11:43:46 +0800515 },
516 "common_params": _common_tfm_builder_cfg,
517 "invalid": _common_tfm_invalid_configs + []
518 }
Karl Zhangaff558a2020-05-15 14:28:23 +0100519
Xinyu Zhang0aebb3d2022-04-11 18:27:12 +0800520config_fp = {"seed_params": {
Xinyu Zhange91567c2023-09-13 14:10:11 +0800521 "tfm_platform": ["arm/mps2/an521",
522 "arm/mps3/corstone300/an552",
523 "arm/mps3/corstone300/fvp"],
Xinyu Zhang0aebb3d2022-04-11 18:27:12 +0800524 "compiler": ["GCC_10_3"],
Xinyu Zhangb708f572020-09-15 11:43:46 +0800525 "isolation_level": ["1", "2"],
Xinyu Zhang66e22ff2023-04-25 15:56:29 +0800526 "test_regression": ["RegBL2, RegS, RegNS"],
Xinyu Zhangb708f572020-09-15 11:43:46 +0800527 "test_psa_api": ["OFF"],
528 "cmake_build_type": ["Debug", "Release"],
Xinyu Zhangb708f572020-09-15 11:43:46 +0800529 "with_bl2": [True],
Xinyu Zhangb708f572020-09-15 11:43:46 +0800530 "profile": [""],
Mark Horvath93cb5fb2022-09-06 17:51:24 +0200531 "extra_params": ["FPOFF", "FPON", "FPON, LZOFF"]
Xinyu Zhangb708f572020-09-15 11:43:46 +0800532 },
533 "common_params": _common_tfm_builder_cfg,
534 "invalid": _common_tfm_invalid_configs + []
535 }
Karl Zhangeffed972020-06-30 15:48:01 +0800536
Xinyu Zhang0aebb3d2022-04-11 18:27:12 +0800537config_psa_api = {"seed_params": {
538 "tfm_platform": ["arm/mps2/an521",
Mark Horvathef57baa2022-09-12 13:36:36 +0200539 "arm/musca_b1",
Xinyu Zhang0aebb3d2022-04-11 18:27:12 +0800540 "arm/musca_s1"],
Paul Sokolovsky253ed722023-11-07 11:08:46 +0300541 "compiler": ["GCC_10_3", "ARMCLANG_6_21"],
Xinyu Zhangb1c550f2020-10-28 15:32:38 +0800542 "isolation_level": ["1", "2", "3"],
Xinyu Zhangb18ae742023-04-25 14:33:27 +0800543 "test_regression": ["OFF"],
Xinyu Zhangb708f572020-09-15 11:43:46 +0800544 "test_psa_api": ["IPC",
545 "CRYPTO",
Xinyu Zhangb708f572020-09-15 11:43:46 +0800546 "INITIAL_ATTESTATION",
Xinyu Zhang39acb412021-07-09 20:35:19 +0800547 "STORAGE"],
Xinyu Zhangb708f572020-09-15 11:43:46 +0800548 "cmake_build_type": ["Debug", "Release", "Minsizerel"],
Xinyu Zhangb708f572020-09-15 11:43:46 +0800549 "with_bl2": [True],
Xinyu Zhangb708f572020-09-15 11:43:46 +0800550 "profile": [""],
Xinyu Zhangfd2e1152021-12-17 18:09:01 +0800551 "extra_params": [""]
Xinyu Zhangb708f572020-09-15 11:43:46 +0800552 },
553 "common_params": _common_tfm_builder_cfg,
Paul Sokolovsky75f67e82022-05-02 15:39:41 +0300554 "invalid": _common_tfm_invalid_configs + []
Xinyu Zhangb708f572020-09-15 11:43:46 +0800555 }
Karl Zhang14573bc2020-06-08 09:23:21 +0800556
Xinyu Zhang050e39a2021-11-16 14:38:15 +0800557config_nsce = {"seed_params": {
Xinyu Zhang9bfe8a92021-10-28 16:27:12 +0800558 "tfm_platform": ["arm/mps2/an521"],
Paul Sokolovsky253ed722023-11-07 11:08:46 +0300559 "compiler": ["GCC_10_3", "ARMCLANG_6_21"],
Xinyu Zhang9bfe8a92021-10-28 16:27:12 +0800560 "isolation_level": ["1", "2", "3"],
Xinyu Zhang66e22ff2023-04-25 15:56:29 +0800561 "test_regression": ["RegBL2, RegS, RegNS"],
Xinyu Zhang9bfe8a92021-10-28 16:27:12 +0800562 "test_psa_api": ["OFF"],
563 "cmake_build_type": ["Debug"],
Xinyu Zhang9bfe8a92021-10-28 16:27:12 +0800564 "with_bl2": [True],
Xinyu Zhang9bfe8a92021-10-28 16:27:12 +0800565 "profile": [""],
Xinyu Zhang67612992021-12-20 14:11:27 +0800566 "extra_params": ["NSCE"]
Xinyu Zhanga1088e22021-11-11 18:02:45 +0800567 },
568 "common_params": _common_tfm_builder_cfg,
569 "invalid": _common_tfm_invalid_configs + []
570 }
571
Xinyu Zhang050e39a2021-11-16 14:38:15 +0800572config_mmio = {"seed_params": {
Xinyu Zhanga1088e22021-11-11 18:02:45 +0800573 "tfm_platform": ["arm/mps2/an521"],
Paul Sokolovsky253ed722023-11-07 11:08:46 +0300574 "compiler": ["GCC_10_3", "ARMCLANG_6_21"],
Xinyu Zhanga1088e22021-11-11 18:02:45 +0800575 "isolation_level": ["1"],
Xinyu Zhang66e22ff2023-04-25 15:56:29 +0800576 "test_regression": ["RegBL2, RegS, RegNS"],
Xinyu Zhanga1088e22021-11-11 18:02:45 +0800577 "test_psa_api": ["OFF"],
578 "cmake_build_type": ["Debug", "Release", "Minsizerel"],
Xinyu Zhanga1088e22021-11-11 18:02:45 +0800579 "with_bl2": [True],
Xinyu Zhanga1088e22021-11-11 18:02:45 +0800580 "profile": [""],
Xinyu Zhang3bb01af2021-12-20 14:45:49 +0800581 "extra_params": ["MMIO"]
Xinyu Zhang9bfe8a92021-10-28 16:27:12 +0800582 },
583 "common_params": _common_tfm_builder_cfg,
584 "invalid": _common_tfm_invalid_configs + []
585 }
586
Bence Balogh79fda442022-10-14 18:01:37 +0200587# Config groups for TF-M examples
588config_example_vad = {"seed_params": {
Bence Balogh1aa8d582023-08-29 13:10:02 +0200589 "tfm_platform": ["arm/mps3/corstone300/an552"],
Bence Balogh79fda442022-10-14 18:01:37 +0200590 "compiler": ["GCC_10_3"],
591 "isolation_level": ["2"],
Xinyu Zhangb18ae742023-04-25 14:33:27 +0800592 "test_regression": ["OFF"],
Bence Balogh79fda442022-10-14 18:01:37 +0200593 "test_psa_api": ["OFF"],
594 "cmake_build_type": ["Release"],
595 "with_bl2": [True],
596 "profile": [""],
597 "extra_params": ["EXAMPLE_VAD"]
598 },
599 "common_params": _common_tfm_builder_cfg,
600 "invalid": _common_tfm_invalid_configs + []
601 }
602
Bence Balogh852f8bd2023-08-07 14:46:54 +0200603config_example_dma350_clcd = {"seed_params": {
Bence Balogh79fda442022-10-14 18:01:37 +0200604 "tfm_platform": ["arm/mps3/corstone310/fvp"],
605 "compiler": ["GCC_10_3"],
606 "isolation_level": ["2"],
Xinyu Zhangb18ae742023-04-25 14:33:27 +0800607 "test_regression": ["OFF"],
Bence Balogh79fda442022-10-14 18:01:37 +0200608 "test_psa_api": ["OFF"],
609 "cmake_build_type": ["Release"],
610 "with_bl2": [True],
611 "profile": [""],
Bence Balogh852f8bd2023-08-07 14:46:54 +0200612 "extra_params": ["EXAMPLE_DMA350_CLCD"]
Bence Balogh79fda442022-10-14 18:01:37 +0200613 },
614 "common_params": _common_tfm_builder_cfg,
615 "invalid": _common_tfm_invalid_configs + []
616 }
617
618config_example_dma350_s = {"seed_params": {
619 "tfm_platform": ["arm/mps3/corstone310/fvp"],
620 "compiler": ["GCC_10_3"],
621 "isolation_level": ["1"],
Xinyu Zhangb18ae742023-04-25 14:33:27 +0800622 "test_regression": ["OFF"],
Bence Balogh79fda442022-10-14 18:01:37 +0200623 "test_psa_api": ["OFF"],
624 "cmake_build_type": ["Release"],
625 "with_bl2": [True],
626 "profile": [""],
627 "extra_params": ["EXAMPLE_DMA350_S"]
628 },
629 "common_params": _common_tfm_builder_cfg,
630 "invalid": _common_tfm_invalid_configs + []
631 }
632
Bence Baloghd23cbda2023-08-07 15:30:58 +0200633config_example_dma350_ns = {"seed_params": {
634 "tfm_platform": ["arm/mps3/corstone310/fvp"],
635 "compiler": ["GCC_10_3"],
636 "isolation_level": ["1"],
637 "test_regression": ["OFF"],
638 "test_psa_api": ["OFF"],
639 "cmake_build_type": ["Release"],
640 "with_bl2": [True],
641 "profile": [""],
642 "extra_params": ["EXAMPLE_DMA350_NS"]
643 },
644 "common_params": _common_tfm_builder_cfg,
645 "invalid": _common_tfm_invalid_configs + []
646 }
647
Bence Balogh79fda442022-10-14 18:01:37 +0200648config_example_dma350_trigger = {"seed_params": {
649 "tfm_platform": ["arm/mps3/corstone310/fvp"],
650 "compiler": ["GCC_10_3"],
651 "isolation_level": ["2"],
Xinyu Zhangb18ae742023-04-25 14:33:27 +0800652 "test_regression": ["OFF"],
Bence Balogh79fda442022-10-14 18:01:37 +0200653 "test_psa_api": ["OFF"],
654 "cmake_build_type": ["Release"],
655 "with_bl2": [True],
656 "profile": [""],
657 "extra_params": ["EXAMPLE_DMA350_TRIGGER"]
658 },
659 "common_params": _common_tfm_builder_cfg,
660 "invalid": _common_tfm_invalid_configs + []
661 }
662
Paul Sokolovsky4fe40b12023-04-21 02:17:57 +0300663config_misra = {"seed_params": {
664 "tfm_platform": ["arm/musca_b1"],
665 "compiler": ["GCC_10_3"],
666 "isolation_level": ["1"],
667 "test_regression": ["OFF"],
668 "test_psa_api": ["OFF"],
669 "cmake_build_type": ["Debug"],
670 "with_bl2": [True],
Xinyu Zhange17926f2023-08-14 11:00:43 +0800671 "profile": ["profile_small", "profile_medium_arotless"],
Paul Sokolovsky4fe40b12023-04-21 02:17:57 +0300672 "extra_params": ["PSOFF"]
673 },
674 "common_params": _common_tfm_builder_cfg,
Xinyu Zhange17926f2023-08-14 11:00:43 +0800675 "valid": [
676 # MUSCA_B1_GCC_2_Debug_BL2_MEDIUM_PSOFF
677 ("arm/musca_b1", "GCC_10_3", "2", "OFF",
678 "OFF", "Debug", True, "profile_medium", "PSOFF"),
679 # MUSCA_B1_GCC_3_Debug_BL2_LARGE_PSOFF
680 ("arm/musca_b1", "GCC_10_3", "3", "OFF",
681 "OFF", "Debug", True, "profile_large", "PSOFF"),
682 ],
Paul Sokolovsky4fe40b12023-04-21 02:17:57 +0300683 "invalid": _common_tfm_invalid_configs + []
684 }
685
Paul Sokolovskya526e5d2023-06-15 09:49:13 +0300686config_misra_debug = {"seed_params": {
687 "tfm_platform": ["arm/musca_b1"],
688 "compiler": ["GCC_10_3"],
689 "isolation_level": ["1"],
690 "test_regression": ["OFF"],
691 "test_psa_api": ["OFF"],
692 "cmake_build_type": ["Debug"],
693 "with_bl2": [True],
694 "profile": ["profile_small"],
695 "extra_params": ["PSOFF"]
696 },
697 "common_params": _common_tfm_builder_cfg,
698 "invalid": _common_tfm_invalid_configs + []
699 }
700
Xinyu Zhang0aebb3d2022-04-11 18:27:12 +0800701# Config groups for code coverage
702config_cov_profile_s = deepcopy(config_profile_s)
Xinyu Zhang778424e2023-02-27 11:39:57 +0800703config_cov_profile_s["seed_params"]["tfm_platform"] = ["arm/mps2/an521"]
Xinyu Zhang16a218e2022-10-11 17:21:39 +0800704config_cov_profile_s["seed_params"]["compiler"] = ["GCC_10_3"]
Xinyu Zhangbdc37e32022-04-06 17:47:44 +0800705
Xinyu Zhang0aebb3d2022-04-11 18:27:12 +0800706config_cov_profile_m = deepcopy(config_profile_m)
Xinyu Zhang778424e2023-02-27 11:39:57 +0800707config_cov_profile_m["seed_params"]["tfm_platform"] = ["arm/mps2/an521"]
Xinyu Zhang16a218e2022-10-11 17:21:39 +0800708config_cov_profile_m["seed_params"]["compiler"] = ["GCC_10_3"]
Karl Zhang14573bc2020-06-08 09:23:21 +0800709
Xinyu Zhang0aebb3d2022-04-11 18:27:12 +0800710config_cov_profile_l = deepcopy(config_profile_l)
Xinyu Zhang778424e2023-02-27 11:39:57 +0800711config_cov_profile_l["seed_params"]["tfm_platform"] = ["arm/mps2/an521"]
Xinyu Zhang16a218e2022-10-11 17:21:39 +0800712config_cov_profile_l["seed_params"]["compiler"] = ["GCC_10_3"]
Karl Zhang14573bc2020-06-08 09:23:21 +0800713
Xinyu Zhang88b965c2022-11-21 17:50:33 +0800714config_cov_ipc_backend = deepcopy(config_ipc_backend)
715config_cov_ipc_backend["seed_params"]["tfm_platform"] = ["arm/mps2/an521"]
716config_cov_ipc_backend["seed_params"]["compiler"] = ["GCC_10_3"]
717
Xinyu Zhang0aebb3d2022-04-11 18:27:12 +0800718config_cov_nsce = deepcopy(config_nsce)
Xinyu Zhang778424e2023-02-27 11:39:57 +0800719config_cov_nsce["seed_params"]["tfm_platform"] = ["arm/mps2/an521"]
Xinyu Zhang16a218e2022-10-11 17:21:39 +0800720config_cov_nsce["seed_params"]["compiler"] = ["GCC_10_3"]
Karl Zhang14573bc2020-06-08 09:23:21 +0800721
Xinyu Zhang0aebb3d2022-04-11 18:27:12 +0800722config_cov_mmio = deepcopy(config_mmio)
Xinyu Zhang778424e2023-02-27 11:39:57 +0800723config_cov_mmio["seed_params"]["tfm_platform"] = ["arm/mps2/an521"]
Xinyu Zhang16a218e2022-10-11 17:21:39 +0800724config_cov_mmio["seed_params"]["compiler"] = ["GCC_10_3"]
Karl Zhang14573bc2020-06-08 09:23:21 +0800725
Xinyu Zhang5f725ee2022-12-19 10:29:20 +0800726config_cov_fp = deepcopy(config_fp)
727config_cov_fp["seed_params"]["tfm_platform"] = ["arm/mps2/an521"]
Xinyu Zhang778424e2023-02-27 11:39:57 +0800728config_cov_fp["seed_params"]["compiler"] = ["GCC_10_3"]
Xinyu Zhang5f725ee2022-12-19 10:29:20 +0800729
Xinyu Zhang0aebb3d2022-04-11 18:27:12 +0800730# Config groups for platforms
731config_an519 = {"seed_params": {
Xinyu Zhangf25856a2021-06-17 14:06:46 +0800732 "tfm_platform": ["arm/mps2/an519"],
Paul Sokolovsky253ed722023-11-07 11:08:46 +0300733 "compiler": ["GCC_10_3", "ARMCLANG_6_21"],
Xinyu Zhangb708f572020-09-15 11:43:46 +0800734 "isolation_level": ["1", "2"],
Xinyu Zhang66e22ff2023-04-25 15:56:29 +0800735 "test_regression": ["OFF", "RegBL2, RegS, RegNS"],
Xinyu Zhangb708f572020-09-15 11:43:46 +0800736 "test_psa_api": ["OFF"],
Xinyu Zhang0aebb3d2022-04-11 18:27:12 +0800737 "cmake_build_type": ["Debug", "Release"],
Xinyu Zhangb708f572020-09-15 11:43:46 +0800738 "with_bl2": [True, False],
Xinyu Zhangb708f572020-09-15 11:43:46 +0800739 "profile": [""],
Xinyu Zhangfb80b5d2022-07-26 15:42:26 +0800740 "extra_params": ["", "NSOFF"]
Xinyu Zhangb708f572020-09-15 11:43:46 +0800741 },
742 "common_params": _common_tfm_builder_cfg,
Xinyu Zhang0aebb3d2022-04-11 18:27:12 +0800743 "invalid": _common_tfm_invalid_configs + []
744 }
745
746config_an521 = {"seed_params": {
747 "tfm_platform": ["arm/mps2/an521"],
Paul Sokolovsky253ed722023-11-07 11:08:46 +0300748 "compiler": ["GCC_10_3", "ARMCLANG_6_21"],
Xinyu Zhang0aebb3d2022-04-11 18:27:12 +0800749 "isolation_level": ["1", "2", "3"],
Xinyu Zhang66e22ff2023-04-25 15:56:29 +0800750 "test_regression": ["OFF", "RegBL2, RegS, RegNS"],
Xinyu Zhang0aebb3d2022-04-11 18:27:12 +0800751 "test_psa_api": ["OFF"],
752 "cmake_build_type": ["Debug", "Release"],
Xinyu Zhang0aebb3d2022-04-11 18:27:12 +0800753 "with_bl2": [True, False],
Xinyu Zhang0aebb3d2022-04-11 18:27:12 +0800754 "profile": [""],
Xinyu Zhangfb80b5d2022-07-26 15:42:26 +0800755 "extra_params": ["", "NSOFF"]
Xinyu Zhang0aebb3d2022-04-11 18:27:12 +0800756 },
757 "common_params": _common_tfm_builder_cfg,
758 "invalid": _common_tfm_invalid_configs + []
759 }
760
761config_an524 = {"seed_params": {
762 "tfm_platform": ["arm/mps3/an524"],
Paul Sokolovsky253ed722023-11-07 11:08:46 +0300763 "compiler": ["GCC_10_3", "ARMCLANG_6_21"],
Xinyu Zhang0aebb3d2022-04-11 18:27:12 +0800764 "isolation_level": ["1", "2"],
Xinyu Zhang66e22ff2023-04-25 15:56:29 +0800765 "test_regression": ["OFF", "RegBL2, RegS, RegNS"],
Xinyu Zhang0aebb3d2022-04-11 18:27:12 +0800766 "test_psa_api": ["OFF"],
767 "cmake_build_type": ["Debug", "Release"],
Xinyu Zhang0aebb3d2022-04-11 18:27:12 +0800768 "with_bl2": [True, False],
Xinyu Zhang0aebb3d2022-04-11 18:27:12 +0800769 "profile": [""],
Xinyu Zhangfb80b5d2022-07-26 15:42:26 +0800770 "extra_params": ["", "NSOFF"]
Xinyu Zhang0aebb3d2022-04-11 18:27:12 +0800771 },
772 "common_params": _common_tfm_builder_cfg,
773 "invalid": _common_tfm_invalid_configs + []
Xinyu Zhangb708f572020-09-15 11:43:46 +0800774 }
Dean Birch4c6ad622020-03-13 11:28:03 +0000775
Bence Balogh1aa8d582023-08-29 13:10:02 +0200776config_cs300_an547 = {"seed_params": {
777 "tfm_platform": ["arm/mps3/corstone300/an547"],
778 "compiler": ["GCC_10_3"],
779 "isolation_level": ["1"],
780 "test_regression": ["OFF"],
781 "test_psa_api": ["OFF"],
782 "cmake_build_type": ["Debug"],
783 "with_bl2": [True],
784 "profile": [""],
785 "extra_params": [""]
786 },
787 "common_params": _common_tfm_builder_cfg,
788 "invalid": _common_tfm_invalid_configs + []
789 }
Xinyu Zhang38b76742021-11-11 13:57:56 +0800790
Bence Balogh1aa8d582023-08-29 13:10:02 +0200791config_cs300_an552 = {"seed_params": {
792 "tfm_platform": ["arm/mps3/corstone300/an552"],
793 "compiler": ["GCC_10_3"],
794 "isolation_level": ["1", "2"],
795 "test_regression": ["OFF", "RegBL2, RegS, RegNS"],
796 "test_psa_api": ["OFF"],
797 "cmake_build_type": ["Debug", "Release"],
798 "with_bl2": [True],
799 "profile": [""],
800 "extra_params": [""]
801 },
802 "common_params": _common_tfm_builder_cfg,
803 "invalid": _common_tfm_invalid_configs + []
804 }
805
806config_cs300_fvp = {"seed_params": {
807 "tfm_platform": ["arm/mps3/corstone300/fvp"],
808 "compiler": ["GCC_10_3"],
809 "isolation_level": ["1", "2"],
810 "test_regression": ["OFF", "RegBL2, RegS, RegNS"],
811 "test_psa_api": ["OFF"],
812 "cmake_build_type": ["Debug", "Release"],
813 "with_bl2": [True],
814 "profile": [""],
815 "extra_params": [""]
816 },
817 "common_params": _common_tfm_builder_cfg,
818 "invalid": _common_tfm_invalid_configs + []
819 }
Xinyu Zhang0aebb3d2022-04-11 18:27:12 +0800820
821config_musca_b1 = {"seed_params": {
Mark Horvathef57baa2022-09-12 13:36:36 +0200822 "tfm_platform": ["arm/musca_b1"],
Paul Sokolovsky253ed722023-11-07 11:08:46 +0300823 "compiler": ["GCC_10_3", "ARMCLANG_6_21"],
Xinyu Zhang0aebb3d2022-04-11 18:27:12 +0800824 "isolation_level": ["1", "2", "3"],
Xinyu Zhang66e22ff2023-04-25 15:56:29 +0800825 "test_regression": ["OFF", "RegBL2, RegS, RegNS"],
Xinyu Zhang0aebb3d2022-04-11 18:27:12 +0800826 "test_psa_api": ["OFF"],
827 "cmake_build_type": ["Debug", "Release"],
Xinyu Zhang0aebb3d2022-04-11 18:27:12 +0800828 "with_bl2": [True],
Xinyu Zhang0aebb3d2022-04-11 18:27:12 +0800829 "profile": [""],
Xinyu Zhangfb80b5d2022-07-26 15:42:26 +0800830 "extra_params": ["", "NSOFF"]
Xinyu Zhang0aebb3d2022-04-11 18:27:12 +0800831 },
832 "common_params": _common_tfm_builder_cfg,
833 "invalid": _common_tfm_invalid_configs + []
834 }
835
Xinyu Zhang0aebb3d2022-04-11 18:27:12 +0800836config_musca_s1 = {"seed_params": {
837 "tfm_platform": ["arm/musca_s1"],
Paul Sokolovsky253ed722023-11-07 11:08:46 +0300838 "compiler": ["GCC_10_3", "ARMCLANG_6_21"],
Xinyu Zhang0aebb3d2022-04-11 18:27:12 +0800839 "isolation_level": ["1", "2"],
Xinyu Zhang66e22ff2023-04-25 15:56:29 +0800840 "test_regression": ["OFF", "RegBL2, RegS, RegNS"],
Xinyu Zhang0aebb3d2022-04-11 18:27:12 +0800841 "test_psa_api": ["OFF"],
842 "cmake_build_type": ["Debug", "Release"],
Xinyu Zhang0aebb3d2022-04-11 18:27:12 +0800843 "with_bl2": [True],
Xinyu Zhang0aebb3d2022-04-11 18:27:12 +0800844 "profile": [""],
Xinyu Zhangfb80b5d2022-07-26 15:42:26 +0800845 "extra_params": ["", "NSOFF"]
Xinyu Zhang0aebb3d2022-04-11 18:27:12 +0800846 },
847 "common_params": _common_tfm_builder_cfg,
848 "invalid": _common_tfm_invalid_configs + []
849 }
850
Bence Balogh8731a092022-05-24 17:24:54 +0200851config_corstone310 = {"seed_params": {
Bence Balogh23d8fa72022-11-08 12:16:23 +0100852 "tfm_platform": ["arm/mps3/corstone310/fvp"],
Bence Balogh176b78f2022-02-22 13:49:34 +0100853 "compiler": ["GCC_10_3"],
Xinyu Zhang38b76742021-11-11 13:57:56 +0800854 "isolation_level": ["1"],
Xinyu Zhangb18ae742023-04-25 14:33:27 +0800855 "test_regression": ["OFF"],
Xinyu Zhang38b76742021-11-11 13:57:56 +0800856 "test_psa_api": ["OFF"],
857 "cmake_build_type": ["Debug"],
Xinyu Zhang38b76742021-11-11 13:57:56 +0800858 "with_bl2": [True],
Xinyu Zhang38b76742021-11-11 13:57:56 +0800859 "profile": [""],
Xinyu Zhangfb80b5d2022-07-26 15:42:26 +0800860 "extra_params": ["NSOFF"]
Xinyu Zhang38b76742021-11-11 13:57:56 +0800861 },
862 "common_params": _common_tfm_builder_cfg,
863 "invalid": _common_tfm_invalid_configs + []
864 }
865
Gergely Korcsákba0c5212024-04-03 18:21:49 +0200866config_corstone315 = {"seed_params": {
867 "tfm_platform": ["arm/mps4/corstone315"],
868 "compiler": ["GCC_10_3", "ARMCLANG_6_21"],
869 "isolation_level": ["1"],
870 "test_regression": ["OFF"],
871 "test_psa_api": ["OFF"],
872 "cmake_build_type": ["Debug", "Release"],
873 "with_bl2": [True],
874 "profile": [""],
875 "extra_params": [""]
876 },
877 "common_params": _common_tfm_builder_cfg,
878 "invalid": _common_tfm_invalid_configs + []
879 }
880
Jamie Fox5ae6fa42024-02-19 15:11:00 +0000881config_rse = {"seed_params": {
882 "tfm_platform": ["arm/rse/tc"],
Jamie Foxf3b8aa82022-09-08 11:52:01 +0100883 "compiler": ["GCC_10_3"],
Jamie Foxf3b8aa82022-09-08 11:52:01 +0100884 "isolation_level": ["1", "2"],
Xinyu Zhang66e22ff2023-04-25 15:56:29 +0800885 "test_regression": ["OFF", "RegBL2, RegS, RegNS"],
Jamie Foxf3b8aa82022-09-08 11:52:01 +0100886 "test_psa_api": ["OFF"],
887 "cmake_build_type": ["Debug", "Release"],
888 "with_bl2": [True],
889 "profile": [""],
Xinyu Zhangdf88e302022-09-19 11:27:57 +0800890 "extra_params": ["PSOFF"]
Jamie Foxf3b8aa82022-09-08 11:52:01 +0100891 },
892 "common_params": _common_tfm_builder_cfg,
Jamie Fox9e2c2352023-01-13 15:11:23 +0000893 "invalid": _common_tfm_invalid_configs + [
Jamie Fox5ae6fa42024-02-19 15:11:00 +0000894 # BL2 is too large for RSE in Debug builds with tests
895 ("arm/rse/tc", "GCC_10_3", "*", "RegBL2, RegS, RegNS", "*",
Jamie Fox9e2c2352023-01-13 15:11:23 +0000896 "Debug", True, "*", "*"),
897 ]
Jamie Foxf3b8aa82022-09-08 11:52:01 +0100898 }
899
Joel Goddard2dd81a12024-01-23 15:10:08 +0000900config_rse_rdfremont = {"seed_params": {
901 "tfm_platform": ["arm/rse/rdfremont"],
902 "compiler": ["GCC_10_3"],
903 "isolation_level": ["1", "2"],
904 "test_regression": ["OFF"],
905 "test_psa_api": ["OFF"],
906 "cmake_build_type": ["Debug", "Release"],
907 "with_bl2": [True],
908 "profile": [""],
909 "extra_params": ["NSOFF, PSOFF, CFG0"]
910 },
911 "common_params": _common_tfm_builder_cfg,
912 "invalid": _common_tfm_invalid_configs + []
913 }
914
Xinyu Zhang0aebb3d2022-04-11 18:27:12 +0800915config_psoc64 = {"seed_params": {
916 "tfm_platform": ["cypress/psoc64"],
Paul Sokolovsky253ed722023-11-07 11:08:46 +0300917 "compiler": ["GCC_10_3", "ARMCLANG_6_21"],
Xinyu Zhang0aebb3d2022-04-11 18:27:12 +0800918 "isolation_level": ["1", "2"],
Xinyu Zhangb18ae742023-04-25 14:33:27 +0800919 "test_regression": ["RegS, RegNS"],
Xinyu Zhang0aebb3d2022-04-11 18:27:12 +0800920 "test_psa_api": ["OFF"],
921 "cmake_build_type": ["Release"],
Xinyu Zhang0aebb3d2022-04-11 18:27:12 +0800922 "with_bl2": [False],
Xinyu Zhang0aebb3d2022-04-11 18:27:12 +0800923 "profile": [""],
Xinyu Zhang0aebb3d2022-04-11 18:27:12 +0800924 "extra_params": [""]
925 },
926 "common_params": _common_tfm_builder_cfg,
927 "invalid": _common_tfm_invalid_configs + []
928 }
929
930config_corstone1000 = {"seed_params": {
931 "tfm_platform": ["arm/corstone1000"],
Xinyu Zhang16a218e2022-10-11 17:21:39 +0800932 "compiler": ["GCC_10_3"],
Xinyu Zhang5c4f2182023-10-31 16:26:45 +0800933 "isolation_level": ["1", "2"],
Emekcan Arasf8b39802023-04-24 10:15:22 +0100934 "test_regression": ["RegS"],
Xinyu Zhang0aebb3d2022-04-11 18:27:12 +0800935 "test_psa_api": ["OFF"],
936 "cmake_build_type": ["Debug"],
Xinyu Zhang0aebb3d2022-04-11 18:27:12 +0800937 "with_bl2": [True],
Xinyu Zhang0aebb3d2022-04-11 18:27:12 +0800938 "profile": [""],
Xinyu Zhang09acfbf2023-10-30 18:30:48 +0800939 "extra_params": ["NSOFF, CS1K_TEST, FVP", "NSOFF, CS1K_TEST, FPGA"]
Xinyu Zhang0aebb3d2022-04-11 18:27:12 +0800940 },
941 "common_params": _common_tfm_builder_cfg,
942 "invalid": _common_tfm_invalid_configs + []
943 }
944
945config_stm32l562e_dk = {"seed_params": {
946 "tfm_platform": ["stm/stm32l562e_dk"],
Paul Sokolovsky253ed722023-11-07 11:08:46 +0300947 "compiler": ["GCC_10_3", "ARMCLANG_6_21"],
Xinyu Zhang0aebb3d2022-04-11 18:27:12 +0800948 "isolation_level": ["1", "2", "3"],
Xinyu Zhang66e22ff2023-04-25 15:56:29 +0800949 "test_regression": ["OFF", "RegBL2, RegS, RegNS"],
Xinyu Zhang0aebb3d2022-04-11 18:27:12 +0800950 "test_psa_api": ["OFF"],
951 "cmake_build_type": ["Release"],
Xinyu Zhang0aebb3d2022-04-11 18:27:12 +0800952 "with_bl2": [True],
Xinyu Zhang0aebb3d2022-04-11 18:27:12 +0800953 "profile": [""],
Xinyu Zhang0aebb3d2022-04-11 18:27:12 +0800954 "extra_params": ["CRYPTO_OFF", "CRYPTO_ON"]
955 },
956 "common_params": _common_tfm_builder_cfg,
957 "invalid": _common_tfm_invalid_configs + [
Xinyu Zhang66e22ff2023-04-25 15:56:29 +0800958 # Oversize issue on config stm32l562e_dk_ARMCLANG_1_RegBL2_RegS_RegNS_Release_BL2
Paul Sokolovsky253ed722023-11-07 11:08:46 +0300959 ("stm/stm32l562e_dk", "ARMCLANG_6_21", "1",
Xinyu Zhang66e22ff2023-04-25 15:56:29 +0800960 "RegBL2, RegS, RegNS", "OFF", "Release", True, "", "*"),
Xinyu Zhang0aebb3d2022-04-11 18:27:12 +0800961 # all other tests are off when CRYPTO is ON
Xinyu Zhang66e22ff2023-04-25 15:56:29 +0800962 ("stm/stm32l562e_dk", "*", "*", "RegBL2, RegS, RegNS", "*",
Xinyu Zhangdf88e302022-09-19 11:27:57 +0800963 "*", "*", "*", "CRYPTO_ON"),
Xinyu Zhang0aebb3d2022-04-11 18:27:12 +0800964 # all other tests are ON when CRYPTO is OFF
Xinyu Zhangb18ae742023-04-25 14:33:27 +0800965 ("stm/stm32l562e_dk", "*", "*", "OFF", "*",
Xinyu Zhangdf88e302022-09-19 11:27:57 +0800966 "*", "*", "*", "CRYPTO_OFF"),
Xinyu Zhang0aebb3d2022-04-11 18:27:12 +0800967 ]
968 }
969
970config_b_u585i_iot02a = {"seed_params": {
971 "tfm_platform": ["stm/b_u585i_iot02a"],
Paul Sokolovsky253ed722023-11-07 11:08:46 +0300972 "compiler": ["GCC_10_3", "ARMCLANG_6_21"],
Arthur She026ebb62023-02-08 18:47:39 -0800973 "isolation_level": ["1", "2"],
Arthur She96c6f772023-05-09 21:32:50 -0700974 "test_regression": ["OFF", "RegS, RegNS"],
Xinyu Zhang0aebb3d2022-04-11 18:27:12 +0800975 "test_psa_api": ["OFF"],
976 "cmake_build_type": ["Release"],
Xinyu Zhang0aebb3d2022-04-11 18:27:12 +0800977 "with_bl2": [True],
Xinyu Zhang0aebb3d2022-04-11 18:27:12 +0800978 "profile": [""],
Arthur She026ebb62023-02-08 18:47:39 -0800979 "extra_params": [""]
Xinyu Zhang0aebb3d2022-04-11 18:27:12 +0800980 },
981 "common_params": _common_tfm_builder_cfg,
982 "invalid": _common_tfm_invalid_configs + []
983 }
984
Anton Komlev4164ab62024-02-23 10:59:56 +0100985config_stm32h573i_dk = {"seed_params": {
986 "tfm_platform": ["stm/stm32h573i_dk"],
987 "compiler": ["GCC_10_3", "ARMCLANG_6_21"],
988 "isolation_level": ["1", "2"],
989 "test_regression": ["OFF", "RegS, RegNS"],
990 "test_psa_api": ["OFF"],
991 "cmake_build_type": ["Release"],
992 "with_bl2": [True],
993 "profile": [""],
994 "extra_params": [""]
995 },
996 "common_params": _common_tfm_builder_cfg,
997 "invalid": _common_tfm_invalid_configs + []
998 }
999
Xinyu Zhang0aebb3d2022-04-11 18:27:12 +08001000config_nucleo_l552ze_q = {"seed_params": {
1001 "tfm_platform": ["stm/nucleo_l552ze_q"],
Xinyu Zhang16a218e2022-10-11 17:21:39 +08001002 "compiler": ["GCC_10_3"],
Xinyu Zhang0aebb3d2022-04-11 18:27:12 +08001003 "isolation_level": ["1"],
Xinyu Zhangb18ae742023-04-25 14:33:27 +08001004 "test_regression": ["OFF"],
Xinyu Zhang0aebb3d2022-04-11 18:27:12 +08001005 "test_psa_api": ["OFF"],
1006 "cmake_build_type": ["Release"],
Xinyu Zhang0aebb3d2022-04-11 18:27:12 +08001007 "with_bl2": [True],
Xinyu Zhang0aebb3d2022-04-11 18:27:12 +08001008 "profile": [""],
Xinyu Zhangfb80b5d2022-07-26 15:42:26 +08001009 "extra_params": ["NSOFF"]
Xinyu Zhang0aebb3d2022-04-11 18:27:12 +08001010 },
1011 "common_params": _common_tfm_builder_cfg,
1012 "invalid": _common_tfm_invalid_configs + []
1013 }
1014
1015config_lpcxpresso55s69 = {"seed_params": {
1016 "tfm_platform": ["nxp/lpcxpresso55s69"],
Xinyu Zhang16a218e2022-10-11 17:21:39 +08001017 "compiler": ["GCC_10_3"],
Xinyu Zhang0aebb3d2022-04-11 18:27:12 +08001018 "isolation_level": ["2"],
Xinyu Zhangb18ae742023-04-25 14:33:27 +08001019 "test_regression": ["OFF", "RegS, RegNS"],
Xinyu Zhang0aebb3d2022-04-11 18:27:12 +08001020 "test_psa_api": ["OFF"],
1021 "cmake_build_type": ["Relwithdebinfo"],
Xinyu Zhang0aebb3d2022-04-11 18:27:12 +08001022 "with_bl2": [False],
Xinyu Zhang0aebb3d2022-04-11 18:27:12 +08001023 "profile": ["profile_medium"],
Xinyu Zhang0aebb3d2022-04-11 18:27:12 +08001024 "extra_params": [""]
1025 },
1026 "common_params": _common_tfm_builder_cfg,
1027 "invalid": _common_tfm_invalid_configs + []
1028 }
1029
Xinyu Zhang38b76742021-11-11 13:57:56 +08001030config_bl5340 = {"seed_params": {
1031 "tfm_platform": ["lairdconnectivity/bl5340_dvk_cpuapp"],
Xinyu Zhang16a218e2022-10-11 17:21:39 +08001032 "compiler": ["GCC_10_3"],
Xinyu Zhang38b76742021-11-11 13:57:56 +08001033 "isolation_level": ["1"],
Xinyu Zhangb18ae742023-04-25 14:33:27 +08001034 "test_regression": ["OFF"],
Xinyu Zhang38b76742021-11-11 13:57:56 +08001035 "test_psa_api": ["OFF"],
1036 "cmake_build_type": ["Debug"],
Xinyu Zhang38b76742021-11-11 13:57:56 +08001037 "with_bl2": [True],
Xinyu Zhang38b76742021-11-11 13:57:56 +08001038 "profile": [""],
Xinyu Zhangfb80b5d2022-07-26 15:42:26 +08001039 "extra_params": ["NSOFF"]
Xinyu Zhang38b76742021-11-11 13:57:56 +08001040 },
1041 "common_params": _common_tfm_builder_cfg,
1042 "invalid": _common_tfm_invalid_configs + []
1043 }
1044
1045config_nrf5340dk = {"seed_params": {
1046 "tfm_platform": ["nordic_nrf/nrf5340dk_nrf5340_cpuapp"],
Xinyu Zhang16a218e2022-10-11 17:21:39 +08001047 "compiler": ["GCC_10_3"],
Xinyu Zhang38b76742021-11-11 13:57:56 +08001048 "isolation_level": ["1"],
Xinyu Zhangb18ae742023-04-25 14:33:27 +08001049 "test_regression": ["OFF"],
Xinyu Zhang38b76742021-11-11 13:57:56 +08001050 "test_psa_api": ["OFF"],
1051 "cmake_build_type": ["Debug"],
Xinyu Zhang38b76742021-11-11 13:57:56 +08001052 "with_bl2": [True],
Xinyu Zhang38b76742021-11-11 13:57:56 +08001053 "profile": [""],
Xinyu Zhangfb80b5d2022-07-26 15:42:26 +08001054 "extra_params": ["NSOFF"]
Xinyu Zhang38b76742021-11-11 13:57:56 +08001055 },
1056 "common_params": _common_tfm_builder_cfg,
1057 "invalid": _common_tfm_invalid_configs + []
1058 }
1059
1060config_nrf9160dk = {"seed_params": {
1061 "tfm_platform": ["nordic_nrf/nrf9160dk_nrf9160"],
Xinyu Zhang16a218e2022-10-11 17:21:39 +08001062 "compiler": ["GCC_10_3"],
Xinyu Zhang38b76742021-11-11 13:57:56 +08001063 "isolation_level": ["1"],
Xinyu Zhangb18ae742023-04-25 14:33:27 +08001064 "test_regression": ["OFF"],
Xinyu Zhang38b76742021-11-11 13:57:56 +08001065 "test_psa_api": ["OFF"],
1066 "cmake_build_type": ["Debug"],
Xinyu Zhang38b76742021-11-11 13:57:56 +08001067 "with_bl2": [True],
Xinyu Zhang38b76742021-11-11 13:57:56 +08001068 "profile": [""],
Xinyu Zhangfb80b5d2022-07-26 15:42:26 +08001069 "extra_params": ["NSOFF"]
Xinyu Zhang38b76742021-11-11 13:57:56 +08001070 },
1071 "common_params": _common_tfm_builder_cfg,
1072 "invalid": _common_tfm_invalid_configs + []
1073 }
1074
1075config_m2351 = {"seed_params": {
1076 "tfm_platform": ["nuvoton/m2351"],
Xinyu Zhang16a218e2022-10-11 17:21:39 +08001077 "compiler": ["GCC_10_3"],
Xinyu Zhang38b76742021-11-11 13:57:56 +08001078 "isolation_level": ["1"],
Xinyu Zhangb18ae742023-04-25 14:33:27 +08001079 "test_regression": ["OFF"],
Xinyu Zhang38b76742021-11-11 13:57:56 +08001080 "test_psa_api": ["OFF"],
1081 "cmake_build_type": ["Release"],
Xinyu Zhang38b76742021-11-11 13:57:56 +08001082 "with_bl2": [True],
Xinyu Zhang38b76742021-11-11 13:57:56 +08001083 "profile": [""],
Xinyu Zhangfb80b5d2022-07-26 15:42:26 +08001084 "extra_params": ["NSOFF"]
Xinyu Zhang38b76742021-11-11 13:57:56 +08001085 },
1086 "common_params": _common_tfm_builder_cfg,
1087 "invalid": _common_tfm_invalid_configs + []
1088 }
1089
1090config_m2354 = {"seed_params": {
1091 "tfm_platform": ["nuvoton/m2354"],
Xinyu Zhang16a218e2022-10-11 17:21:39 +08001092 "compiler": ["GCC_10_3"],
Xinyu Zhang38b76742021-11-11 13:57:56 +08001093 "isolation_level": ["1"],
Xinyu Zhangb18ae742023-04-25 14:33:27 +08001094 "test_regression": ["OFF"],
Xinyu Zhang38b76742021-11-11 13:57:56 +08001095 "test_psa_api": ["OFF"],
1096 "cmake_build_type": ["Debug"],
Xinyu Zhang38b76742021-11-11 13:57:56 +08001097 "with_bl2": [True],
Xinyu Zhang38b76742021-11-11 13:57:56 +08001098 "profile": [""],
Xinyu Zhangfb80b5d2022-07-26 15:42:26 +08001099 "extra_params": ["NSOFF"]
Xinyu Zhang38b76742021-11-11 13:57:56 +08001100 },
1101 "common_params": _common_tfm_builder_cfg,
1102 "invalid": _common_tfm_invalid_configs + []
1103 }
1104
Jianliang Shen48704152023-10-17 17:06:00 +08001105config_mem_footprint = {"seed_params": {
1106 "tfm_platform": ["arm/mps2/an521"],
Paul Sokolovsky253ed722023-11-07 11:08:46 +03001107 "compiler": ["ARMCLANG_6_21"],
Jianliang Shen48704152023-10-17 17:06:00 +08001108 "isolation_level": ["1"],
1109 "test_regression": ["OFF"],
1110 "test_psa_api": ["OFF"],
1111 "cmake_build_type": ["Minsizerel"],
1112 "with_bl2": [True],
1113 "profile": [""],
1114 "extra_params": [""]
1115 },
1116 "common_params": _common_tfm_builder_cfg,
1117 "valid": [
1118 # AN521_ARMCLANG_1_Minsizerel_BL2_SMALL_PSOFF
Paul Sokolovsky253ed722023-11-07 11:08:46 +03001119 ("arm/mps2/an521", "ARMCLANG_6_21", "1",
Jianliang Shen48704152023-10-17 17:06:00 +08001120 "OFF", "OFF", "Minsizerel", True, "profile_small", "PSOFF"),
1121 # AN521_ARMCLANG_2_Minsizerel_BL2_MEDIUM_PSOFF
Paul Sokolovsky253ed722023-11-07 11:08:46 +03001122 ("arm/mps2/an521", "ARMCLANG_6_21", "2",
Jianliang Shen48704152023-10-17 17:06:00 +08001123 "OFF", "OFF", "Minsizerel", True, "profile_medium", "PSOFF"),
1124 # AN521_ARMCLANG_3_Minsizerel_BL2_LARGE_PSOFF
Paul Sokolovsky253ed722023-11-07 11:08:46 +03001125 ("arm/mps2/an521", "ARMCLANG_6_21", "3",
Jianliang Shen48704152023-10-17 17:06:00 +08001126 "OFF", "OFF", "Minsizerel", True, "profile_large", "PSOFF"),
1127 ],
1128 "invalid": _common_tfm_invalid_configs + []
1129 }
1130
Jianliang Shen5492f752023-07-27 15:59:01 +08001131config_prof = {"seed_params": {
1132 "tfm_platform": ["arm/mps2/an521"],
1133 "compiler": ["GCC_10_3"],
1134 "isolation_level": ["1"],
1135 "test_regression": ["OFF"],
1136 "test_psa_api": ["OFF"],
1137 "cmake_build_type": ["Release"],
1138 "with_bl2": [True],
1139 "profile": [""],
1140 "extra_params": ["PROF"]
1141 },
1142 "common_params": _common_tfm_builder_cfg,
1143 "valid": [
1144 # AN521_GNUARM_1_Release_BL2_IPC_PROF
1145 ("arm/mps2/an521", "GCC_10_3", "1",
1146 "OFF", "OFF", "Release", True, "", "IPC, PROF"),
1147 # AN521_GNUARM_2_Release_BL2_PROF
1148 ("arm/mps2/an521", "GCC_10_3", "2",
1149 "OFF", "OFF", "Release", True, "", "PROF"),
1150 # AN521_GNUARM_3_Release_BL2_PROF
1151 ("arm/mps2/an521", "GCC_10_3", "3",
1152 "OFF", "OFF", "Release", True, "", "PROF"),
1153 ],
1154 "invalid": _common_tfm_invalid_configs + []
1155 }
1156
Xinyu Zhang0aebb3d2022-04-11 18:27:12 +08001157# Config groups for debug
1158config_debug = {"seed_params": {
1159 "tfm_platform": ["arm/mps2/an521"],
Xinyu Zhang16a218e2022-10-11 17:21:39 +08001160 "compiler": ["GCC_10_3"],
Xinyu Zhang38b76742021-11-11 13:57:56 +08001161 "isolation_level": ["1"],
Xinyu Zhangb18ae742023-04-25 14:33:27 +08001162 "test_regression": ["OFF"],
Xinyu Zhang38b76742021-11-11 13:57:56 +08001163 "test_psa_api": ["OFF"],
Xinyu Zhang0aebb3d2022-04-11 18:27:12 +08001164 "cmake_build_type": ["Debug"],
Xinyu Zhang38b76742021-11-11 13:57:56 +08001165 "with_bl2": [True],
Xinyu Zhang38b76742021-11-11 13:57:56 +08001166 "profile": [""],
Xinyu Zhangfd2e1152021-12-17 18:09:01 +08001167 "extra_params": [""]
Xinyu Zhang38b76742021-11-11 13:57:56 +08001168 },
1169 "common_params": _common_tfm_builder_cfg,
1170 "invalid": _common_tfm_invalid_configs + []
1171 }
1172
Xinyu Zhang0aebb3d2022-04-11 18:27:12 +08001173config_debug_regr = deepcopy(config_debug)
Xinyu Zhang66e22ff2023-04-25 15:56:29 +08001174config_debug_regr["seed_params"]["test_regression"] = ["RegBL2, RegS, RegNS"]
Xinyu Zhang0aebb3d2022-04-11 18:27:12 +08001175
1176config_debug_PSA_API = {"seed_params": {
1177 "tfm_platform": ["arm/mps2/an521"],
Paul Sokolovsky253ed722023-11-07 11:08:46 +03001178 "compiler": ["ARMCLANG_6_21"],
Xinyu Zhang38b76742021-11-11 13:57:56 +08001179 "isolation_level": ["1"],
Xinyu Zhangb18ae742023-04-25 14:33:27 +08001180 "test_regression": ["OFF"],
Xinyu Zhang0aebb3d2022-04-11 18:27:12 +08001181 "test_psa_api": ["CRYPTO",
1182 "INITIAL_ATTESTATION",
1183 "STORAGE",
1184 "IPC"],
1185 "cmake_build_type": ["Debug"],
Xinyu Zhang38b76742021-11-11 13:57:56 +08001186 "with_bl2": [True],
Xinyu Zhang38b76742021-11-11 13:57:56 +08001187 "profile": [""],
Xinyu Zhangfd2e1152021-12-17 18:09:01 +08001188 "extra_params": [""]
Xinyu Zhang38b76742021-11-11 13:57:56 +08001189 },
1190 "common_params": _common_tfm_builder_cfg,
1191 "invalid": _common_tfm_invalid_configs + []
1192 }
1193
Karl Zhangaff558a2020-05-15 14:28:23 +01001194_builtin_configs = {
Xinyu Zhang5c4f2182023-10-31 16:26:45 +08001195 # per-patch test group
Xinyu Zhang0aebb3d2022-04-11 18:27:12 +08001196 "pp_test": config_pp_test,
Karl Zhang14573bc2020-06-08 09:23:21 +08001197
Xinyu Zhang0aebb3d2022-04-11 18:27:12 +08001198 # nightly test groups
1199 "nightly_test": config_nightly_test,
1200 "nightly_profile_s": config_profile_s,
1201 "nightly_profile_m": config_profile_m,
David Hu3d333762022-10-27 18:12:33 +08001202 "nightly_profile_m_arotless": config_profile_m_arotless,
Xinyu Zhang0aebb3d2022-04-11 18:27:12 +08001203 "nightly_profile_l": config_profile_l,
Xinyu Zhang88b965c2022-11-21 17:50:33 +08001204 "nightly_ipc_backend": config_ipc_backend,
Xinyu Zhang0aebb3d2022-04-11 18:27:12 +08001205 "nightly_cc_driver_psa": config_cc_driver_psa,
1206 "nightly_fp":config_fp,
1207 "nightly_psa_api": config_psa_api,
Xinyu Zhang050e39a2021-11-16 14:38:15 +08001208 "nightly_nsce": config_nsce,
1209 "nightly_mmio": config_mmio,
Bence Balogh1aa8d582023-08-29 13:10:02 +02001210 "nightly_cs300_an547": config_cs300_an547,
1211 "nightly_cs300_an552": config_cs300_an552,
1212 "nightly_cs300_fvp": config_cs300_fvp,
Bence Balogh8731a092022-05-24 17:24:54 +02001213 "nightly_corstone310": config_corstone310,
Gergely Korcsákba0c5212024-04-03 18:21:49 +02001214 "nightly_corstone315": config_corstone315,
Antonio de Angelis92ad2442023-08-07 15:00:32 +02001215 "nightly_corstone1000": config_corstone1000,
Jamie Fox5ae6fa42024-02-19 15:11:00 +00001216 "nightly_rse": config_rse,
Joel Goddard2dd81a12024-01-23 15:10:08 +00001217 "nightly_rse_rdfremont": config_rse_rdfremont,
Xinyu Zhang0aebb3d2022-04-11 18:27:12 +08001218 "nightly_psoc64": config_psoc64,
Anton Komlev55c3c022024-03-05 16:24:17 +01001219 "nightly_stm32l562e_dk": config_stm32l562e_dk,
Arthur She026ebb62023-02-08 18:47:39 -08001220 "nightly_b_u585i_iot02a": config_b_u585i_iot02a,
Anton Komlev4164ab62024-02-23 10:59:56 +01001221 "nightly_stm32h573i_dk": config_stm32h573i_dk,
Xinyu Zhang0aebb3d2022-04-11 18:27:12 +08001222 "nightly_lpcxpresso55s69": config_lpcxpresso55s69,
Karl Zhang14573bc2020-06-08 09:23:21 +08001223
Xinyu Zhang0aebb3d2022-04-11 18:27:12 +08001224 # release test groups
1225 "release_test": config_release_test,
1226 "release_profile_s": config_profile_s,
1227 "release_profile_m": config_profile_m,
David Hu3d333762022-10-27 18:12:33 +08001228 "release_profile_m_arotless": config_profile_m_arotless,
Xinyu Zhang0aebb3d2022-04-11 18:27:12 +08001229 "release_profile_l": config_profile_l,
Xinyu Zhang88b965c2022-11-21 17:50:33 +08001230 "release_ipc_backend": config_ipc_backend,
Xinyu Zhang0aebb3d2022-04-11 18:27:12 +08001231 "release_cc_driver_psa": config_cc_driver_psa,
1232 "release_fp": config_fp,
1233 "release_psa_api": config_psa_api,
Xinyu Zhang0aebb3d2022-04-11 18:27:12 +08001234 "release_nsce": config_nsce,
1235 "release_mmio": config_mmio,
Bence Balogh1aa8d582023-08-29 13:10:02 +02001236 "release_cs300_an547": config_cs300_an547,
1237 "release_cs300_an552": config_cs300_an552,
1238 "release_cs300_fvp": config_cs300_fvp,
Bence Balogh8731a092022-05-24 17:24:54 +02001239 "release_corstone310": config_corstone310,
Gergely Korcsákba0c5212024-04-03 18:21:49 +02001240 "release_corstone315": config_corstone315,
Jamie Fox5ae6fa42024-02-19 15:11:00 +00001241 "release_rse": config_rse,
Joel Goddard2dd81a12024-01-23 15:10:08 +00001242 "release_rse_rdfremont": config_rse_rdfremont,
Xinyu Zhang0aebb3d2022-04-11 18:27:12 +08001243 "release_psoc64": config_psoc64,
Anton Komlev55c3c022024-03-05 16:24:17 +01001244 "release_stm32l562e_dk": config_stm32l562e_dk,
Arthur She026ebb62023-02-08 18:47:39 -08001245 "release_b_u585i_iot02a": config_b_u585i_iot02a,
Anton Komlev4164ab62024-02-23 10:59:56 +01001246 "release_stm32h573i_dk": config_stm32h573i_dk,
Xinyu Zhang0aebb3d2022-04-11 18:27:12 +08001247 "release_lpcxpresso55s69": config_lpcxpresso55s69,
Karl Zhang14573bc2020-06-08 09:23:21 +08001248
Xinyu Zhang0aebb3d2022-04-11 18:27:12 +08001249 # code coverage test groups
1250 "coverage_profile_s": config_cov_profile_s,
1251 "coverage_profile_m": config_cov_profile_m,
1252 "coverage_profile_l": config_cov_profile_l,
Xinyu Zhang88b965c2022-11-21 17:50:33 +08001253 "coverage_ipc_backend": config_cov_ipc_backend,
Xinyu Zhang0aebb3d2022-04-11 18:27:12 +08001254 "coverage_nsce": config_cov_nsce,
1255 "coverage_mmio": config_cov_mmio,
Xinyu Zhang5f725ee2022-12-19 10:29:20 +08001256 "coverage_fp": config_cov_fp,
Xinyu Zhangf25856a2021-06-17 14:06:46 +08001257
Paul Sokolovsky4fe40b12023-04-21 02:17:57 +03001258 # MISRA analysis
1259 "misra": config_misra,
Paul Sokolovskya526e5d2023-06-15 09:49:13 +03001260 "misra_debug": config_misra_debug,
Paul Sokolovsky4fe40b12023-04-21 02:17:57 +03001261
Xinyu Zhang0aebb3d2022-04-11 18:27:12 +08001262 # platform groups
1263 "an521": config_an521,
1264 "an519": config_an519,
1265 "an524": config_an524,
Bence Balogh1aa8d582023-08-29 13:10:02 +02001266 "cs300_an547": config_cs300_an547,
1267 "cs300_an552": config_cs300_an552,
1268 "cs300_fvp": config_cs300_fvp,
Xinyu Zhang0aebb3d2022-04-11 18:27:12 +08001269 "musca_b1": config_musca_b1,
Xinyu Zhang0aebb3d2022-04-11 18:27:12 +08001270 "musca_s1": config_musca_s1,
Bence Balogh8731a092022-05-24 17:24:54 +02001271 "corstone310": config_corstone310,
Gergely Korcsákba0c5212024-04-03 18:21:49 +02001272 "corstone315": config_corstone315,
Jamie Fox5ae6fa42024-02-19 15:11:00 +00001273 "rse": config_rse,
Joel Goddard2dd81a12024-01-23 15:10:08 +00001274 "rse_rdfremont": config_rse_rdfremont,
Xinyu Zhang0aebb3d2022-04-11 18:27:12 +08001275 "cypress_psoc64": config_psoc64,
Antonio de Angelis92ad2442023-08-07 15:00:32 +02001276 "corstone1000": config_corstone1000,
Anton Komlev55c3c022024-03-05 16:24:17 +01001277 "stm_stm32l562e_dk": config_stm32l562e_dk,
Xinyu Zhang0aebb3d2022-04-11 18:27:12 +08001278 "stm_b_u585i_iot02a": config_b_u585i_iot02a,
Anton Komlev4164ab62024-02-23 10:59:56 +01001279 "stm_stm32h573i_dk": config_stm32h573i_dk,
Xinyu Zhang0aebb3d2022-04-11 18:27:12 +08001280 "stm_nucleo_l552ze_q": config_nucleo_l552ze_q,
1281 "nxp_lpcxpresso55s69": config_lpcxpresso55s69,
Xinyu Zhang38b76742021-11-11 13:57:56 +08001282 "laird_bl5340": config_bl5340,
1283 "nordic_nrf5340dk": config_nrf5340dk,
1284 "nordic_nrf9160dk": config_nrf9160dk,
1285 "nuvoton_m2351": config_m2351,
1286 "nuvoton_m2354": config_m2354,
Xinyu Zhang38b76742021-11-11 13:57:56 +08001287
Bence Balogh79fda442022-10-14 18:01:37 +02001288 # config groups for tf-m-extras examples
1289 "example_vad": config_example_vad,
1290 "example_dma350_trigger": config_example_dma350_trigger,
Bence Balogh852f8bd2023-08-07 14:46:54 +02001291 "example_dma350_clcd": config_example_dma350_clcd,
Bence Balogh79fda442022-10-14 18:01:37 +02001292 "example_dma350_s": config_example_dma350_s,
Bence Baloghd23cbda2023-08-07 15:30:58 +02001293 "example_dma350_ns": config_example_dma350_ns,
Bence Balogh79fda442022-10-14 18:01:37 +02001294
Jianliang Shen48704152023-10-17 17:06:00 +08001295 # config groups for tf-m performance monitor
1296 "mem_footprint": config_mem_footprint,
Jianliang Shen5492f752023-07-27 15:59:01 +08001297 "profiling": config_prof,
1298
Xinyu Zhang0aebb3d2022-04-11 18:27:12 +08001299 # config groups for debug
Dean Birch4c6ad622020-03-13 11:28:03 +00001300 "debug": config_debug,
Paul Sokolovsky6c3c6562022-04-04 23:23:02 +03001301 "debug_regr": config_debug_regr,
Paul Sokolovsky1ec752b2022-01-22 19:50:58 +03001302 "debug_PSA_API": config_debug_PSA_API,
Xinyu Zhang0aebb3d2022-04-11 18:27:12 +08001303 }
Minos Galanakisf4ca6ac2017-12-11 02:39:21 +01001304
1305if __name__ == '__main__':
1306 import os
Minos Galanakisf4ca6ac2017-12-11 02:39:21 +01001307
Minos Galanakisea421232019-06-20 17:11:28 +01001308 # Default behavior is to export refference config when called
1309 _dir = os.getcwd()
1310 from utils import save_json
1311 for _cname, _cfg in _builtin_configs.items():
1312 _fname = os.path.join(_dir, _cname + ".json")
1313 print("Exporting config %s" % _fname)
1314 save_json(_fname, _cfg)