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