1dddba19aSStephan Gerhold /*
2d833af3aSStephan Gerhold * Copyright (c) 2021-2023, Stephan Gerhold <stephan@gerhold.net>
3dddba19aSStephan Gerhold *
4dddba19aSStephan Gerhold * SPDX-License-Identifier: BSD-3-Clause
5dddba19aSStephan Gerhold */
6dddba19aSStephan Gerhold
7dddba19aSStephan Gerhold #include <assert.h>
8dddba19aSStephan Gerhold
9dddba19aSStephan Gerhold #include <arch.h>
10dddba19aSStephan Gerhold #include <common/debug.h>
11dddba19aSStephan Gerhold #include <plat/common/platform.h>
12dddba19aSStephan Gerhold
13840831b2SStephan Gerhold #include "msm8916_config.h"
14840831b2SStephan Gerhold #include "msm8916_setup.h"
15dddba19aSStephan Gerhold
16dddba19aSStephan Gerhold static struct {
17dddba19aSStephan Gerhold entry_point_info_t bl32;
18dddba19aSStephan Gerhold entry_point_info_t bl33;
19dddba19aSStephan Gerhold } image_ep_info = {
20dddba19aSStephan Gerhold /* BL32 entry point */
21dddba19aSStephan Gerhold SET_STATIC_PARAM_HEAD(bl32, PARAM_EP, VERSION_1,
22dddba19aSStephan Gerhold entry_point_info_t, SECURE),
23dddba19aSStephan Gerhold .bl32.pc = BL32_BASE,
24dddba19aSStephan Gerhold
25dddba19aSStephan Gerhold /* BL33 entry point */
26dddba19aSStephan Gerhold SET_STATIC_PARAM_HEAD(bl33, PARAM_EP, VERSION_1,
27dddba19aSStephan Gerhold entry_point_info_t, NON_SECURE),
28dddba19aSStephan Gerhold .bl33.pc = PRELOADED_BL33_BASE,
29dddba19aSStephan Gerhold .bl33.spsr = SPSR_64(MODE_EL2, MODE_SP_ELX, DISABLE_ALL_EXCEPTIONS),
30dddba19aSStephan Gerhold };
31dddba19aSStephan Gerhold
bl31_early_platform_setup2(u_register_t arg0,u_register_t arg1,u_register_t arg2,u_register_t arg3)32dddba19aSStephan Gerhold void bl31_early_platform_setup2(u_register_t arg0, u_register_t arg1,
33dddba19aSStephan Gerhold u_register_t arg2, u_register_t arg3)
34dddba19aSStephan Gerhold {
35840831b2SStephan Gerhold msm8916_early_platform_setup();
36*1240dc7eSStephan Gerhold msm8916_configure_early();
37dddba19aSStephan Gerhold }
38dddba19aSStephan Gerhold
bl31_plat_arch_setup(void)39dddba19aSStephan Gerhold void bl31_plat_arch_setup(void)
40dddba19aSStephan Gerhold {
41840831b2SStephan Gerhold msm8916_plat_arch_setup(BL31_BASE, BL31_END - BL31_BASE);
42dddba19aSStephan Gerhold enable_mmu_el3(0);
43dddba19aSStephan Gerhold }
44dddba19aSStephan Gerhold
bl31_platform_setup(void)45dddba19aSStephan Gerhold void bl31_platform_setup(void)
46dddba19aSStephan Gerhold {
47af644731SStephan Gerhold INFO("BL31: Platform setup start\n");
48840831b2SStephan Gerhold msm8916_platform_setup();
49840831b2SStephan Gerhold msm8916_configure();
50af644731SStephan Gerhold INFO("BL31: Platform setup done\n");
51dddba19aSStephan Gerhold }
52dddba19aSStephan Gerhold
bl31_plat_get_next_image_ep_info(uint32_t type)53dddba19aSStephan Gerhold entry_point_info_t *bl31_plat_get_next_image_ep_info(uint32_t type)
54dddba19aSStephan Gerhold {
55dddba19aSStephan Gerhold switch (type) {
56dddba19aSStephan Gerhold case SECURE:
57dddba19aSStephan Gerhold return &image_ep_info.bl32;
58dddba19aSStephan Gerhold case NON_SECURE:
59dddba19aSStephan Gerhold return &image_ep_info.bl33;
60dddba19aSStephan Gerhold default:
61dddba19aSStephan Gerhold assert(sec_state_is_valid(type));
62dddba19aSStephan Gerhold return NULL;
63dddba19aSStephan Gerhold }
64dddba19aSStephan Gerhold }
65