ARM: integrator: move flash registration to device tree
authorLinus Walleij <linus.walleij@linaro.org>
Tue, 26 Jan 2016 10:09:22 +0000 (11:09 +0100)
committerLinus Walleij <linus.walleij@linaro.org>
Mon, 4 Apr 2016 08:33:16 +0000 (10:33 +0200)
The flash on the Integrator was already defined by the device
tree, but VPP control and flash protection was in the
boardfiles. Simply add the compatible string
"arm,versatile-flash" and the special add-on code for flash
programming voltage and protection kicks in in the MTD
layer.

Remove the board file code and augment the device tree in
one go for seamless transition.

Cc: Grant Likely <grant.likely@linaro.org>
Cc: Rob Herring <robh@kernel.org>
Cc: Arnd Bergmann <arnd@arndb.de>
Signed-off-by: Linus Walleij <linus.walleij@linaro.org>
arch/arm/boot/dts/integrator.dtsi
arch/arm/mach-integrator/integrator_ap.c
arch/arm/mach-integrator/integrator_cp.c

index b82f0e6d9a637936f1d6ff150a770687cfca0efb..6fe0dd1d3541361538bf9c6f1d52ff99f46ac655 100644 (file)
@@ -52,8 +52,9 @@
        };
 
        flash@24000000 {
-               compatible = "cfi-flash";
+               compatible = "arm,versatile-flash", "cfi-flash";
                reg = <0x24000000 0x02000000>;
+               bank-width = <4>;
        };
 
        fpga {
index 5b0e363fe5ba525dcf05af4a2cf28d8a20d62c8d..2b118f20c62c6b9c86cd8b290307a4ab080be4da 100644 (file)
@@ -29,7 +29,6 @@
 #include <linux/amba/kmi.h>
 #include <linux/io.h>
 #include <linux/irqchip.h>
-#include <linux/mtd/physmap.h>
 #include <linux/platform_data/clk-integrator.h>
 #include <linux/of_irq.h>
 #include <linux/of_address.h>
@@ -146,65 +145,6 @@ static int __init irq_syscore_init(void)
 
 device_initcall(irq_syscore_init);
 
-/*
- * Flash handling.
- */
-static int ap_flash_init(struct platform_device *dev)
-{
-       u32 tmp;
-
-       writel(INTEGRATOR_SC_CTRL_nFLVPPEN | INTEGRATOR_SC_CTRL_nFLWP,
-              ap_syscon_base + INTEGRATOR_SC_CTRLC_OFFSET);
-
-       tmp = readl(ebi_base + INTEGRATOR_EBI_CSR1_OFFSET) |
-               INTEGRATOR_EBI_WRITE_ENABLE;
-       writel(tmp, ebi_base + INTEGRATOR_EBI_CSR1_OFFSET);
-
-       if (!(readl(ebi_base + INTEGRATOR_EBI_CSR1_OFFSET)
-             & INTEGRATOR_EBI_WRITE_ENABLE)) {
-               writel(0xa05f, ebi_base + INTEGRATOR_EBI_LOCK_OFFSET);
-               writel(tmp, ebi_base + INTEGRATOR_EBI_CSR1_OFFSET);
-               writel(0, ebi_base + INTEGRATOR_EBI_LOCK_OFFSET);
-       }
-       return 0;
-}
-
-static void ap_flash_exit(struct platform_device *dev)
-{
-       u32 tmp;
-
-       writel(INTEGRATOR_SC_CTRL_nFLVPPEN | INTEGRATOR_SC_CTRL_nFLWP,
-              ap_syscon_base + INTEGRATOR_SC_CTRLC_OFFSET);
-
-       tmp = readl(ebi_base + INTEGRATOR_EBI_CSR1_OFFSET) &
-               ~INTEGRATOR_EBI_WRITE_ENABLE;
-       writel(tmp, ebi_base + INTEGRATOR_EBI_CSR1_OFFSET);
-
-       if (readl(ebi_base + INTEGRATOR_EBI_CSR1_OFFSET) &
-           INTEGRATOR_EBI_WRITE_ENABLE) {
-               writel(0xa05f, ebi_base + INTEGRATOR_EBI_LOCK_OFFSET);
-               writel(tmp, ebi_base + INTEGRATOR_EBI_CSR1_OFFSET);
-               writel(0, ebi_base + INTEGRATOR_EBI_LOCK_OFFSET);
-       }
-}
-
-static void ap_flash_set_vpp(struct platform_device *pdev, int on)
-{
-       if (on)
-               writel(INTEGRATOR_SC_CTRL_nFLVPPEN,
-                      ap_syscon_base + INTEGRATOR_SC_CTRLS_OFFSET);
-       else
-               writel(INTEGRATOR_SC_CTRL_nFLVPPEN,
-                      ap_syscon_base + INTEGRATOR_SC_CTRLC_OFFSET);
-}
-
-static struct physmap_flash_data ap_flash_data = {
-       .width          = 4,
-       .init           = ap_flash_init,
-       .exit           = ap_flash_exit,
-       .set_vpp        = ap_flash_set_vpp,
-};
-
 /*
  * For the PL010 found in the Integrator/AP some of the UART control is
  * implemented in the system controller and accessed using a callback
@@ -266,8 +206,6 @@ static struct of_dev_auxdata ap_auxdata_lookup[] __initdata = {
                "kmi0", NULL),
        OF_DEV_AUXDATA("arm,primecell", KMI1_BASE,
                "kmi1", NULL),
-       OF_DEV_AUXDATA("cfi-flash", INTEGRATOR_FLASH_BASE,
-               "physmap-flash", &ap_flash_data),
        { /* sentinel */ },
 };
 
index b5fb71a36ee63961899709af0f5332fb7ee0a062..6f6b051e81e0f74262eec601c6abf4b55203f8c4 100644 (file)
@@ -23,7 +23,6 @@
 #include <linux/io.h>
 #include <linux/irqchip.h>
 #include <linux/gfp.h>
-#include <linux/mtd/physmap.h>
 #include <linux/of_irq.h>
 #include <linux/of_address.h>
 #include <linux/of_platform.h>
 /* Base address to the CP controller */
 static void __iomem *intcp_con_base;
 
-#define INTCP_PA_FLASH_BASE            0x24000000
-
 #define INTCP_PA_CLCD_BASE             0xc0000000
 
-#define INTCP_FLASHPROG                        0x04
-#define CINTEGRATOR_FLASHPROG_FLVPPEN  (1 << 0)
-#define CINTEGRATOR_FLASHPROG_FLWREN   (1 << 1)
-
 /*
  * Logical      Physical
  * f1000000    10000000        Core module registers
@@ -107,48 +100,6 @@ static void __init intcp_map_io(void)
        iotable_init(intcp_io_desc, ARRAY_SIZE(intcp_io_desc));
 }
 
-/*
- * Flash handling.
- */
-static int intcp_flash_init(struct platform_device *dev)
-{
-       u32 val;
-
-       val = readl(intcp_con_base + INTCP_FLASHPROG);
-       val |= CINTEGRATOR_FLASHPROG_FLWREN;
-       writel(val, intcp_con_base + INTCP_FLASHPROG);
-
-       return 0;
-}
-
-static void intcp_flash_exit(struct platform_device *dev)
-{
-       u32 val;
-
-       val = readl(intcp_con_base + INTCP_FLASHPROG);
-       val &= ~(CINTEGRATOR_FLASHPROG_FLVPPEN|CINTEGRATOR_FLASHPROG_FLWREN);
-       writel(val, intcp_con_base + INTCP_FLASHPROG);
-}
-
-static void intcp_flash_set_vpp(struct platform_device *pdev, int on)
-{
-       u32 val;
-
-       val = readl(intcp_con_base + INTCP_FLASHPROG);
-       if (on)
-               val |= CINTEGRATOR_FLASHPROG_FLVPPEN;
-       else
-               val &= ~CINTEGRATOR_FLASHPROG_FLVPPEN;
-       writel(val, intcp_con_base + INTCP_FLASHPROG);
-}
-
-static struct physmap_flash_data intcp_flash_data = {
-       .width          = 4,
-       .init           = intcp_flash_init,
-       .exit           = intcp_flash_exit,
-       .set_vpp        = intcp_flash_set_vpp,
-};
-
 /*
  * It seems that the card insertion interrupt remains active after
  * we've acknowledged it.  We therefore ignore the interrupt, and
@@ -260,8 +211,6 @@ static struct of_dev_auxdata intcp_auxdata_lookup[] __initdata = {
                "aaci", &mmc_data),
        OF_DEV_AUXDATA("arm,primecell", INTCP_PA_CLCD_BASE,
                "clcd", &clcd_data),
-       OF_DEV_AUXDATA("cfi-flash", INTCP_PA_FLASH_BASE,
-               "physmap-flash", &intcp_flash_data),
        { /* sentinel */ },
 };