Ken Liu | 5885250 | 2021-08-10 15:48:23 +0800 | [diff] [blame] | 1 | /* |
Kevin Peng | 1de1e7a | 2022-06-07 17:38:01 +0800 | [diff] [blame] | 2 | * Copyright (c) 2021-2022, Arm Limited. All rights reserved. |
Ken Liu | 5885250 | 2021-08-10 15:48:23 +0800 | [diff] [blame] | 3 | * |
| 4 | * SPDX-License-Identifier: BSD-3-Clause |
| 5 | * |
| 6 | */ |
| 7 | |
| 8 | #ifndef __SECURITY_DEFS_H__ |
| 9 | #define __SECURITY_DEFS_H__ |
| 10 | |
| 11 | /* Generic security-related definitions */ |
| 12 | |
| 13 | /* |
| 14 | * Stack SEAL is involved since Security Extension exists, it becomes |
| 15 | * a generic security defs used by both SPM and Partitions. |
| 16 | */ |
| 17 | #define STACK_SEAL_PATTERN 0xFEF5EDA5 |
| 18 | |
Ken Liu | 3a80caf | 2022-06-17 14:58:01 +0800 | [diff] [blame] | 19 | #if (defined(__ARM_FEATURE_CMSE) && (__ARM_FEATURE_CMSE == 3)) |
| 20 | |
Kevin Peng | 1de1e7a | 2022-06-07 17:38:01 +0800 | [diff] [blame] | 21 | /* Attributes for psa api secure gateway functions */ |
| 22 | #if defined(__GNUC__) && !defined(__ARMCC_VERSION) |
| 23 | /* |
| 24 | * GNUARM requires noclone attribute to protect gateway function symbol from |
| 25 | * being renamed and cloned |
| 26 | */ |
| 27 | #define __tz_c_veneer \ |
chesun01 | 7e757b0 | 2023-11-07 14:12:40 +0800 | [diff] [blame^] | 28 | __attribute__((cmse_nonsecure_entry, noclone)) |
Kevin Peng | 1de1e7a | 2022-06-07 17:38:01 +0800 | [diff] [blame] | 29 | #define __tz_naked_veneer \ |
chesun01 | 7e757b0 | 2023-11-07 14:12:40 +0800 | [diff] [blame^] | 30 | __attribute__((cmse_nonsecure_entry, noclone, naked)) |
Ken Liu | 3a80caf | 2022-06-17 14:58:01 +0800 | [diff] [blame] | 31 | |
Kevin Peng | 1de1e7a | 2022-06-07 17:38:01 +0800 | [diff] [blame] | 32 | #else /* __GNUC__ && !__ARMCC_VERSION */ |
Ken Liu | 3a80caf | 2022-06-17 14:58:01 +0800 | [diff] [blame] | 33 | |
Kevin Peng | 1de1e7a | 2022-06-07 17:38:01 +0800 | [diff] [blame] | 34 | #define __tz_c_veneer \ |
chesun01 | 7e757b0 | 2023-11-07 14:12:40 +0800 | [diff] [blame^] | 35 | __attribute__((cmse_nonsecure_entry)) |
Kevin Peng | 1de1e7a | 2022-06-07 17:38:01 +0800 | [diff] [blame] | 36 | #define __tz_naked_veneer \ |
chesun01 | 7e757b0 | 2023-11-07 14:12:40 +0800 | [diff] [blame^] | 37 | __attribute__((cmse_nonsecure_entry, naked)) |
Ken Liu | 3a80caf | 2022-06-17 14:58:01 +0800 | [diff] [blame] | 38 | |
Kevin Peng | 1de1e7a | 2022-06-07 17:38:01 +0800 | [diff] [blame] | 39 | #endif /* __GNUC__ && !__ARMCC_VERSION */ |
| 40 | |
Ken Liu | 3a80caf | 2022-06-17 14:58:01 +0800 | [diff] [blame] | 41 | #endif /* __ARM_FEATURE_CMSE */ |
| 42 | |
Ken Liu | 5885250 | 2021-08-10 15:48:23 +0800 | [diff] [blame] | 43 | #endif /* __SECURITY_DEFS_H__ */ |