xref: /rk3399_ARM-atf/plat/arm/common/arm_image_load.c (revision bd9344f670a46125cdd8949ded75be124f34d587)
1a8aa7fecSYatharth Kochar /*
2cab0b5b0SSoby Mathew  * Copyright (c) 2016-2018, 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>
10*bd9344f6SAntonio Nino Diaz #include <plat/arm/common/plat_arm.h>
1109d40e0eSAntonio Nino Diaz #include <plat/common/platform.h>
12a8aa7fecSYatharth Kochar 
13a8aa7fecSYatharth Kochar #pragma weak plat_flush_next_bl_params
14a8aa7fecSYatharth Kochar #pragma weak plat_get_bl_image_load_info
15a8aa7fecSYatharth Kochar #pragma weak plat_get_next_bl_params
16a8aa7fecSYatharth Kochar 
175b8d50e4SSathees Balya static bl_params_t *next_bl_params_cpy_ptr;
18a8aa7fecSYatharth Kochar 
19a8aa7fecSYatharth Kochar /*******************************************************************************
20a8aa7fecSYatharth Kochar  * This function flushes the data structures so that they are visible
21a8aa7fecSYatharth Kochar  * in memory for the next BL image.
22a8aa7fecSYatharth Kochar  ******************************************************************************/
23a8aa7fecSYatharth Kochar void plat_flush_next_bl_params(void)
24a8aa7fecSYatharth Kochar {
255b8d50e4SSathees Balya 	assert(next_bl_params_cpy_ptr != NULL);
265b8d50e4SSathees Balya 
275b8d50e4SSathees Balya 	flush_bl_params_desc_args(bl_mem_params_desc_ptr,
285b8d50e4SSathees Balya 		bl_mem_params_desc_num,
295b8d50e4SSathees Balya 		next_bl_params_cpy_ptr);
30a8aa7fecSYatharth Kochar }
31a8aa7fecSYatharth Kochar 
32a8aa7fecSYatharth Kochar /*******************************************************************************
33a8aa7fecSYatharth Kochar  * This function returns the list of loadable images.
34a8aa7fecSYatharth Kochar  ******************************************************************************/
356c77e749SSandrine Bailleux struct bl_load_info *plat_get_bl_image_load_info(void)
36a8aa7fecSYatharth Kochar {
37a8aa7fecSYatharth Kochar 	return get_bl_load_info_from_mem_params_desc();
38a8aa7fecSYatharth Kochar }
39a8aa7fecSYatharth Kochar 
40a8aa7fecSYatharth Kochar /*******************************************************************************
415b8d50e4SSathees Balya  * ARM helper function to return the list of executable images.Since the default
425b8d50e4SSathees Balya  * descriptors are allocated within BL2 RW memory, this prevents BL31/BL32
435b8d50e4SSathees Balya  * overlay of BL2 memory. Hence this function also copies the descriptors to a
445b8d50e4SSathees Balya  * pre-allocated memory indicated by ARM_BL2_MEM_DESC_BASE.
455b8d50e4SSathees Balya  ******************************************************************************/
465b8d50e4SSathees Balya struct bl_params *arm_get_next_bl_params(void)
475b8d50e4SSathees Balya {
485b8d50e4SSathees Balya 	bl_mem_params_node_t *bl2_mem_params_descs_cpy
495b8d50e4SSathees Balya 			= (bl_mem_params_node_t *)ARM_BL2_MEM_DESC_BASE;
505b8d50e4SSathees Balya 	const bl_params_t *next_bl_params;
515b8d50e4SSathees Balya 
525b8d50e4SSathees Balya 	next_bl_params_cpy_ptr =
535b8d50e4SSathees Balya 		(bl_params_t *)(ARM_BL2_MEM_DESC_BASE +
545b8d50e4SSathees Balya 		(bl_mem_params_desc_num * sizeof(bl_mem_params_node_t)));
555b8d50e4SSathees Balya 
565b8d50e4SSathees Balya 	/*
575b8d50e4SSathees Balya 	 * Copy the memory descriptors to ARM_BL2_MEM_DESC_BASE area.
585b8d50e4SSathees Balya 	 */
595b8d50e4SSathees Balya 	(void) memcpy(bl2_mem_params_descs_cpy, bl_mem_params_desc_ptr,
605b8d50e4SSathees Balya 		(bl_mem_params_desc_num * sizeof(bl_mem_params_node_t)));
615b8d50e4SSathees Balya 
625b8d50e4SSathees Balya 	/*
635b8d50e4SSathees Balya 	 * Modify the global 'bl_mem_params_desc_ptr' to point to the
645b8d50e4SSathees Balya 	 * copied location.
655b8d50e4SSathees Balya 	 */
665b8d50e4SSathees Balya 	bl_mem_params_desc_ptr = bl2_mem_params_descs_cpy;
675b8d50e4SSathees Balya 
685b8d50e4SSathees Balya 	next_bl_params = get_next_bl_params_from_mem_params_desc();
695b8d50e4SSathees Balya 	assert(next_bl_params != NULL);
705b8d50e4SSathees Balya 
715b8d50e4SSathees Balya 	/*
725b8d50e4SSathees Balya 	 * Copy 'next_bl_params' to the reserved location after the copied
735b8d50e4SSathees Balya 	 * memory descriptors.
745b8d50e4SSathees Balya 	 */
755b8d50e4SSathees Balya 	(void) memcpy(next_bl_params_cpy_ptr, next_bl_params,
765b8d50e4SSathees Balya 						(sizeof(bl_params_t)));
775b8d50e4SSathees Balya 
785b8d50e4SSathees Balya 	populate_next_bl_params_config(next_bl_params_cpy_ptr);
795b8d50e4SSathees Balya 
805b8d50e4SSathees Balya 	return next_bl_params_cpy_ptr;
815b8d50e4SSathees Balya }
825b8d50e4SSathees Balya 
835b8d50e4SSathees Balya /*******************************************************************************
845b8d50e4SSathees Balya  * This function returns the list of executable images
85a8aa7fecSYatharth Kochar  ******************************************************************************/
866c77e749SSandrine Bailleux struct bl_params *plat_get_next_bl_params(void)
87a8aa7fecSYatharth Kochar {
885b8d50e4SSathees Balya 	return arm_get_next_bl_params();
89a8aa7fecSYatharth Kochar }
905b8d50e4SSathees Balya 
91