Nicolas Pitre wrote at Friday, October 14, 2011 2:06 PM: > On Fri, 14 Oct 2011, Russell King - ARM Linux wrote: > > > But... one thing to note is that it _is_ common to load the decompressor > > at a _different_ address to that where the kernel ultimately ends up > > residing to avoid the additional copy in the decompressor. My experience > > shows that this is quite common on the platforms I had supplied. This > > means that if we default to AUTO_ZRELADDR for !ZBOOT_ROM, we end up > > having to have developers change their uboot setups to avoid unexpected > > results. > > Currently, U-Boot insists on having a uImage with a fixed absolute load > address. This is currently provided by the zreladdr value, whether or > not AUTO_ZRELADDR is set. I consider this as a persisting uImage > limitation. Well, that value only comes from zreladdr when running U-Boot's mkimage from the kernel makefile rather than some other packaging script:-) > Either u-Boot gets fixed so it can work with plain zImage (and this > certainly will happen once the pressure from people wanting a single > kernel to work on targets with different load addresses increase. > Tegra is one such example. I proposed to solve it by adding a new image format within the uImage; "kernel-rel" rather than "kernel", where the load/entry address encoded into the uImage is specified relative to "start of SDRAM" rather than as an absolute address. This way, Tegra20 and Tegra30 will have the same layout of U-Boot location, uImage load address, kernel execute address etc. within SDRAM, but all those addresses might end up being based at physical address 0, or physical address 2G. Here's the patch I proposed: http://patchwork.ozlabs.org/patch/119017/ What are your thoughts on this? I hope it will work for multi-SoC image across vendors, although I suppose finding a common load address across a bunch of different SoC's memory layouts might be tough? I did originally briefly look into getting U-Boot to boot a zImage, but that looked like a far more invasive patch. There were rumours of some chip's custom U-Boot already having such support, but I couldn't find it, nor any evidence of such support in mainline U-Boot. > Or we create a u-Boot specific Kconfig menu for uImage options that > would be common to all architectures and kick it out from the ARM > specific makefile. This is not solving the u-Boot limitation though. > > In either cases this is a u-Boot problem that needs fixing on the u-Boot > side in the end. -- nvpublic -- To unsubscribe from this list: send the line "unsubscribe linux-tegra" in the body of a message to majordomo@xxxxxxxxxxxxxxx More majordomo info at http://vger.kernel.org/majordomo-info.html