summaryrefslogtreecommitdiffstats
path: root/arch
diff options
context:
space:
mode:
authorPhil Elwell <phil@raspberrypi.org>2017-05-09 10:04:30 +0100
committerEric Anholt <eric@anholt.net>2017-05-15 15:05:29 -0700
commitb0804ed0cadd7e38d94d2f15cdcc0d9695818856 (patch)
treeff7729baccba888f5df1eda8142d8d965d2585c9 /arch
parent2ea659a9ef488125eb46da6eb571de5eae5c43f6 (diff)
downloadlinux-b0804ed0cadd7e38d94d2f15cdcc0d9695818856.tar.gz
linux-b0804ed0cadd7e38d94d2f15cdcc0d9695818856.tar.bz2
linux-b0804ed0cadd7e38d94d2f15cdcc0d9695818856.zip
ARM: dts: bcm283x: Reserve first page for firmware
The Raspberry Pi startup stub files for multi-core BCM283X processors make the secondary CPUs spin until the corresponding mailbox is written. These stubs are loaded at physical address 0x00000xxx (as seen by the ARMs), but this page will be reused by the kernel unless it is explicitly reserved, causing the waiting cores to execute random code. Use the /memreserve/ Device Tree directive to mark the first page as off-limits to the kernel. See: https://github.com/raspberrypi/linux/issues/1989 Signed-off-by: Phil Elwell <phil@raspberrypi.org> Signed-off-by: Eric Anholt <eric@anholt.net> Reviewed-by: Eric Anholt <eric@anholt.net>
Diffstat (limited to 'arch')
-rw-r--r--arch/arm/boot/dts/bcm283x.dtsi5
1 files changed, 5 insertions, 0 deletions
diff --git a/arch/arm/boot/dts/bcm283x.dtsi b/arch/arm/boot/dts/bcm283x.dtsi
index 35cea3fcaf5c..1ac7c0dc6577 100644
--- a/arch/arm/boot/dts/bcm283x.dtsi
+++ b/arch/arm/boot/dts/bcm283x.dtsi
@@ -3,6 +3,11 @@
#include <dt-bindings/clock/bcm2835-aux.h>
#include <dt-bindings/gpio/gpio.h>
+/* firmware-provided startup stubs live here, where the secondary CPUs are
+ * spinning.
+ */
+/memreserve/ 0x00000000 0x00001000;
+
/* This include file covers the common peripherals and configuration between
* bcm2835 and bcm2836 implementations, leaving the CPU configuration to
* bcm2835.dtsi and bcm2836.dtsi.