blob: 11cb3b8397eec66233f843eac73b285aba5f5f42 [file] [log] [blame]
Yatharth Kocharf9a0f162016-09-13 17:07:57 +01001/*
Manish Pandey1fa6ecb2020-02-25 11:38:19 +00002 * Copyright (c) 2016-2020, ARM Limited and Contributors. All rights reserved.
Yatharth Kocharf9a0f162016-09-13 17:07:57 +01003 *
dp-armfa3cf0b2017-05-03 09:38:09 +01004 * SPDX-License-Identifier: BSD-3-Clause
Yatharth Kocharf9a0f162016-09-13 17:07:57 +01005 */
6
Sathees Balya90950092018-11-15 14:22:30 +00007#include <assert.h>
Antonio Nino Diaze0f90632018-12-14 00:18:21 +00008#include <common/bl_common.h>
9#include <common/desc_image_load.h>
Manish Pandey1fa6ecb2020-02-25 11:38:19 +000010#if defined(SPD_spmd)
11#include <plat/arm/common/fconf_arm_sp_getter.h>
12#endif
Antonio Nino Diazbd7b7402019-01-25 14:30:04 +000013#include <plat/arm/common/plat_arm.h>
Antonio Nino Diaze0f90632018-12-14 00:18:21 +000014#include <plat/common/platform.h>
15
Yatharth Kocharf9a0f162016-09-13 17:07:57 +010016#pragma weak plat_flush_next_bl_params
17#pragma weak plat_get_bl_image_load_info
18#pragma weak plat_get_next_bl_params
19
Sathees Balya90950092018-11-15 14:22:30 +000020static bl_params_t *next_bl_params_cpy_ptr;
Yatharth Kocharf9a0f162016-09-13 17:07:57 +010021
22/*******************************************************************************
23 * This function flushes the data structures so that they are visible
24 * in memory for the next BL image.
25 ******************************************************************************/
26void plat_flush_next_bl_params(void)
27{
Sathees Balya90950092018-11-15 14:22:30 +000028 assert(next_bl_params_cpy_ptr != NULL);
29
30 flush_bl_params_desc_args(bl_mem_params_desc_ptr,
31 bl_mem_params_desc_num,
32 next_bl_params_cpy_ptr);
Yatharth Kocharf9a0f162016-09-13 17:07:57 +010033}
34
Olivier Deprez042db532020-03-19 09:27:11 +010035#if defined(SPD_spmd) && SPMD_SPM_AT_SEL2
Manish Pandey1fa6ecb2020-02-25 11:38:19 +000036/*******************************************************************************
37 * This function appends Secure Partitions to list of loadable images.
38 ******************************************************************************/
Olivier Deprez042db532020-03-19 09:27:11 +010039static void plat_add_sp_images_load_info(struct bl_load_info *load_info)
Manish Pandey1fa6ecb2020-02-25 11:38:19 +000040{
41 bl_load_info_node_t *node_info = load_info->head;
42 unsigned int index = 0;
43
44 if (sp_mem_params_descs[index].image_id == 0) {
45 ERROR("No Secure Partition Image available\n");
46 return;
47 }
48
49 /* Traverse through the bl images list */
50 do {
51 node_info = node_info->next_load_info;
52 } while (node_info->next_load_info != NULL);
53
Heyi Guo3dd94932021-01-25 21:45:47 +080054 bl_load_info_node_t *sp_node =
55 &sp_mem_params_descs[index].load_node_mem;
56
57 node_info->next_load_info = sp_node;
58
Manish Pandey1fa6ecb2020-02-25 11:38:19 +000059 for (; index < MAX_SP_IDS; index++) {
60 /* Populate the image information */
Heyi Guo3dd94932021-01-25 21:45:47 +080061 sp_node->image_id = sp_mem_params_descs[index].image_id;
62 sp_node->image_info = &sp_mem_params_descs[index].image_info;
Manish Pandey1fa6ecb2020-02-25 11:38:19 +000063
64 if ((index + 1U) == MAX_SP_IDS) {
65 INFO("Reached Max number of SPs\n");
66 return;
67 }
68
69 if (sp_mem_params_descs[index + 1U].image_id == 0) {
70 return;
71 }
72
Heyi Guo3dd94932021-01-25 21:45:47 +080073 sp_node->next_load_info =
Manish Pandey1fa6ecb2020-02-25 11:38:19 +000074 &sp_mem_params_descs[index + 1U].load_node_mem;
Heyi Guo3dd94932021-01-25 21:45:47 +080075 sp_node = sp_node->next_load_info;
Manish Pandey1fa6ecb2020-02-25 11:38:19 +000076
77 }
78}
79#endif
80
Yatharth Kocharf9a0f162016-09-13 17:07:57 +010081/*******************************************************************************
82 * This function returns the list of loadable images.
83 ******************************************************************************/
Sandrine Bailleuxb3b6e222018-07-11 12:44:22 +020084struct bl_load_info *plat_get_bl_image_load_info(void)
Yatharth Kocharf9a0f162016-09-13 17:07:57 +010085{
Olivier Deprez042db532020-03-19 09:27:11 +010086#if defined(SPD_spmd) && SPMD_SPM_AT_SEL2
Manish Pandey1fa6ecb2020-02-25 11:38:19 +000087 bl_load_info_t *bl_load_info;
88
89 bl_load_info = get_bl_load_info_from_mem_params_desc();
90 plat_add_sp_images_load_info(bl_load_info);
91
92 return bl_load_info;
93#else
Yatharth Kocharf9a0f162016-09-13 17:07:57 +010094 return get_bl_load_info_from_mem_params_desc();
Manish Pandey1fa6ecb2020-02-25 11:38:19 +000095#endif
Yatharth Kocharf9a0f162016-09-13 17:07:57 +010096}
97
98/*******************************************************************************
Sathees Balya90950092018-11-15 14:22:30 +000099 * ARM helper function to return the list of executable images.Since the default
100 * descriptors are allocated within BL2 RW memory, this prevents BL31/BL32
101 * overlay of BL2 memory. Hence this function also copies the descriptors to a
102 * pre-allocated memory indicated by ARM_BL2_MEM_DESC_BASE.
Yatharth Kocharf9a0f162016-09-13 17:07:57 +0100103 ******************************************************************************/
Sathees Balya90950092018-11-15 14:22:30 +0000104struct bl_params *arm_get_next_bl_params(void)
Yatharth Kocharf9a0f162016-09-13 17:07:57 +0100105{
Sathees Balya90950092018-11-15 14:22:30 +0000106 bl_mem_params_node_t *bl2_mem_params_descs_cpy
107 = (bl_mem_params_node_t *)ARM_BL2_MEM_DESC_BASE;
108 const bl_params_t *next_bl_params;
109
110 next_bl_params_cpy_ptr =
111 (bl_params_t *)(ARM_BL2_MEM_DESC_BASE +
112 (bl_mem_params_desc_num * sizeof(bl_mem_params_node_t)));
113
114 /*
115 * Copy the memory descriptors to ARM_BL2_MEM_DESC_BASE area.
116 */
117 (void) memcpy(bl2_mem_params_descs_cpy, bl_mem_params_desc_ptr,
118 (bl_mem_params_desc_num * sizeof(bl_mem_params_node_t)));
Soby Mathew96a1c6b2018-01-15 14:45:33 +0000119
Sathees Balya90950092018-11-15 14:22:30 +0000120 /*
121 * Modify the global 'bl_mem_params_desc_ptr' to point to the
122 * copied location.
123 */
124 bl_mem_params_desc_ptr = bl2_mem_params_descs_cpy;
125
126 next_bl_params = get_next_bl_params_from_mem_params_desc();
127 assert(next_bl_params != NULL);
128
129 /*
130 * Copy 'next_bl_params' to the reserved location after the copied
131 * memory descriptors.
132 */
133 (void) memcpy(next_bl_params_cpy_ptr, next_bl_params,
134 (sizeof(bl_params_t)));
135
136 populate_next_bl_params_config(next_bl_params_cpy_ptr);
137
138 return next_bl_params_cpy_ptr;
Yatharth Kocharf9a0f162016-09-13 17:07:57 +0100139}
Sathees Balya90950092018-11-15 14:22:30 +0000140
141/*******************************************************************************
142 * This function returns the list of executable images
143 ******************************************************************************/
144struct bl_params *plat_get_next_bl_params(void)
145{
146 return arm_get_next_bl_params();
147}
148