Ver código fonte

ARM: zynq: Reserve not DMAable space in front of the kernel

Reserve space from 0x0 - __pa(swapper_pg_dir),
if kernel is loaded from 0, which is not DMAable.
It is causing problem with MMC driver and others
which want to add dma buffers to this space.

Signed-off-by: Michal Simek <michal.simek@xilinx.com>
Signed-off-by: Kevin Hilman <khilman@linaro.org>
Michal Simek 11 anos atrás
pai
commit
46f5b96085
1 arquivos alterados com 14 adições e 0 exclusões
  1. 14 0
      arch/arm/mach-zynq/common.c

+ 14 - 0
arch/arm/mach-zynq/common.c

@@ -25,6 +25,7 @@
 #include <linux/of_irq.h>
 #include <linux/of_irq.h>
 #include <linux/of_platform.h>
 #include <linux/of_platform.h>
 #include <linux/of.h>
 #include <linux/of.h>
+#include <linux/memblock.h>
 #include <linux/irqchip.h>
 #include <linux/irqchip.h>
 #include <linux/irqchip/arm-gic.h>
 #include <linux/irqchip/arm-gic.h>
 
 
@@ -41,6 +42,18 @@
 
 
 void __iomem *zynq_scu_base;
 void __iomem *zynq_scu_base;
 
 
+/**
+ * zynq_memory_init - Initialize special memory
+ *
+ * We need to stop things allocating the low memory as DMA can't work in
+ * the 1st 512K of memory.
+ */
+static void __init zynq_memory_init(void)
+{
+	if (!__pa(PAGE_OFFSET))
+		memblock_reserve(__pa(PAGE_OFFSET), __pa(swapper_pg_dir));
+}
+
 static struct platform_device zynq_cpuidle_device = {
 static struct platform_device zynq_cpuidle_device = {
 	.name = "cpuidle-zynq",
 	.name = "cpuidle-zynq",
 };
 };
@@ -117,5 +130,6 @@ DT_MACHINE_START(XILINX_EP107, "Xilinx Zynq Platform")
 	.init_machine	= zynq_init_machine,
 	.init_machine	= zynq_init_machine,
 	.init_time	= zynq_timer_init,
 	.init_time	= zynq_timer_init,
 	.dt_compat	= zynq_dt_match,
 	.dt_compat	= zynq_dt_match,
+	.reserve	= zynq_memory_init,
 	.restart	= zynq_system_reset,
 	.restart	= zynq_system_reset,
 MACHINE_END
 MACHINE_END