Raef Coles | 958aeef | 2020-10-08 12:12:58 +0100 | [diff] [blame] | 1 | #------------------------------------------------------------------------------- |
| 2 | # Copyright (c) 2020, Arm Limited. All rights reserved. |
| 3 | # |
| 4 | # SPDX-License-Identifier: BSD-3-Clause |
| 5 | # |
| 6 | #------------------------------------------------------------------------------- |
| 7 | |
| 8 | function(tfm_invalid_config) |
| 9 | if (${ARGV}) |
| 10 | string (REPLACE ";" " " ARGV_STRING "${ARGV}") |
| 11 | string (REPLACE "STREQUAL" "=" ARGV_STRING "${ARGV_STRING}") |
| 12 | string (REPLACE "GREATER" ">" ARGV_STRING "${ARGV_STRING}") |
| 13 | string (REPLACE "LESS" "<" ARGV_STRING "${ARGV_STRING}") |
| 14 | string (REPLACE "EQUAL" "=" ARGV_STRING "${ARGV_STRING}") |
Mingyang Sun | c9d2471 | 2020-10-23 15:06:34 +0800 | [diff] [blame^] | 15 | string (REPLACE "IN_LIST" "in" ARGV_STRING "${ARGV_STRING}") |
Raef Coles | 958aeef | 2020-10-08 12:12:58 +0100 | [diff] [blame] | 16 | |
| 17 | message(FATAL_ERROR "INVALID CONFIG: ${ARGV_STRING}") |
| 18 | endif() |
| 19 | endfunction() |
| 20 | |
Mingyang Sun | c9d2471 | 2020-10-23 15:06:34 +0800 | [diff] [blame^] | 21 | set (TFM_L3_PLATFORM_LISTS mps2/an521 musca_b1) |
| 22 | |
| 23 | tfm_invalid_config(TFM_ISOLATION_LEVEL LESS 1 OR TFM_ISOLATION_LEVEL GREATER 3) |
| 24 | tfm_invalid_config(TFM_ISOLATION_LEVEL EQUAL 3 AND NOT TFM_PLATFORM IN_LIST TFM_L3_PLATFORM_LISTS) |
Raef Coles | 958aeef | 2020-10-08 12:12:58 +0100 | [diff] [blame] | 25 | tfm_invalid_config(TFM_ISOLATION_LEVEL GREATER 1 AND NOT TFM_PSA_API) |
| 26 | |
| 27 | tfm_invalid_config(TFM_MULTI_CORE_TOPOLOGY AND NOT TFM_PSA_API) |
| 28 | tfm_invalid_config(TFM_MULTI_CORE_MULTI_CLIENT_CALL AND NOT TFM_MULTI_CORE_TOPOLOGY) |
| 29 | |
| 30 | tfm_invalid_config(TEST_S AND TEST_PSA_API) |
| 31 | tfm_invalid_config(TEST_NS AND TEST_PSA_API) |
| 32 | |
| 33 | tfm_invalid_config((TFM_PARTITION_PROTECTED_STORAGE AND PS_ROLLBACK_PROTECTION) AND NOT TFM_PARTITION_PLATFORM) |
| 34 | |
| 35 | tfm_invalid_config(TEST_PSA_API STREQUAL "IPC" AND NOT TFM_PSA_API) |
| 36 | tfm_invalid_config(TEST_PSA_API STREQUAL "CRYPTO" AND NOT TFM_PARTITION_CRYPTO) |
| 37 | tfm_invalid_config(TEST_PSA_API STREQUAL "INITIAL_ATTESTATION" AND NOT TFM_PARTITION_INITIAL_ATTESTATION) |
| 38 | tfm_invalid_config(TEST_PSA_API STREQUAL "INTERNAL_TRUSTED_STORAGE" AND NOT TFM_PARTITION_INTERNAL_TRUSTED_STORAGE) |
| 39 | tfm_invalid_config(TEST_PSA_API STREQUAL "PROTECTED_STORAGE" AND NOT TFM_PARTITION_PROTECTED_STORAGE) |
| 40 | tfm_invalid_config(TEST_PSA_API STREQUAL "STORAGE" AND NOT TFM_PARTITION_INTERNAL_TRUSTED_STORAGE) |
| 41 | tfm_invalid_config(TEST_PSA_API STREQUAL "STORAGE" AND NOT TFM_PARTITION_PROTECTED_STORAGE) |
| 42 | |
| 43 | tfm_invalid_config(CRYPTO_HW_ACCELERATOR_OTP_STATE AND NOT CRYPTO_HW_ACCELERATOR) |
| 44 | tfm_invalid_config(CRYPTO_HW_ACCELERATOR_OTP_STATE AND NOT (CRYPTO_HW_ACCELERATOR_OTP_STATE STREQUAL "ENABLED" OR CRYPTO_HW_ACCELERATOR_OTP_STATE STREQUAL "PROVISIONING")) |