You can not select more than 25 topics
Topics must start with a letter or number, can include dashes ('-') and can be up to 35 characters long.
144 lines
4.4 KiB
144 lines
4.4 KiB
4 months ago
|
/*
|
||
|
* Copyright (c) 2016-2020, ARM Limited and Contributors. All rights reserved.
|
||
|
*
|
||
|
* SPDX-License-Identifier: BSD-3-Clause
|
||
|
*/
|
||
|
|
||
|
#include <assert.h>
|
||
|
#include <common/bl_common.h>
|
||
|
#include <common/desc_image_load.h>
|
||
|
#if defined(SPD_spmd)
|
||
|
#include <plat/arm/common/fconf_arm_sp_getter.h>
|
||
|
#endif
|
||
|
#include <plat/arm/common/plat_arm.h>
|
||
|
#include <plat/common/platform.h>
|
||
|
|
||
|
#pragma weak plat_flush_next_bl_params
|
||
|
#pragma weak plat_get_bl_image_load_info
|
||
|
#pragma weak plat_get_next_bl_params
|
||
|
|
||
|
static bl_params_t *next_bl_params_cpy_ptr;
|
||
|
|
||
|
/*******************************************************************************
|
||
|
* This function flushes the data structures so that they are visible
|
||
|
* in memory for the next BL image.
|
||
|
******************************************************************************/
|
||
|
void plat_flush_next_bl_params(void)
|
||
|
{
|
||
|
assert(next_bl_params_cpy_ptr != NULL);
|
||
|
|
||
|
flush_bl_params_desc_args(bl_mem_params_desc_ptr,
|
||
|
bl_mem_params_desc_num,
|
||
|
next_bl_params_cpy_ptr);
|
||
|
}
|
||
|
|
||
|
#if defined(SPD_spmd) && SPMD_SPM_AT_SEL2
|
||
|
/*******************************************************************************
|
||
|
* This function appends Secure Partitions to list of loadable images.
|
||
|
******************************************************************************/
|
||
|
static void plat_add_sp_images_load_info(struct bl_load_info *load_info)
|
||
|
{
|
||
|
bl_load_info_node_t *node_info = load_info->head;
|
||
|
unsigned int index = 0;
|
||
|
|
||
|
if (sp_mem_params_descs[index].image_id == 0) {
|
||
|
ERROR("No Secure Partition Image available\n");
|
||
|
return;
|
||
|
}
|
||
|
|
||
|
/* Traverse through the bl images list */
|
||
|
do {
|
||
|
node_info = node_info->next_load_info;
|
||
|
} while (node_info->next_load_info != NULL);
|
||
|
|
||
|
for (; index < MAX_SP_IDS; index++) {
|
||
|
/* Populate the image information */
|
||
|
node_info->image_id = sp_mem_params_descs[index].image_id;
|
||
|
node_info->image_info = &sp_mem_params_descs[index].image_info;
|
||
|
|
||
|
if ((index + 1U) == MAX_SP_IDS) {
|
||
|
INFO("Reached Max number of SPs\n");
|
||
|
return;
|
||
|
}
|
||
|
|
||
|
if (sp_mem_params_descs[index + 1U].image_id == 0) {
|
||
|
return;
|
||
|
}
|
||
|
|
||
|
node_info->next_load_info =
|
||
|
&sp_mem_params_descs[index + 1U].load_node_mem;
|
||
|
node_info = node_info->next_load_info;
|
||
|
|
||
|
}
|
||
|
}
|
||
|
#endif
|
||
|
|
||
|
/*******************************************************************************
|
||
|
* This function returns the list of loadable images.
|
||
|
******************************************************************************/
|
||
|
struct bl_load_info *plat_get_bl_image_load_info(void)
|
||
|
{
|
||
|
#if defined(SPD_spmd) && SPMD_SPM_AT_SEL2
|
||
|
bl_load_info_t *bl_load_info;
|
||
|
|
||
|
bl_load_info = get_bl_load_info_from_mem_params_desc();
|
||
|
plat_add_sp_images_load_info(bl_load_info);
|
||
|
|
||
|
return bl_load_info;
|
||
|
#else
|
||
|
return get_bl_load_info_from_mem_params_desc();
|
||
|
#endif
|
||
|
}
|
||
|
|
||
|
/*******************************************************************************
|
||
|
* ARM helper function to return the list of executable images.Since the default
|
||
|
* descriptors are allocated within BL2 RW memory, this prevents BL31/BL32
|
||
|
* overlay of BL2 memory. Hence this function also copies the descriptors to a
|
||
|
* pre-allocated memory indicated by ARM_BL2_MEM_DESC_BASE.
|
||
|
******************************************************************************/
|
||
|
struct bl_params *arm_get_next_bl_params(void)
|
||
|
{
|
||
|
bl_mem_params_node_t *bl2_mem_params_descs_cpy
|
||
|
= (bl_mem_params_node_t *)ARM_BL2_MEM_DESC_BASE;
|
||
|
const bl_params_t *next_bl_params;
|
||
|
|
||
|
next_bl_params_cpy_ptr =
|
||
|
(bl_params_t *)(ARM_BL2_MEM_DESC_BASE +
|
||
|
(bl_mem_params_desc_num * sizeof(bl_mem_params_node_t)));
|
||
|
|
||
|
/*
|
||
|
* Copy the memory descriptors to ARM_BL2_MEM_DESC_BASE area.
|
||
|
*/
|
||
|
(void) memcpy(bl2_mem_params_descs_cpy, bl_mem_params_desc_ptr,
|
||
|
(bl_mem_params_desc_num * sizeof(bl_mem_params_node_t)));
|
||
|
|
||
|
/*
|
||
|
* Modify the global 'bl_mem_params_desc_ptr' to point to the
|
||
|
* copied location.
|
||
|
*/
|
||
|
bl_mem_params_desc_ptr = bl2_mem_params_descs_cpy;
|
||
|
|
||
|
next_bl_params = get_next_bl_params_from_mem_params_desc();
|
||
|
assert(next_bl_params != NULL);
|
||
|
|
||
|
/*
|
||
|
* Copy 'next_bl_params' to the reserved location after the copied
|
||
|
* memory descriptors.
|
||
|
*/
|
||
|
(void) memcpy(next_bl_params_cpy_ptr, next_bl_params,
|
||
|
(sizeof(bl_params_t)));
|
||
|
|
||
|
populate_next_bl_params_config(next_bl_params_cpy_ptr);
|
||
|
|
||
|
return next_bl_params_cpy_ptr;
|
||
|
}
|
||
|
|
||
|
/*******************************************************************************
|
||
|
* This function returns the list of executable images
|
||
|
******************************************************************************/
|
||
|
struct bl_params *plat_get_next_bl_params(void)
|
||
|
{
|
||
|
return arm_get_next_bl_params();
|
||
|
}
|
||
|
|