[U-Boot-Users] [PATCH 3/6] [new uImage] Add gen_get_image() routine

Kumar Gala galak at kernel.crashing.org
Wed Feb 20 20:19:39 CET 2008


> +/**
> + * gen_get_image - get image from special storage (if necessary)
> + * @img_addr: image start address
> + *
> + * gen_get_image() checks if provided image start adddress is located
> + * in a dataflash storage. If so, image is moved to a system RAM  
> memory.
> + *
> + * returns:
> + *     image start address after possible relocation from special  
> storage
> + */
> +ulong gen_get_image (ulong img_addr)
> +{
> +	ulong ram_addr, h_size, d_size;
> +
> +	h_size = image_get_header_size ();
> +#if defined(CONFIG_FIT)
> +	if (sizeof(struct fdt_header) > h_size)
> +		h_size = sizeof(struct fdt_header);
> +#endif
> +
> +#ifdef CONFIG_HAS_DATAFLASH
> +	if (addr_dataflash (img_addr)){
> +		ram_addr = CFG_LOAD_ADDR;
> +		debug ("   Reading image header from dataflash address "
> +			"%08lx to RAM address %08lx\n", img_addr, ram_addr);
> +		read_dataflash (img_addr, h_size, (char *)ram_addr);
> +	} else
> +#endif
> +	ram_addr = img_addr;

can we not early out at this point?

> +
> +	switch (gen_image_get_format ((void *)ram_addr)) {
> +	case IMAGE_FORMAT_LEGACY:
> +		d_size = image_get_data_size ((image_header_t *)ram_addr);
> +		debug ("   Legacy format image found at 0x%08lx, size 0x%08lx\n",
> +				ram_addr, d_size);
> +		break;
> +#if defined(CONFIG_FIT)
> +	case IMAGE_FORMAT_FIT:
> +		d_size = fdt_totalsize((void *)ram_addr) - h_size;
> +		debug ("   FIT/FDT format image found at 0x%08lx, size 0x%08lx\n",
> +				ram_addr, d_size);
> +
> +		break;
> +#endif
> +	default:
> +		printf ("   No valid image found at 0x%08lx\n", img_addr);
> +		return ram_addr;
> +	}
> +
> +#ifdef CONFIG_HAS_DATAFLASH
> +	if (addr_dataflash (img_addr)) {
> +		debug ("   Reading image remaining data from dataflash address "
> +			"%08lx to RAM address %08lx\n", img_addr + h_size,
> +			ram_addr + h_size);
> +
> +		read_dataflash (img_addr + h_size, d_size,
> +				(char *)(ram_addr + h_size));
> +	}
> +#endif
> +
> +	return ram_addr;
> +}




More information about the U-Boot mailing list