aboutsummaryrefslogtreecommitdiffstats
diff options
context:
space:
mode:
authorNicolas Pitre <nico@linaro.org>2016-02-01 18:14:53 -0500
committerRussell King <rmk+kernel@arm.linux.org.uk>2016-02-16 12:17:49 -0500
commitd78114554939aec0344b494e759d0679224562db (patch)
treea0596003347a6680cb863be11240962d12a82221
parentdb57f88e4ccbbb6dd194b3f3088b3dc1987db423 (diff)
ARM: 8512/1: proc-v7.S: Adjust stack address when XIP_KERNEL
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>
-rw-r--r--arch/arm/include/asm/memory.h8
-rw-r--r--arch/arm/mm/proc-v7.S2
2 files changed, 9 insertions, 1 deletions
diff --git a/arch/arm/include/asm/memory.h b/arch/arm/include/asm/memory.h
index 49bf6b1e2177..ebdaaf7dd19f 100644
--- a/arch/arm/include/asm/memory.h
+++ b/arch/arm/include/asm/memory.h
@@ -134,6 +134,14 @@
134 */ 134 */
135#define PLAT_PHYS_OFFSET UL(CONFIG_PHYS_OFFSET) 135#define PLAT_PHYS_OFFSET UL(CONFIG_PHYS_OFFSET)
136 136
137#ifdef CONFIG_XIP_KERNEL
138#define PHYS_OFFSET_FIXUP \
139 ( XIP_VIRT_ADDR(CONFIG_XIP_PHYS_ADDR) - PAGE_OFFSET + \
140 PLAT_PHYS_OFFSET - CONFIG_XIP_PHYS_ADDR )
141#else
142#define PHYS_OFFSET_FIXUP 0
143#endif
144
137#ifndef __ASSEMBLY__ 145#ifndef __ASSEMBLY__
138 146
139/* 147/*
diff --git a/arch/arm/mm/proc-v7.S b/arch/arm/mm/proc-v7.S
index 0f92d575a304..1595fb29ec12 100644
--- a/arch/arm/mm/proc-v7.S
+++ b/arch/arm/mm/proc-v7.S
@@ -487,7 +487,7 @@ __errata_finish:
487 487
488 .align 2 488 .align 2
489__v7_setup_stack_ptr: 489__v7_setup_stack_ptr:
490 .word __v7_setup_stack - . 490 .word __v7_setup_stack - . + PHYS_OFFSET_FIXUP
491ENDPROC(__v7_setup) 491ENDPROC(__v7_setup)
492 492
493 .bss 493 .bss