mirror of
https://github.com/ARM-software/arm-trusted-firmware.git
synced 2025-04-26 14:55:16 +00:00
Remove sp_min functions from plat_common.c
This patch removes default platform implementations of sp_min platform APIs from plat/common/aarch32/plat_common.c. The APIs are now implemented in `plat_sp_min_common.c` file within the same folder. The ARM platform layer had a weak definition of sp_min_platform_setup2() which conflicted with the weak definition in the common file. Hence this patch fixes that by introducing a `plat_arm_` version of the API thus allowing individual boards within ARM platforms to override it if they wish to. Fixes ARM-software/tf-issues#559 Change-Id: I11a74ecae8191878ccc7ea03f12bdd5ae88faba5 Signed-off-by: Soby Mathew <soby.mathew@arm.com>
This commit is contained in:
parent
4504ab2bc2
commit
0ed8c00174
6 changed files with 55 additions and 27 deletions
|
@ -15,6 +15,7 @@ INCLUDES += -Iinclude/bl32/sp_min
|
||||||
BL32_SOURCES += bl32/sp_min/sp_min_main.c \
|
BL32_SOURCES += bl32/sp_min/sp_min_main.c \
|
||||||
bl32/sp_min/aarch32/entrypoint.S \
|
bl32/sp_min/aarch32/entrypoint.S \
|
||||||
common/runtime_svc.c \
|
common/runtime_svc.c \
|
||||||
|
plat/common/aarch32/plat_sp_min_common.c\
|
||||||
services/std_svc/std_svc_setup.c \
|
services/std_svc/std_svc_setup.c \
|
||||||
${PSCI_LIB_SOURCES}
|
${PSCI_LIB_SOURCES}
|
||||||
|
|
||||||
|
|
|
@ -237,6 +237,10 @@ int arm_execution_state_switch(unsigned int smc_fid,
|
||||||
uint32_t cookie_lo,
|
uint32_t cookie_lo,
|
||||||
void *handle);
|
void *handle);
|
||||||
|
|
||||||
|
/* Optional functions for SP_MIN */
|
||||||
|
void plat_arm_sp_min_early_platform_setup(u_register_t arg0, u_register_t arg1,
|
||||||
|
u_register_t arg2, u_register_t arg3);
|
||||||
|
|
||||||
/* global variables */
|
/* global variables */
|
||||||
extern plat_psci_ops_t plat_arm_psci_pm_ops;
|
extern plat_psci_ops_t plat_arm_psci_pm_ops;
|
||||||
extern const mmap_region_t plat_arm_mmap[];
|
extern const mmap_region_t plat_arm_mmap[];
|
||||||
|
|
|
@ -7,7 +7,7 @@
|
||||||
#include <plat_arm.h>
|
#include <plat_arm.h>
|
||||||
#include "../fvp_private.h"
|
#include "../fvp_private.h"
|
||||||
|
|
||||||
void sp_min_early_platform_setup2(u_register_t arg0, u_register_t arg1,
|
void plat_arm_sp_min_early_platform_setup(u_register_t arg0, u_register_t arg1,
|
||||||
u_register_t arg2, u_register_t arg3)
|
u_register_t arg2, u_register_t arg3)
|
||||||
{
|
{
|
||||||
arm_sp_min_early_platform_setup((void *)arg0, arg1, arg2, (void *)arg3);
|
arm_sp_min_early_platform_setup((void *)arg0, arg1, arg2, (void *)arg3);
|
||||||
|
|
|
@ -18,9 +18,9 @@
|
||||||
static entry_point_info_t bl33_image_ep_info;
|
static entry_point_info_t bl33_image_ep_info;
|
||||||
|
|
||||||
/* Weak definitions may be overridden in specific ARM standard platform */
|
/* Weak definitions may be overridden in specific ARM standard platform */
|
||||||
#pragma weak sp_min_early_platform_setup2
|
|
||||||
#pragma weak sp_min_platform_setup
|
#pragma weak sp_min_platform_setup
|
||||||
#pragma weak sp_min_plat_arch_setup
|
#pragma weak sp_min_plat_arch_setup
|
||||||
|
#pragma weak plat_arm_sp_min_early_platform_setup
|
||||||
|
|
||||||
|
|
||||||
/*******************************************************************************
|
/*******************************************************************************
|
||||||
|
@ -46,7 +46,7 @@ entry_point_info_t *sp_min_plat_get_bl33_ep_info(void)
|
||||||
}
|
}
|
||||||
|
|
||||||
/*******************************************************************************
|
/*******************************************************************************
|
||||||
* Perform early platform setup.
|
* Utility function to perform early platform setup.
|
||||||
******************************************************************************/
|
******************************************************************************/
|
||||||
void arm_sp_min_early_platform_setup(void *from_bl2, uintptr_t tos_fw_config,
|
void arm_sp_min_early_platform_setup(void *from_bl2, uintptr_t tos_fw_config,
|
||||||
uintptr_t hw_config, void *plat_params_from_bl2)
|
uintptr_t hw_config, void *plat_params_from_bl2)
|
||||||
|
@ -105,7 +105,10 @@ void arm_sp_min_early_platform_setup(void *from_bl2, uintptr_t tos_fw_config,
|
||||||
|
|
||||||
}
|
}
|
||||||
|
|
||||||
void sp_min_early_platform_setup2(u_register_t arg0, u_register_t arg1,
|
/*******************************************************************************
|
||||||
|
* Default implementation for sp_min_platform_setup2() for ARM platforms
|
||||||
|
******************************************************************************/
|
||||||
|
void plat_arm_sp_min_early_platform_setup(u_register_t arg0, u_register_t arg1,
|
||||||
u_register_t arg2, u_register_t arg3)
|
u_register_t arg2, u_register_t arg3)
|
||||||
{
|
{
|
||||||
arm_sp_min_early_platform_setup((void *)arg0, arg1, arg2, (void *)arg3);
|
arm_sp_min_early_platform_setup((void *)arg0, arg1, arg2, (void *)arg3);
|
||||||
|
@ -127,6 +130,12 @@ void sp_min_early_platform_setup2(u_register_t arg0, u_register_t arg1,
|
||||||
plat_arm_interconnect_enter_coherency();
|
plat_arm_interconnect_enter_coherency();
|
||||||
}
|
}
|
||||||
|
|
||||||
|
void sp_min_early_platform_setup2(u_register_t arg0, u_register_t arg1,
|
||||||
|
u_register_t arg2, u_register_t arg3)
|
||||||
|
{
|
||||||
|
plat_arm_sp_min_early_platform_setup(arg0, arg1, arg2, arg3);
|
||||||
|
}
|
||||||
|
|
||||||
/*******************************************************************************
|
/*******************************************************************************
|
||||||
* Perform any SP_MIN platform runtime setup prior to SP_MIN exit.
|
* Perform any SP_MIN platform runtime setup prior to SP_MIN exit.
|
||||||
* Common to ARM standard platforms.
|
* Common to ARM standard platforms.
|
||||||
|
|
|
@ -4,9 +4,7 @@
|
||||||
* SPDX-License-Identifier: BSD-3-Clause
|
* SPDX-License-Identifier: BSD-3-Clause
|
||||||
*/
|
*/
|
||||||
|
|
||||||
#include <console.h>
|
|
||||||
#include <platform.h>
|
#include <platform.h>
|
||||||
#include <platform_sp_min.h>
|
|
||||||
#include <xlat_mmu_helpers.h>
|
#include <xlat_mmu_helpers.h>
|
||||||
|
|
||||||
/*
|
/*
|
||||||
|
@ -15,29 +13,9 @@
|
||||||
* platforms but may also be overridden by a platform if required.
|
* platforms but may also be overridden by a platform if required.
|
||||||
*/
|
*/
|
||||||
#pragma weak bl32_plat_enable_mmu
|
#pragma weak bl32_plat_enable_mmu
|
||||||
#pragma weak sp_min_plat_runtime_setup
|
|
||||||
|
|
||||||
void bl32_plat_enable_mmu(uint32_t flags)
|
void bl32_plat_enable_mmu(uint32_t flags)
|
||||||
{
|
{
|
||||||
enable_mmu_secure(flags);
|
enable_mmu_secure(flags);
|
||||||
}
|
}
|
||||||
|
|
||||||
void sp_min_plat_runtime_setup(void)
|
|
||||||
{
|
|
||||||
/*
|
|
||||||
* Finish the use of console driver in SP_MIN so that any runtime logs
|
|
||||||
* from SP_MIN will be suppressed.
|
|
||||||
*/
|
|
||||||
console_uninit();
|
|
||||||
}
|
|
||||||
|
|
||||||
#if !ERROR_DEPRECATED
|
|
||||||
|
|
||||||
#pragma weak sp_min_early_platform_setup2
|
|
||||||
|
|
||||||
void sp_min_early_platform_setup2(u_register_t arg0, u_register_t arg1,
|
|
||||||
u_register_t arg2, u_register_t arg3)
|
|
||||||
{
|
|
||||||
sp_min_early_platform_setup((void *) arg0, (void *)arg1);
|
|
||||||
}
|
|
||||||
#endif
|
|
||||||
|
|
36
plat/common/aarch32/plat_sp_min_common.c
Normal file
36
plat/common/aarch32/plat_sp_min_common.c
Normal file
|
@ -0,0 +1,36 @@
|
||||||
|
/*
|
||||||
|
* Copyright (c) 2018, ARM Limited and Contributors. All rights reserved.
|
||||||
|
*
|
||||||
|
* SPDX-License-Identifier: BSD-3-Clause
|
||||||
|
*/
|
||||||
|
|
||||||
|
#include <console.h>
|
||||||
|
#include <platform.h>
|
||||||
|
#include <platform_sp_min.h>
|
||||||
|
|
||||||
|
/*
|
||||||
|
* The following platform setup functions are weakly defined. They
|
||||||
|
* provide typical implementations that may be re-used by multiple
|
||||||
|
* platforms but may also be overridden by a platform if required.
|
||||||
|
*/
|
||||||
|
#pragma weak sp_min_plat_runtime_setup
|
||||||
|
|
||||||
|
void sp_min_plat_runtime_setup(void)
|
||||||
|
{
|
||||||
|
/*
|
||||||
|
* Finish the use of console driver in SP_MIN so that any runtime logs
|
||||||
|
* from SP_MIN will be suppressed.
|
||||||
|
*/
|
||||||
|
console_uninit();
|
||||||
|
}
|
||||||
|
|
||||||
|
#if !ERROR_DEPRECATED
|
||||||
|
|
||||||
|
#pragma weak sp_min_early_platform_setup2
|
||||||
|
|
||||||
|
void sp_min_early_platform_setup2(u_register_t arg0, u_register_t arg1,
|
||||||
|
u_register_t arg2, u_register_t arg3)
|
||||||
|
{
|
||||||
|
sp_min_early_platform_setup((void *)arg0, (void *)arg1);
|
||||||
|
}
|
||||||
|
#endif
|
Loading…
Add table
Reference in a new issue