xref: /rk3399_ARM-atf/plat/qti/msm8916/sp_min/msm8916_sp_min_setup.c (revision d1b5ada8887c767c39eceaf816eefbf303e0dcd8)
145b2bd0aSStephan Gerhold /*
245b2bd0aSStephan Gerhold  * Copyright (c) 2022-2023, Stephan Gerhold <stephan@gerhold.net>
345b2bd0aSStephan Gerhold  *
445b2bd0aSStephan Gerhold  * SPDX-License-Identifier: BSD-3-Clause
545b2bd0aSStephan Gerhold  */
645b2bd0aSStephan Gerhold 
745b2bd0aSStephan Gerhold #include <arch.h>
845b2bd0aSStephan Gerhold #include <common/debug.h>
945b2bd0aSStephan Gerhold #include <lib/xlat_tables/xlat_mmu_helpers.h>
1045b2bd0aSStephan Gerhold #include <platform_sp_min.h>
1145b2bd0aSStephan Gerhold 
1245b2bd0aSStephan Gerhold #include "../msm8916_config.h"
1345b2bd0aSStephan Gerhold #include "../msm8916_setup.h"
1445b2bd0aSStephan Gerhold 
1545b2bd0aSStephan Gerhold static struct {
1645b2bd0aSStephan Gerhold 	entry_point_info_t bl33;
1745b2bd0aSStephan Gerhold } image_ep_info = {
1845b2bd0aSStephan Gerhold 	/* BL33 entry point */
1945b2bd0aSStephan Gerhold 	SET_STATIC_PARAM_HEAD(bl33, PARAM_EP, VERSION_1,
2045b2bd0aSStephan Gerhold 			      entry_point_info_t, NON_SECURE),
2145b2bd0aSStephan Gerhold 	.bl33.pc = PRELOADED_BL33_BASE,
2245b2bd0aSStephan Gerhold 	.bl33.spsr = SPSR_MODE32(MODE32_hyp, SPSR_T_ARM, SPSR_E_LITTLE,
2345b2bd0aSStephan Gerhold 				 DISABLE_ALL_EXCEPTIONS),
2445b2bd0aSStephan Gerhold };
2545b2bd0aSStephan Gerhold 
sp_min_early_platform_setup2(u_register_t arg0,u_register_t arg1,u_register_t arg2,u_register_t arg3)2645b2bd0aSStephan Gerhold void sp_min_early_platform_setup2(u_register_t arg0, u_register_t arg1,
2745b2bd0aSStephan Gerhold 				  u_register_t arg2, u_register_t arg3)
2845b2bd0aSStephan Gerhold {
2945b2bd0aSStephan Gerhold 	msm8916_early_platform_setup();
30*1240dc7eSStephan Gerhold 	msm8916_configure_early();
3145b2bd0aSStephan Gerhold }
3245b2bd0aSStephan Gerhold 
sp_min_plat_arch_setup(void)3345b2bd0aSStephan Gerhold void sp_min_plat_arch_setup(void)
3445b2bd0aSStephan Gerhold {
3545b2bd0aSStephan Gerhold 	msm8916_plat_arch_setup(BL32_BASE, BL32_END - BL32_BASE);
3645b2bd0aSStephan Gerhold 	enable_mmu_svc_mon(0);
3745b2bd0aSStephan Gerhold }
3845b2bd0aSStephan Gerhold 
sp_min_platform_setup(void)3945b2bd0aSStephan Gerhold void sp_min_platform_setup(void)
4045b2bd0aSStephan Gerhold {
4145b2bd0aSStephan Gerhold 	INFO("SP_MIN: Platform setup start\n");
4245b2bd0aSStephan Gerhold 	msm8916_platform_setup();
4345b2bd0aSStephan Gerhold 	msm8916_configure();
4445b2bd0aSStephan Gerhold 	INFO("SP_MIN: Platform setup done\n");
4545b2bd0aSStephan Gerhold }
4645b2bd0aSStephan Gerhold 
sp_min_plat_get_bl33_ep_info(void)4745b2bd0aSStephan Gerhold entry_point_info_t *sp_min_plat_get_bl33_ep_info(void)
4845b2bd0aSStephan Gerhold {
4945b2bd0aSStephan Gerhold 	return &image_ep_info.bl33;
5045b2bd0aSStephan Gerhold }
51