Miklos Balint | bf25a40 | 2018-06-14 17:43:54 +0200 | [diff] [blame] | 1 | /* |
Mate Toth-Pal | 2a6f8c2 | 2018-12-13 16:37:17 +0100 | [diff] [blame] | 2 | * Copyright (c) 2018-2019, Arm Limited. All rights reserved. |
Miklos Balint | bf25a40 | 2018-06-14 17:43:54 +0200 | [diff] [blame] | 3 | * |
| 4 | * SPDX-License-Identifier: BSD-3-Clause |
| 5 | * |
| 6 | */ |
| 7 | |
Mate Toth-Pal | 36f2184 | 2018-11-08 16:12:51 +0100 | [diff] [blame] | 8 | {{utilities.donotedit_warning}} |
Miklos Balint | bf25a40 | 2018-06-14 17:43:54 +0200 | [diff] [blame] | 9 | |
| 10 | #include "tfm_secure_api.h" |
Miklos Balint | bf25a40 | 2018-06-14 17:43:54 +0200 | [diff] [blame] | 11 | #include "secure_fw/spm/spm_partition_defs.h" |
| 12 | |
Mate Toth-Pal | 36f2184 | 2018-11-08 16:12:51 +0100 | [diff] [blame] | 13 | {% for manifest in manifests %} |
| 14 | {% if manifest.attr.conditional %} |
| 15 | #ifdef {{manifest.attr.conditional}} |
| 16 | {% endif %} |
| 17 | /******** {{manifest.manifest.name}} ********/ |
| 18 | {% for sec_func in manifest.manifest.secure_functions %} |
Antonio de Angelis | 09586c5 | 2019-03-27 16:35:31 +0000 | [diff] [blame] | 19 | psa_status_t {{sec_func.tfm_symbol}}(psa_invec *, size_t, psa_outvec *, size_t); |
Mate Toth-Pal | 36f2184 | 2018-11-08 16:12:51 +0100 | [diff] [blame] | 20 | {% endfor %} |
| 21 | {% if manifest.attr.conditional %} |
| 22 | #endif /* {{manifest.attr.conditional}} */ |
| 23 | {% endif %} |
Miklos Balint | bf25a40 | 2018-06-14 17:43:54 +0200 | [diff] [blame] | 24 | |
Mate Toth-Pal | 36f2184 | 2018-11-08 16:12:51 +0100 | [diff] [blame] | 25 | {% endfor %} |
Miklos Balint | bf25a40 | 2018-06-14 17:43:54 +0200 | [diff] [blame] | 26 | |
| 27 | #define TFM_VENEER_FUNCTION(partition_name, sfn_name) \ |
| 28 | __tfm_secure_gateway_attributes__ \ |
Antonio de Angelis | 09586c5 | 2019-03-27 16:35:31 +0000 | [diff] [blame] | 29 | psa_status_t tfm_##sfn_name##_veneer(psa_invec *in_vec, \ |
Mate Toth-Pal | 2a6f8c2 | 2018-12-13 16:37:17 +0100 | [diff] [blame] | 30 | size_t in_len, \ |
Antonio de Angelis | 09586c5 | 2019-03-27 16:35:31 +0000 | [diff] [blame] | 31 | psa_outvec *out_vec, \ |
Mate Toth-Pal | 2a6f8c2 | 2018-12-13 16:37:17 +0100 | [diff] [blame] | 32 | size_t out_len) \ |
Miklos Balint | bf25a40 | 2018-06-14 17:43:54 +0200 | [diff] [blame] | 33 | { \ |
Mate Toth-Pal | b8ce0dd | 2018-07-25 10:18:34 +0200 | [diff] [blame] | 34 | TFM_CORE_IOVEC_SFN_REQUEST(partition_name##_ID, \ |
TTornblom | c640e07 | 2019-06-14 14:33:51 +0200 | [diff] [blame] | 35 | (void *) sfn_name, \ |
Mate Toth-Pal | b8ce0dd | 2018-07-25 10:18:34 +0200 | [diff] [blame] | 36 | in_vec, in_len, out_vec, out_len); \ |
Miklos Balint | bf25a40 | 2018-06-14 17:43:54 +0200 | [diff] [blame] | 37 | } |
| 38 | |
Mate Toth-Pal | 36f2184 | 2018-11-08 16:12:51 +0100 | [diff] [blame] | 39 | {% for manifest in manifests %} |
| 40 | {% if manifest.attr.conditional %} |
| 41 | #ifdef {{manifest.attr.conditional}} |
| 42 | {% endif %} |
| 43 | /******** {{manifest.manifest.name}} ********/ |
| 44 | {% for sec_func in manifest.manifest.secure_functions %} |
| 45 | TFM_VENEER_FUNCTION({{manifest.manifest.name}}, {{sec_func.tfm_symbol}}) |
| 46 | {% endfor %} |
| 47 | {% if manifest.attr.conditional %} |
| 48 | #endif /* {{manifest.attr.conditional}} */ |
| 49 | {% endif %} |
Miklos Balint | bf25a40 | 2018-06-14 17:43:54 +0200 | [diff] [blame] | 50 | |
Mate Toth-Pal | 36f2184 | 2018-11-08 16:12:51 +0100 | [diff] [blame] | 51 | {% endfor %} |