ARM: 8512/1: proc-v7.S: Adjust stack address when XIP_KERNEL
authorNicolas Pitre <nico@linaro.org>
Mon, 1 Feb 2016 23:14:53 +0000 (00:14 +0100)
committerRussell King <rmk+kernel@arm.linux.org.uk>
Tue, 16 Feb 2016 17:17:49 +0000 (17:17 +0000)
When XIP_KERNEL is enabled, the virt to phys address translation for RAM
is not the same as the virt to phys address translation for .text.
The only way to know where physical RAM is located is to use
PLAT_PHYS_OFFSET.
The MACRO will be useful for other places where there is a similar problem.

Signed-off-by: Nicolas Pitre <nico@linaro.org>
Signed-off-by: Chris Brandt <chris.brandt@renesas.com>
Signed-off-by: Russell King <rmk+kernel@arm.linux.org.uk>
arch/arm/include/asm/memory.h
arch/arm/mm/proc-v7.S

index 49bf6b1e2177d6dc049baf014dc42a3971f6b6b0..ebdaaf7dd19f4b3bdd39169524ed70ee4caa1c34 100644 (file)
  */
 #define PLAT_PHYS_OFFSET       UL(CONFIG_PHYS_OFFSET)
 
+#ifdef CONFIG_XIP_KERNEL
+#define PHYS_OFFSET_FIXUP \
+       ( XIP_VIRT_ADDR(CONFIG_XIP_PHYS_ADDR) - PAGE_OFFSET + \
+         PLAT_PHYS_OFFSET - CONFIG_XIP_PHYS_ADDR )
+#else
+#define PHYS_OFFSET_FIXUP 0
+#endif
+
 #ifndef __ASSEMBLY__
 
 /*
index 0f92d575a3040b53f6584759b95a0bd1217ea3c2..1595fb29ec12d2a664c3a0df7afa06d5b2514496 100644 (file)
@@ -487,7 +487,7 @@ __errata_finish:
 
        .align  2
 __v7_setup_stack_ptr:
-       .word   __v7_setup_stack - .
+       .word   __v7_setup_stack - . + PHYS_OFFSET_FIXUP
 ENDPROC(__v7_setup)
 
        .bss