mirror of
https://github.com/u-boot/u-boot.git
synced 2024-11-25 21:24:21 +08:00
spl: Extract legacy image handling into separate file
This patch moves the legacy image handling into a separate file, which will be extended with other legacy image features later. No function change intended. Signed-off-by: Stefan Roese <sr@denx.de> Cc: Daniel Schwierzeck <daniel.schwierzeck@gmail.com> Cc: Weijie Gao <weijie.gao@mediatek.com> Cc: Simon Goldschmidt <simon.k.r.goldschmidt@gmail.com> Reviewed-by: Daniel Schwierzeck <daniel.schwierzeck@gmail.com>
This commit is contained in:
parent
a38f84b439
commit
c11081729f
@ -10,6 +10,7 @@ ifdef CONFIG_SPL_BUILD
|
||||
obj-$(CONFIG_$(SPL_TPL_)FRAMEWORK) += spl.o
|
||||
obj-$(CONFIG_$(SPL_TPL_)BOOTROM_SUPPORT) += spl_bootrom.o
|
||||
obj-$(CONFIG_$(SPL_TPL_)LOAD_FIT) += spl_fit.o
|
||||
obj-$(CONFIG_$(SPL_TPL_)LEGACY_IMAGE_SUPPORT) += spl_legacy.o
|
||||
obj-$(CONFIG_$(SPL_TPL_)NOR_SUPPORT) += spl_nor.o
|
||||
obj-$(CONFIG_$(SPL_TPL_)XIP_SUPPORT) += spl_xip.o
|
||||
obj-$(CONFIG_$(SPL_TPL_)YMODEM_SUPPORT) += spl_ymodem.o
|
||||
|
@ -254,6 +254,14 @@ static int spl_load_fit_image(struct spl_image_info *spl_image,
|
||||
}
|
||||
#endif
|
||||
|
||||
__weak int spl_parse_legacy_header(struct spl_image_info *spl_image,
|
||||
const struct image_header *header)
|
||||
{
|
||||
/* LEGACY image not supported */
|
||||
debug("Legacy boot image support not enabled, proceeding to other boot methods\n");
|
||||
return -EINVAL;
|
||||
}
|
||||
|
||||
int spl_parse_image_header(struct spl_image_info *spl_image,
|
||||
const struct image_header *header)
|
||||
{
|
||||
@ -264,51 +272,11 @@ int spl_parse_image_header(struct spl_image_info *spl_image,
|
||||
return ret;
|
||||
#endif
|
||||
if (image_get_magic(header) == IH_MAGIC) {
|
||||
#ifdef CONFIG_SPL_LEGACY_IMAGE_SUPPORT
|
||||
u32 header_size = sizeof(struct image_header);
|
||||
int ret;
|
||||
|
||||
#ifdef CONFIG_SPL_LEGACY_IMAGE_CRC_CHECK
|
||||
/* check uImage header CRC */
|
||||
if (!image_check_hcrc(header)) {
|
||||
puts("SPL: Image header CRC check failed!\n");
|
||||
return -EINVAL;
|
||||
}
|
||||
#endif
|
||||
|
||||
if (spl_image->flags & SPL_COPY_PAYLOAD_ONLY) {
|
||||
/*
|
||||
* On some system (e.g. powerpc), the load-address and
|
||||
* entry-point is located at address 0. We can't load
|
||||
* to 0-0x40. So skip header in this case.
|
||||
*/
|
||||
spl_image->load_addr = image_get_load(header);
|
||||
spl_image->entry_point = image_get_ep(header);
|
||||
spl_image->size = image_get_data_size(header);
|
||||
} else {
|
||||
spl_image->entry_point = image_get_ep(header);
|
||||
/* Load including the header */
|
||||
spl_image->load_addr = image_get_load(header) -
|
||||
header_size;
|
||||
spl_image->size = image_get_data_size(header) +
|
||||
header_size;
|
||||
}
|
||||
#ifdef CONFIG_SPL_LEGACY_IMAGE_CRC_CHECK
|
||||
/* store uImage data length and CRC to check later */
|
||||
spl_image->dcrc_data = image_get_load(header);
|
||||
spl_image->dcrc_length = image_get_data_size(header);
|
||||
spl_image->dcrc = image_get_dcrc(header);
|
||||
#endif
|
||||
|
||||
spl_image->os = image_get_os(header);
|
||||
spl_image->name = image_get_name(header);
|
||||
debug(SPL_TPL_PROMPT
|
||||
"payload image: %32s load addr: 0x%lx size: %d\n",
|
||||
spl_image->name, spl_image->load_addr, spl_image->size);
|
||||
#else
|
||||
/* LEGACY image not supported */
|
||||
debug("Legacy boot image support not enabled, proceeding to other boot methods\n");
|
||||
return -EINVAL;
|
||||
#endif
|
||||
ret = spl_parse_legacy_header(spl_image, header);
|
||||
if (ret)
|
||||
return ret;
|
||||
} else {
|
||||
#ifdef CONFIG_SPL_PANIC_ON_RAW_IMAGE
|
||||
/*
|
||||
|
54
common/spl/spl_legacy.c
Normal file
54
common/spl/spl_legacy.c
Normal file
@ -0,0 +1,54 @@
|
||||
// SPDX-License-Identifier: GPL-2.0+
|
||||
/*
|
||||
* Copyright (C) 2020 Stefan Roese <sr@denx.de>
|
||||
*/
|
||||
|
||||
#include <common.h>
|
||||
#include <spl.h>
|
||||
|
||||
int spl_parse_legacy_header(struct spl_image_info *spl_image,
|
||||
const struct image_header *header)
|
||||
{
|
||||
u32 header_size = sizeof(struct image_header);
|
||||
|
||||
#ifdef CONFIG_SPL_LEGACY_IMAGE_CRC_CHECK
|
||||
/* check uImage header CRC */
|
||||
if (!image_check_hcrc(header)) {
|
||||
puts("SPL: Image header CRC check failed!\n");
|
||||
return -EINVAL;
|
||||
}
|
||||
#endif
|
||||
|
||||
if (spl_image->flags & SPL_COPY_PAYLOAD_ONLY) {
|
||||
/*
|
||||
* On some system (e.g. powerpc), the load-address and
|
||||
* entry-point is located at address 0. We can't load
|
||||
* to 0-0x40. So skip header in this case.
|
||||
*/
|
||||
spl_image->load_addr = image_get_load(header);
|
||||
spl_image->entry_point = image_get_ep(header);
|
||||
spl_image->size = image_get_data_size(header);
|
||||
} else {
|
||||
spl_image->entry_point = image_get_ep(header);
|
||||
/* Load including the header */
|
||||
spl_image->load_addr = image_get_load(header) -
|
||||
header_size;
|
||||
spl_image->size = image_get_data_size(header) +
|
||||
header_size;
|
||||
}
|
||||
|
||||
#ifdef CONFIG_SPL_LEGACY_IMAGE_CRC_CHECK
|
||||
/* store uImage data length and CRC to check later */
|
||||
spl_image->dcrc_data = image_get_load(header);
|
||||
spl_image->dcrc_length = image_get_data_size(header);
|
||||
spl_image->dcrc = image_get_dcrc(header);
|
||||
#endif
|
||||
|
||||
spl_image->os = image_get_os(header);
|
||||
spl_image->name = image_get_name(header);
|
||||
debug(SPL_TPL_PROMPT
|
||||
"payload image: %32s load addr: 0x%lx size: %d\n",
|
||||
spl_image->name, spl_image->load_addr, spl_image->size);
|
||||
|
||||
return 0;
|
||||
}
|
Loading…
Reference in New Issue
Block a user