[U-Boot] [PATCH v2 2/2] common: spl: atf: support booting bl32 image【请注意,邮件由u-boot-bounces at lists.denx.de代发】 image

Kever Yang kever.yang at rock-chips.com
Mon Oct 14 09:55:52 UTC 2019


On 2019/10/14 下午5:07, Kever Yang wrote:
>
> On 2019/10/7 上午2:10, Heiko Stuebner wrote:
>> From: Joseph Chen <chenjh at rock-chips.com>
>>
>> Trusted-Firmware can also initialize a secure payload to use as a 
>> trusted
>> execution environment. In general for the arm64 case this is provided as
>> separate image and uboot is supposed to also place it in a predetermined
>> location in memory and add the necessary parameters to the ATF boot 
>> params.
>>
>> So add the possibility to get this tee payload from the provided FIT 
>> image
>> and setup things as necessary.
>>
>> Tested on a Rockchip PX30 with mainline TF-A, mainline OP-Tee (with 
>> pending
>> PX30 support) and mainline 5.4-rc1 Linux kernel.
>>
>> Signed-off-by: Joseph Chen <chenjh at rock-chips.com>
>> Signed-off-by: Heiko Stuebner <heiko at sntech.de>
>
> Reviewed-by: Kever Yang<kever.yang at rock-chips.com>

Applied to u-boot-rockchip master.
>
>
> Thanks,
> - Kever
>> ---
>> changes in v2: set fdt address as param for tee
>>
>>   common/spl/spl_atf.c | 49 +++++++++++++++++++++++++++++++-------------
>>   1 file changed, 35 insertions(+), 14 deletions(-)
>>
>> diff --git a/common/spl/spl_atf.c b/common/spl/spl_atf.c
>> index 4715f9d371..7a46ed6e6d 100644
>> --- a/common/spl/spl_atf.c
>> +++ b/common/spl/spl_atf.c
>> @@ -30,8 +30,11 @@ static struct bl31_params *bl2_to_bl31_params;
>>    *
>>    * @return bl31 params structure pointer
>>    */
>> -static struct bl31_params *bl2_plat_get_bl31_params(uintptr_t 
>> bl33_entry)
>> +static struct bl31_params *bl2_plat_get_bl31_params(uintptr_t 
>> bl32_entry,
>> +                            uintptr_t bl33_entry,
>> +                            uintptr_t fdt_addr)
>>   {
>> +    struct entry_point_info *bl32_ep_info;
>>       struct entry_point_info *bl33_ep_info;
>>         /*
>> @@ -49,16 +52,22 @@ static struct bl31_params 
>> *bl2_plat_get_bl31_params(uintptr_t bl33_entry)
>>       SET_PARAM_HEAD(bl2_to_bl31_params->bl31_image_info,
>>                  ATF_PARAM_IMAGE_BINARY, ATF_VERSION_1, 0);
>>   -    /* Fill BL32 related information if it exists */
>> +
>> +    /* Fill BL32 related information */
>>       bl2_to_bl31_params->bl32_ep_info = &bl31_params_mem.bl32_ep_info;
>> -    SET_PARAM_HEAD(bl2_to_bl31_params->bl32_ep_info, ATF_PARAM_EP,
>> -               ATF_VERSION_1, 0);
>> +    bl32_ep_info = &bl31_params_mem.bl32_ep_info;
>> +    SET_PARAM_HEAD(bl32_ep_info, ATF_PARAM_EP, ATF_VERSION_1,
>> +               ATF_EP_SECURE);
>> +
>> +    /* secure payload is optional, so set pc to 0 if absent */
>> +    bl32_ep_info->args.arg3 = fdt_addr;
>> +    bl32_ep_info->pc = bl32_entry ? bl32_entry : 0;
>> +    bl32_ep_info->spsr = SPSR_64(MODE_EL1, MODE_SP_ELX,
>> +                     DISABLE_ALL_EXECPTIONS);
>> +
>>       bl2_to_bl31_params->bl32_image_info = 
>> &bl31_params_mem.bl32_image_info;
>>       SET_PARAM_HEAD(bl2_to_bl31_params->bl32_image_info,
>>                  ATF_PARAM_IMAGE_BINARY, ATF_VERSION_1, 0);
>> -#ifndef BL32_BASE
>> -    bl2_to_bl31_params->bl32_ep_info->pc = 0;
>> -#endif /* BL32_BASE */
>>         /* Fill BL33 related information */
>>       bl2_to_bl31_params->bl33_ep_info = &bl31_params_mem.bl33_ep_info;
>> @@ -86,13 +95,14 @@ static inline void raw_write_daif(unsigned int daif)
>>     typedef void (*atf_entry_t)(struct bl31_params *params, void 
>> *plat_params);
>>   -static void bl31_entry(uintptr_t bl31_entry, uintptr_t bl33_entry,
>> -               uintptr_t fdt_addr)
>> +static void bl31_entry(uintptr_t bl31_entry, uintptr_t bl32_entry,
>> +               uintptr_t bl33_entry, uintptr_t fdt_addr)
>>   {
>>       struct bl31_params *bl31_params;
>>       atf_entry_t  atf_entry = (atf_entry_t)bl31_entry;
>>   -    bl31_params = bl2_plat_get_bl31_params(bl33_entry);
>> +    bl31_params = bl2_plat_get_bl31_params(bl32_entry, bl33_entry,
>> +                           fdt_addr);
>>         raw_write_daif(SPSR_EXCEPTION_MASK);
>>       dcache_disable();
>> @@ -100,7 +110,7 @@ static void bl31_entry(uintptr_t bl31_entry, 
>> uintptr_t bl33_entry,
>>       atf_entry((void *)bl31_params, (void *)fdt_addr);
>>   }
>>   -static int spl_fit_images_find_uboot(void *blob)
>> +static int spl_fit_images_find(void *blob, int os)
>>   {
>>       int parent, node, ndepth;
>>       const void *data;
>> @@ -122,7 +132,7 @@ static int spl_fit_images_find_uboot(void *blob)
>>           if (!data)
>>               continue;
>>   -        if (genimg_get_os_id(data) == IH_OS_U_BOOT)
>> +        if (genimg_get_os_id(data) == os)
>>               return node;
>>       };
>>   @@ -143,11 +153,21 @@ uintptr_t spl_fit_images_get_entry(void 
>> *blob, int node)
>>     void spl_invoke_atf(struct spl_image_info *spl_image)
>>   {
>> +    uintptr_t  bl32_entry = 0;
>>       uintptr_t  bl33_entry = CONFIG_SYS_TEXT_BASE;
>>       void *blob = spl_image->fdt_addr;
>>       uintptr_t platform_param = (uintptr_t)blob;
>>       int node;
>>   +    /*
>> +     * Find the OP-TEE binary (in /fit-images) load address or
>> +     * entry point (if different) and pass it as the BL3-2 entry
>> +     * point, this is optional.
>> +     */
>> +    node = spl_fit_images_find(blob, IH_OS_TEE);
>> +    if (node >= 0)
>> +        bl32_entry = spl_fit_images_get_entry(blob, node);
>> +
>>       /*
>>        * Find the U-Boot binary (in /fit-images) load addreess or
>>        * entry point (if different) and pass it as the BL3-3 entry
>> @@ -155,7 +175,7 @@ void spl_invoke_atf(struct spl_image_info 
>> *spl_image)
>>        * This will need to be extended to support Falcon mode.
>>        */
>>   -    node = spl_fit_images_find_uboot(blob);
>> +    node = spl_fit_images_find(blob, IH_OS_U_BOOT);
>>       if (node >= 0)
>>           bl33_entry = spl_fit_images_get_entry(blob, node);
>>   @@ -172,5 +192,6 @@ void spl_invoke_atf(struct spl_image_info 
>> *spl_image)
>>        * We don't provide a BL3-2 entry yet, but this will be possible
>>        * using similar logic.
>>        */
>> -    bl31_entry(spl_image->entry_point, bl33_entry, platform_param);
>> +    bl31_entry(spl_image->entry_point, bl32_entry,
>> +           bl33_entry, platform_param);
>>   }
>
>
> _______________________________________________
> U-Boot mailing list
> U-Boot at lists.denx.de
> https://lists.denx.de/listinfo/u-boot




More information about the U-Boot mailing list