blob: 3cdc0d329db278344cd5b1f93fc389320c587afe [file] [log] [blame]
Aditya Angadid61740b2020-11-19 18:05:33 +05301/*
Rohit Mathew20d4a212024-02-03 21:20:17 +00002 * Copyright (c) 2020-2024, Arm Limited and Contributors. All rights reserved.
Aditya Angadid61740b2020-11-19 18:05:33 +05303 *
4 * SPDX-License-Identifier: BSD-3-Clause
5 */
6
Aditya Angadiccae8a12021-08-09 09:38:58 +05307#include <common/debug.h>
Aditya Angadid61740b2020-11-19 18:05:33 +05308#include <plat/arm/common/plat_arm.h>
9#include <platform_def.h>
10
Omkar Anand Kulkarni1f425992023-06-22 15:18:07 +053011#define RDN2_TZC_CPER_REGION \
12 {CSS_SGI_SP_CPER_BUF_BASE, (CSS_SGI_SP_CPER_BUF_BASE + \
13 CSS_SGI_SP_CPER_BUF_SIZE) - 1, TZC_REGION_S_NONE, \
14 PLAT_ARM_TZC_NS_DEV_ACCESS}
15
Aditya Angadid61740b2020-11-19 18:05:33 +053016static const arm_tzc_regions_info_t tzc_regions[] = {
17 ARM_TZC_REGIONS_DEF,
Manish Pandeyf90a73c2023-10-10 15:42:19 +010018#if ENABLE_FEAT_RAS && FFH_SUPPORT
Omkar Anand Kulkarni1f425992023-06-22 15:18:07 +053019 RDN2_TZC_CPER_REGION,
20#endif
Aditya Angadid61740b2020-11-19 18:05:33 +053021 {}
22};
Aditya Angadiccae8a12021-08-09 09:38:58 +053023
Rohit Mathew644d9e22024-02-03 19:06:16 +000024#if (NRD_PLATFORM_VARIANT == 2 && NRD_CHIP_COUNT > 1)
25static const arm_tzc_regions_info_t tzc_regions_mc[][NRD_CHIP_COUNT - 1] = {
Aditya Angadiccae8a12021-08-09 09:38:58 +053026 {
27 /* TZC memory regions for second chip */
28 SGI_PLAT_TZC_NS_REMOTE_REGIONS_DEF(1),
29 {}
30 },
Rohit Mathew644d9e22024-02-03 19:06:16 +000031#if NRD_CHIP_COUNT > 2
Aditya Angadiccae8a12021-08-09 09:38:58 +053032 {
33 /* TZC memory regions for third chip */
34 SGI_PLAT_TZC_NS_REMOTE_REGIONS_DEF(2),
35 {}
36 },
37#endif
Rohit Mathew644d9e22024-02-03 19:06:16 +000038#if NRD_CHIP_COUNT > 3
Aditya Angadiccae8a12021-08-09 09:38:58 +053039 {
40 /* TZC memory regions for fourth chip */
41 SGI_PLAT_TZC_NS_REMOTE_REGIONS_DEF(3),
42 {}
43 },
44#endif
45};
Rohit Mathew644d9e22024-02-03 19:06:16 +000046#endif /* NRD_PLATFORM_VARIANT && NRD_CHIP_COUNT */
Aditya Angadid61740b2020-11-19 18:05:33 +053047
48/* Initialize the secure environment */
49void plat_arm_security_setup(void)
50{
Aditya Angadiccae8a12021-08-09 09:38:58 +053051 unsigned int i;
Aditya Angadid61740b2020-11-19 18:05:33 +053052
Aditya Angadiccae8a12021-08-09 09:38:58 +053053 INFO("Configuring TrustZone Controller for Chip 0\n");
Aditya Angadid61740b2020-11-19 18:05:33 +053054
Aditya Angadiccae8a12021-08-09 09:38:58 +053055 for (i = 0; i < TZC400_COUNT; i++) {
Aditya Angadid61740b2020-11-19 18:05:33 +053056 arm_tzc400_setup(TZC400_BASE(i), tzc_regions);
Aditya Angadiccae8a12021-08-09 09:38:58 +053057 }
58
Rohit Mathew644d9e22024-02-03 19:06:16 +000059#if (NRD_PLATFORM_VARIANT == 2 && NRD_CHIP_COUNT > 1)
Aditya Angadiccae8a12021-08-09 09:38:58 +053060 unsigned int j;
61
Rohit Mathew644d9e22024-02-03 19:06:16 +000062 for (i = 1; i < NRD_CHIP_COUNT; i++) {
Aditya Angadiccae8a12021-08-09 09:38:58 +053063 INFO("Configuring TrustZone Controller for Chip %u\n", i);
Aditya Angadid61740b2020-11-19 18:05:33 +053064
Aditya Angadiccae8a12021-08-09 09:38:58 +053065 for (j = 0; j < TZC400_COUNT; j++) {
66 arm_tzc400_setup(CSS_SGI_REMOTE_CHIP_MEM_OFFSET(i)
67 + TZC400_BASE(j), tzc_regions_mc[i-1]);
68 }
69 }
70#endif
Aditya Angadid61740b2020-11-19 18:05:33 +053071}