xref: /rk3399_ARM-atf/plat/arm/common/arm_image_load.c (revision 47fe4c4fe22fa7df5e79867eb6a52e842e6abdb6)
1a8aa7fecSYatharth Kochar /*
2cb3b5344SManish Pandey  * Copyright (c) 2016-2020, ARM Limited and Contributors. All rights reserved.
3a8aa7fecSYatharth Kochar  *
482cb2c1aSdp-arm  * SPDX-License-Identifier: BSD-3-Clause
5a8aa7fecSYatharth Kochar  */
6a8aa7fecSYatharth Kochar 
75b8d50e4SSathees Balya #include <assert.h>
809d40e0eSAntonio Nino Diaz #include <common/bl_common.h>
909d40e0eSAntonio Nino Diaz #include <common/desc_image_load.h>
10cb3b5344SManish Pandey #if defined(SPD_spmd)
11cb3b5344SManish Pandey #include <plat/arm/common/fconf_arm_sp_getter.h>
12cb3b5344SManish Pandey #endif
13bd9344f6SAntonio Nino Diaz #include <plat/arm/common/plat_arm.h>
1409d40e0eSAntonio Nino Diaz #include <plat/common/platform.h>
15a8aa7fecSYatharth Kochar 
16a8aa7fecSYatharth Kochar #pragma weak plat_flush_next_bl_params
17a8aa7fecSYatharth Kochar #pragma weak plat_get_bl_image_load_info
18a8aa7fecSYatharth Kochar #pragma weak plat_get_next_bl_params
19a8aa7fecSYatharth Kochar 
205b8d50e4SSathees Balya static bl_params_t *next_bl_params_cpy_ptr;
21a8aa7fecSYatharth Kochar 
22a8aa7fecSYatharth Kochar /*******************************************************************************
23a8aa7fecSYatharth Kochar  * This function flushes the data structures so that they are visible
24a8aa7fecSYatharth Kochar  * in memory for the next BL image.
25a8aa7fecSYatharth Kochar  ******************************************************************************/
26a8aa7fecSYatharth Kochar void plat_flush_next_bl_params(void)
27a8aa7fecSYatharth Kochar {
285b8d50e4SSathees Balya 	assert(next_bl_params_cpy_ptr != NULL);
295b8d50e4SSathees Balya 
305b8d50e4SSathees Balya 	flush_bl_params_desc_args(bl_mem_params_desc_ptr,
315b8d50e4SSathees Balya 		bl_mem_params_desc_num,
325b8d50e4SSathees Balya 		next_bl_params_cpy_ptr);
33a8aa7fecSYatharth Kochar }
34a8aa7fecSYatharth Kochar 
35c33ff198SOlivier Deprez #if defined(SPD_spmd) && SPMD_SPM_AT_SEL2
36cb3b5344SManish Pandey /*******************************************************************************
37cb3b5344SManish Pandey  * This function appends Secure Partitions to list of loadable images.
38cb3b5344SManish Pandey  ******************************************************************************/
39c33ff198SOlivier Deprez static void plat_add_sp_images_load_info(struct bl_load_info *load_info)
40cb3b5344SManish Pandey {
41cb3b5344SManish Pandey 	bl_load_info_node_t *node_info = load_info->head;
42cb3b5344SManish Pandey 	unsigned int index = 0;
43cb3b5344SManish Pandey 
44cb3b5344SManish Pandey 	if (sp_mem_params_descs[index].image_id == 0) {
45cb3b5344SManish Pandey 		ERROR("No Secure Partition Image available\n");
46cb3b5344SManish Pandey 		return;
47cb3b5344SManish Pandey 	}
48cb3b5344SManish Pandey 
49cb3b5344SManish Pandey 	/* Traverse through the bl images list */
50cb3b5344SManish Pandey 	do {
51cb3b5344SManish Pandey 		node_info = node_info->next_load_info;
52cb3b5344SManish Pandey 	} while (node_info->next_load_info != NULL);
53cb3b5344SManish Pandey 
54*47fe4c4fSHeyi Guo 	bl_load_info_node_t *sp_node =
55*47fe4c4fSHeyi Guo 		&sp_mem_params_descs[index].load_node_mem;
56*47fe4c4fSHeyi Guo 
57*47fe4c4fSHeyi Guo 	node_info->next_load_info = sp_node;
58*47fe4c4fSHeyi Guo 
59cb3b5344SManish Pandey 	for (; index < MAX_SP_IDS; index++) {
60cb3b5344SManish Pandey 		/* Populate the image information */
61*47fe4c4fSHeyi Guo 		sp_node->image_id = sp_mem_params_descs[index].image_id;
62*47fe4c4fSHeyi Guo 		sp_node->image_info = &sp_mem_params_descs[index].image_info;
63cb3b5344SManish Pandey 
64cb3b5344SManish Pandey 		if ((index + 1U) == MAX_SP_IDS) {
65cb3b5344SManish Pandey 			INFO("Reached Max number of SPs\n");
66cb3b5344SManish Pandey 			return;
67cb3b5344SManish Pandey 		}
68cb3b5344SManish Pandey 
69cb3b5344SManish Pandey 		if (sp_mem_params_descs[index + 1U].image_id == 0) {
70cb3b5344SManish Pandey 			return;
71cb3b5344SManish Pandey 		}
72cb3b5344SManish Pandey 
73*47fe4c4fSHeyi Guo 		sp_node->next_load_info =
74cb3b5344SManish Pandey 			&sp_mem_params_descs[index + 1U].load_node_mem;
75*47fe4c4fSHeyi Guo 		sp_node = sp_node->next_load_info;
76cb3b5344SManish Pandey 
77cb3b5344SManish Pandey 	}
78cb3b5344SManish Pandey }
79cb3b5344SManish Pandey #endif
80cb3b5344SManish Pandey 
81a8aa7fecSYatharth Kochar /*******************************************************************************
82a8aa7fecSYatharth Kochar  * This function returns the list of loadable images.
83a8aa7fecSYatharth Kochar  ******************************************************************************/
846c77e749SSandrine Bailleux struct bl_load_info *plat_get_bl_image_load_info(void)
85a8aa7fecSYatharth Kochar {
86c33ff198SOlivier Deprez #if defined(SPD_spmd) && SPMD_SPM_AT_SEL2
87cb3b5344SManish Pandey 	bl_load_info_t *bl_load_info;
88cb3b5344SManish Pandey 
89cb3b5344SManish Pandey 	bl_load_info = get_bl_load_info_from_mem_params_desc();
90cb3b5344SManish Pandey 	plat_add_sp_images_load_info(bl_load_info);
91cb3b5344SManish Pandey 
92cb3b5344SManish Pandey 	return bl_load_info;
93cb3b5344SManish Pandey #else
94a8aa7fecSYatharth Kochar 	return get_bl_load_info_from_mem_params_desc();
95cb3b5344SManish Pandey #endif
96a8aa7fecSYatharth Kochar }
97a8aa7fecSYatharth Kochar 
98a8aa7fecSYatharth Kochar /*******************************************************************************
995b8d50e4SSathees Balya  * ARM helper function to return the list of executable images.Since the default
1005b8d50e4SSathees Balya  * descriptors are allocated within BL2 RW memory, this prevents BL31/BL32
1015b8d50e4SSathees Balya  * overlay of BL2 memory. Hence this function also copies the descriptors to a
1025b8d50e4SSathees Balya  * pre-allocated memory indicated by ARM_BL2_MEM_DESC_BASE.
1035b8d50e4SSathees Balya  ******************************************************************************/
1045b8d50e4SSathees Balya struct bl_params *arm_get_next_bl_params(void)
1055b8d50e4SSathees Balya {
1065b8d50e4SSathees Balya 	bl_mem_params_node_t *bl2_mem_params_descs_cpy
1075b8d50e4SSathees Balya 			= (bl_mem_params_node_t *)ARM_BL2_MEM_DESC_BASE;
1085b8d50e4SSathees Balya 	const bl_params_t *next_bl_params;
1095b8d50e4SSathees Balya 
1105b8d50e4SSathees Balya 	next_bl_params_cpy_ptr =
1115b8d50e4SSathees Balya 		(bl_params_t *)(ARM_BL2_MEM_DESC_BASE +
1125b8d50e4SSathees Balya 		(bl_mem_params_desc_num * sizeof(bl_mem_params_node_t)));
1135b8d50e4SSathees Balya 
1145b8d50e4SSathees Balya 	/*
1155b8d50e4SSathees Balya 	 * Copy the memory descriptors to ARM_BL2_MEM_DESC_BASE area.
1165b8d50e4SSathees Balya 	 */
1175b8d50e4SSathees Balya 	(void) memcpy(bl2_mem_params_descs_cpy, bl_mem_params_desc_ptr,
1185b8d50e4SSathees Balya 		(bl_mem_params_desc_num * sizeof(bl_mem_params_node_t)));
1195b8d50e4SSathees Balya 
1205b8d50e4SSathees Balya 	/*
1215b8d50e4SSathees Balya 	 * Modify the global 'bl_mem_params_desc_ptr' to point to the
1225b8d50e4SSathees Balya 	 * copied location.
1235b8d50e4SSathees Balya 	 */
1245b8d50e4SSathees Balya 	bl_mem_params_desc_ptr = bl2_mem_params_descs_cpy;
1255b8d50e4SSathees Balya 
1265b8d50e4SSathees Balya 	next_bl_params = get_next_bl_params_from_mem_params_desc();
1275b8d50e4SSathees Balya 	assert(next_bl_params != NULL);
1285b8d50e4SSathees Balya 
1295b8d50e4SSathees Balya 	/*
1305b8d50e4SSathees Balya 	 * Copy 'next_bl_params' to the reserved location after the copied
1315b8d50e4SSathees Balya 	 * memory descriptors.
1325b8d50e4SSathees Balya 	 */
1335b8d50e4SSathees Balya 	(void) memcpy(next_bl_params_cpy_ptr, next_bl_params,
1345b8d50e4SSathees Balya 						(sizeof(bl_params_t)));
1355b8d50e4SSathees Balya 
1365b8d50e4SSathees Balya 	populate_next_bl_params_config(next_bl_params_cpy_ptr);
1375b8d50e4SSathees Balya 
1385b8d50e4SSathees Balya 	return next_bl_params_cpy_ptr;
1395b8d50e4SSathees Balya }
1405b8d50e4SSathees Balya 
1415b8d50e4SSathees Balya /*******************************************************************************
1425b8d50e4SSathees Balya  * This function returns the list of executable images
143a8aa7fecSYatharth Kochar  ******************************************************************************/
1446c77e749SSandrine Bailleux struct bl_params *plat_get_next_bl_params(void)
145a8aa7fecSYatharth Kochar {
1465b8d50e4SSathees Balya 	return arm_get_next_bl_params();
147a8aa7fecSYatharth Kochar }
1485b8d50e4SSathees Balya 
149