xref: /rk3399_ARM-atf/plat/arm/css/common/css_bl2u_setup.c (revision 82cb2c1ad9897473743f08437d0a3995bed561b9)
1dcda29f6SYatharth Kochar /*
2dcda29f6SYatharth Kochar  * Copyright (c) 2015, ARM Limited and Contributors. All rights reserved.
3dcda29f6SYatharth Kochar  *
4*82cb2c1aSdp-arm  * SPDX-License-Identifier: BSD-3-Clause
5dcda29f6SYatharth Kochar  */
6dcda29f6SYatharth Kochar 
7dcda29f6SYatharth Kochar #include <bl_common.h>
8dcda29f6SYatharth Kochar #include <debug.h>
9dcda29f6SYatharth Kochar #include <plat_arm.h>
10dcda29f6SYatharth Kochar #include "css_scp_bootloader.h"
11dcda29f6SYatharth Kochar 
12dcda29f6SYatharth Kochar /* Weak definition may be overridden in specific CSS based platform */
13dcda29f6SYatharth Kochar #pragma weak bl2u_plat_handle_scp_bl2u
14dcda29f6SYatharth Kochar 
15dcda29f6SYatharth Kochar /* Data structure which holds the SCP_BL2U image info for BL2U */
16dcda29f6SYatharth Kochar static image_info_t scp_bl2u_image_info;
17dcda29f6SYatharth Kochar 
18dcda29f6SYatharth Kochar /*******************************************************************************
19dcda29f6SYatharth Kochar  * BL1 can pass platform dependent information to BL2U in x1.
20dcda29f6SYatharth Kochar  * In case of ARM CSS platforms x1 contains SCP_BL2U image info.
21dcda29f6SYatharth Kochar  * In case of ARM FVP platforms x1 is not used.
22dcda29f6SYatharth Kochar  * In both cases, x0 contains the extents of the memory available to BL2U
23dcda29f6SYatharth Kochar  ******************************************************************************/
24dcda29f6SYatharth Kochar void bl2u_early_platform_setup(meminfo_t *mem_layout, void *plat_info)
25dcda29f6SYatharth Kochar {
26dcda29f6SYatharth Kochar 	if (!plat_info)
27dcda29f6SYatharth Kochar 		panic();
28dcda29f6SYatharth Kochar 
29dcda29f6SYatharth Kochar 	arm_bl2u_early_platform_setup(mem_layout, plat_info);
30dcda29f6SYatharth Kochar 
31dcda29f6SYatharth Kochar 	scp_bl2u_image_info = *(image_info_t *)plat_info;
32dcda29f6SYatharth Kochar }
33dcda29f6SYatharth Kochar 
34dcda29f6SYatharth Kochar /*******************************************************************************
35dcda29f6SYatharth Kochar  * Transfer SCP_BL2U from Trusted RAM using the SCP Download protocol.
36dcda29f6SYatharth Kochar  ******************************************************************************/
37dcda29f6SYatharth Kochar int bl2u_plat_handle_scp_bl2u(void)
38dcda29f6SYatharth Kochar {
39dcda29f6SYatharth Kochar 	int ret;
40dcda29f6SYatharth Kochar 
41dcda29f6SYatharth Kochar 	INFO("BL2U: Initiating SCP_BL2U transfer to SCP\n");
42dcda29f6SYatharth Kochar 
43dcda29f6SYatharth Kochar 	ret = scp_bootloader_transfer((void *)scp_bl2u_image_info.image_base,
44dcda29f6SYatharth Kochar 		scp_bl2u_image_info.image_size);
45dcda29f6SYatharth Kochar 
46dcda29f6SYatharth Kochar 	if (ret == 0)
47dcda29f6SYatharth Kochar 		INFO("BL2U: SCP_BL2U transferred to SCP\n");
48dcda29f6SYatharth Kochar 	else
49dcda29f6SYatharth Kochar 		ERROR("BL2U: SCP_BL2U transfer failure\n");
50dcda29f6SYatharth Kochar 
51dcda29f6SYatharth Kochar 	return ret;
52dcda29f6SYatharth Kochar }
53