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_)FRAMEWORK) += spl.o
 | 
				
			||||||
obj-$(CONFIG_$(SPL_TPL_)BOOTROM_SUPPORT) += spl_bootrom.o
 | 
					obj-$(CONFIG_$(SPL_TPL_)BOOTROM_SUPPORT) += spl_bootrom.o
 | 
				
			||||||
obj-$(CONFIG_$(SPL_TPL_)LOAD_FIT) += spl_fit.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_)NOR_SUPPORT) += spl_nor.o
 | 
				
			||||||
obj-$(CONFIG_$(SPL_TPL_)XIP_SUPPORT) += spl_xip.o
 | 
					obj-$(CONFIG_$(SPL_TPL_)XIP_SUPPORT) += spl_xip.o
 | 
				
			||||||
obj-$(CONFIG_$(SPL_TPL_)YMODEM_SUPPORT) += spl_ymodem.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
 | 
					#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,
 | 
					int spl_parse_image_header(struct spl_image_info *spl_image,
 | 
				
			||||||
			   const struct image_header *header)
 | 
								   const struct image_header *header)
 | 
				
			||||||
{
 | 
					{
 | 
				
			||||||
| 
						 | 
					@ -264,51 +272,11 @@ int spl_parse_image_header(struct spl_image_info *spl_image,
 | 
				
			||||||
		return ret;
 | 
							return ret;
 | 
				
			||||||
#endif
 | 
					#endif
 | 
				
			||||||
	if (image_get_magic(header) == IH_MAGIC) {
 | 
						if (image_get_magic(header) == IH_MAGIC) {
 | 
				
			||||||
#ifdef CONFIG_SPL_LEGACY_IMAGE_SUPPORT
 | 
							int ret;
 | 
				
			||||||
		u32 header_size = sizeof(struct image_header);
 | 
					 | 
				
			||||||
 | 
					
 | 
				
			||||||
#ifdef CONFIG_SPL_LEGACY_IMAGE_CRC_CHECK
 | 
							ret = spl_parse_legacy_header(spl_image, header);
 | 
				
			||||||
		/* check uImage header CRC */
 | 
							if (ret)
 | 
				
			||||||
		if (!image_check_hcrc(header)) {
 | 
								return ret;
 | 
				
			||||||
			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
 | 
					 | 
				
			||||||
	} else {
 | 
						} else {
 | 
				
			||||||
#ifdef CONFIG_SPL_PANIC_ON_RAW_IMAGE
 | 
					#ifdef CONFIG_SPL_PANIC_ON_RAW_IMAGE
 | 
				
			||||||
		/*
 | 
							/*
 | 
				
			||||||
| 
						 | 
					
 | 
				
			||||||
| 
						 | 
					@ -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