On Fri, Oct 14, 2011 at 09:44:34AM -0700, Olof Johansson wrote: > That is likely to get messy. > > Seems like there could be some use for a (silent) option for a > platform to indicate that it can do XIP kernel (or zImage), and thus > not able to use AUTO_ZRELADDR (or other options that require rewriting > text segment of zImage or kernel). It's not that. The options are: AUTO_ZRELADDR=n ZBOOT_ROM=n => fixed address for decompressed kernel image to be decompressed to from zreladdr make variable, decompressor can be loaded to any RAM address. AUTO_ZRELADDR=y ZBOOT_ROM=n => address for decompressed kernel calculated from location of zImage in RAM, decompressor must be loaded to the correct place in RAM and must always copy itself out of the way prior to decompressing. AUTO_ZRELADDR=n ZBOOT_ROM=y => fixed address for decompressed kernel image to be decompressed to from zreladdr make variable, decompressor can be loaded to any RAM address which doesn't overlap its BSS segment, or decompressor programmed into read-only memory at the address to which it was compiled. AUTO_ZRELADDR=y ZBOOT_ROM=y => invalid (think about it - this results in a zImage which is built to be run from read-only memory, and try to write the decompressed image into that read-only memory.) This has nothing to do with XIP or not - XIP is a completely separate story, and if you're building an XIP kernel you're not using the decompressor (so AUTO_ZRELADDR and ZBOOT_ROM don't even feature.) Neither does the dynamic code patching stuff like ARM_PATCH_PHYS_VIRT. ARM_PATCH_PHYS_VIRT has no bearing on AUTO_ZRELADDR or ZBOOT_ROM; that is a property of the decompressed kernel image itself, and while your decompressor may restrict where it can decompress the kernel image to, the decompressed image itself remains free of those dependencies (and eg, can be turned into a uImage with the appropriate load address for other platforms.) As I've said in the past, what I'd _like_ to see is that ARM_PATCH_PHYS_VIRT be enabled for everything irrespective of any other configuration, and we're just left with AUTO_ZRELADDR / ZBOOT_ROM to worry about. The overhead from the P:V patching is soo small that it's not really worth even having the option in the general case - the only time when P:V patching doesn't work is with non-linear translations found on some sparsemem platforms. 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. -- 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