summaryrefslogtreecommitdiffstats
path: root/arch/arm/include
diff options
context:
space:
mode:
authorNicolas Pitre <nico@linaro.org>2016-02-02 00:14:53 +0100
committerRussell King <rmk+kernel@arm.linux.org.uk>2016-02-16 17:17:49 +0000
commitd78114554939aec0344b494e759d0679224562db (patch)
treea0596003347a6680cb863be11240962d12a82221 /arch/arm/include
parentdb57f88e4ccbbb6dd194b3f3088b3dc1987db423 (diff)
downloadop-kernel-dev-d78114554939aec0344b494e759d0679224562db.zip
op-kernel-dev-d78114554939aec0344b494e759d0679224562db.tar.gz
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>
Diffstat (limited to 'arch/arm/include')
-rw-r--r--arch/arm/include/asm/memory.h8
1 files changed, 8 insertions, 0 deletions
diff --git a/arch/arm/include/asm/memory.h b/arch/arm/include/asm/memory.h
index 49bf6b1..ebdaaf7 100644
--- a/arch/arm/include/asm/memory.h
+++ b/arch/arm/include/asm/memory.h
@@ -134,6 +134,14 @@
*/
#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__
/*
OpenPOWER on IntegriCloud