On Fri, 14 Oct 2011, Stephen Warren wrote: > Nicolas Pitre wrote at Friday, October 14, 2011 2:06 PM: > > 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:-) So what? The whole idea of a kernel that can be loaded anywhere is to _not_ have its load address packaged into it. The fact that you need a separate packaging step just for the specification of that address is rather silly. > > 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/ By all means, please push your patch upstream and free us from this u-Boot misery! > 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? No it is not. We know where the decompressed kernel will end up relative to the start of RAM, so it is always safe to simply load the uImage there. Better yet is to load it with an additional offset corresponding to the decompressed kernel size (plus some small gap) in order to allow the decompressor skip the relocation step. This is all trivial to determine. > 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. FRom my clone of the u-Boot repo: $ git grep -l zImage README arch/arm/cpu/ixp/npe/include/IxTimeSyncAcc.h arch/sh/lib/zimageboot.c arch/x86/include/asm/zimage.h arch/x86/lib/zimage.c doc/README.mx35pdk include/configs/apollon.h include/configs/mpc7448hpc2.h include/configs/mpr2.h include/configs/ms7720se.h include/configs/pxa255_idp.h include/configs/trizepsiv.h Even the name of some of those files clearly hints zImage support. In any case, loading zImage should be even simpler than loading uImage. It is the same as loading uImage except that you just have to skip the checking and relocating steps. Nicolas -- 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