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" |
| 11 | #include "tfm_api.h" |
| 12 | #include "secure_fw/spm/spm_partition_defs.h" |
| 13 | |
Mate Toth-Pal | 36f2184 | 2018-11-08 16:12:51 +0100 | [diff] [blame^] | 14 | {% for manifest in manifests %} |
| 15 | {% if manifest.attr.conditional %} |
| 16 | #ifdef {{manifest.attr.conditional}} |
| 17 | {% endif %} |
| 18 | /******** {{manifest.manifest.name}} ********/ |
| 19 | {% for sec_func in manifest.manifest.secure_functions %} |
| 20 | psa_status_t {{sec_func.tfm_symbol}}(struct psa_invec *, size_t, struct psa_outvec *, size_t); |
| 21 | {% endfor %} |
| 22 | {% if manifest.attr.conditional %} |
| 23 | #endif /* {{manifest.attr.conditional}} */ |
| 24 | {% endif %} |
Miklos Balint | bf25a40 | 2018-06-14 17:43:54 +0200 | [diff] [blame] | 25 | |
Mate Toth-Pal | 36f2184 | 2018-11-08 16:12:51 +0100 | [diff] [blame^] | 26 | {% endfor %} |
Miklos Balint | bf25a40 | 2018-06-14 17:43:54 +0200 | [diff] [blame] | 27 | |
| 28 | #define TFM_VENEER_FUNCTION(partition_name, sfn_name) \ |
| 29 | __tfm_secure_gateway_attributes__ \ |
Mate Toth-Pal | 2a6f8c2 | 2018-12-13 16:37:17 +0100 | [diff] [blame] | 30 | psa_status_t tfm_##sfn_name##_veneer(struct psa_invec *in_vec, \ |
| 31 | size_t in_len, \ |
| 32 | struct psa_outvec *out_vec, \ |
| 33 | size_t out_len) \ |
Miklos Balint | bf25a40 | 2018-06-14 17:43:54 +0200 | [diff] [blame] | 34 | { \ |
Mate Toth-Pal | b8ce0dd | 2018-07-25 10:18:34 +0200 | [diff] [blame] | 35 | TFM_CORE_IOVEC_SFN_REQUEST(partition_name##_ID, \ |
| 36 | sfn_name, \ |
| 37 | in_vec, in_len, out_vec, out_len); \ |
Miklos Balint | bf25a40 | 2018-06-14 17:43:54 +0200 | [diff] [blame] | 38 | } |
| 39 | |
Mate Toth-Pal | 36f2184 | 2018-11-08 16:12:51 +0100 | [diff] [blame^] | 40 | {% for manifest in manifests %} |
| 41 | {% if manifest.attr.conditional %} |
| 42 | #ifdef {{manifest.attr.conditional}} |
| 43 | {% endif %} |
| 44 | /******** {{manifest.manifest.name}} ********/ |
| 45 | {% for sec_func in manifest.manifest.secure_functions %} |
| 46 | TFM_VENEER_FUNCTION({{manifest.manifest.name}}, {{sec_func.tfm_symbol}}) |
| 47 | {% endfor %} |
| 48 | {% if manifest.attr.conditional %} |
| 49 | #endif /* {{manifest.attr.conditional}} */ |
| 50 | {% endif %} |
Miklos Balint | bf25a40 | 2018-06-14 17:43:54 +0200 | [diff] [blame] | 51 | |
Mate Toth-Pal | 36f2184 | 2018-11-08 16:12:51 +0100 | [diff] [blame^] | 52 | {% endfor %} |