mirror of
https://github.com/ARM-software/arm-trusted-firmware.git
synced 2025-04-15 09:04:17 +00:00

The commit
1922875233
("fix(spm-mm): carve out NS buffer TZC400 region")
removes overlaps of ns shared buffer in secure memory region.
Unfortunately, this separation increases 1 region and over maximum
number of TZC programmable regions when they include
extended memory map regions (DRAM3 to DRAM6).
This causes boot failure of StandaloneMm with spmc_el3 && sp_el0 with
ASSERT: drivers/arm/tzc/tzc400.c:256.
To fix this, like SPM_MM, exclude setting extended memory map regions when
it uses SPMC_AT_EL3 && SPC_AT_EL3_SEL0_SP.
Signed-off-by: Levi Yun <yeoreum.yun@arm.com>
Change-Id: I2d40bea066ca030050dfe951218cd17171010676
42 lines
1.3 KiB
C
42 lines
1.3 KiB
C
/*
|
|
* Copyright (c) 2014-2022, Arm Limited and Contributors. All rights reserved.
|
|
*
|
|
* SPDX-License-Identifier: BSD-3-Clause
|
|
*/
|
|
|
|
#include <plat/arm/common/arm_config.h>
|
|
#include <plat/arm/common/plat_arm.h>
|
|
#include <platform_def.h>
|
|
|
|
/*
|
|
* We assume that all security programming is done by the primary core.
|
|
*/
|
|
void plat_arm_security_setup(void)
|
|
{
|
|
/*
|
|
* The Base FVP has a TrustZone address space controller, the Foundation
|
|
* FVP does not. Trying to program the device on the foundation FVP will
|
|
* cause an abort.
|
|
*
|
|
* If the platform had additional peripheral specific security
|
|
* configurations, those would be configured here.
|
|
*/
|
|
|
|
const arm_tzc_regions_info_t fvp_tzc_regions[] = {
|
|
ARM_TZC_REGIONS_DEF,
|
|
#if !SPM_MM && !ENABLE_RME && !(SPMC_AT_EL3 && SPMC_AT_EL3_SEL0_SP)
|
|
{FVP_DRAM3_BASE, FVP_DRAM3_END,
|
|
ARM_TZC_NS_DRAM_S_ACCESS, PLAT_ARM_TZC_NS_DEV_ACCESS},
|
|
{FVP_DRAM4_BASE, FVP_DRAM4_END,
|
|
ARM_TZC_NS_DRAM_S_ACCESS, PLAT_ARM_TZC_NS_DEV_ACCESS},
|
|
{FVP_DRAM5_BASE, FVP_DRAM5_END,
|
|
ARM_TZC_NS_DRAM_S_ACCESS, PLAT_ARM_TZC_NS_DEV_ACCESS},
|
|
{FVP_DRAM6_BASE, FVP_DRAM6_END,
|
|
ARM_TZC_NS_DRAM_S_ACCESS, PLAT_ARM_TZC_NS_DEV_ACCESS},
|
|
#endif
|
|
{0}
|
|
};
|
|
|
|
if ((get_arm_config()->flags & ARM_CONFIG_HAS_TZC) != 0U)
|
|
arm_tzc400_setup(PLAT_ARM_TZC_BASE, fvp_tzc_regions);
|
|
}
|