ARM: dove: convert to DT irqchip and clocksource
authorSebastian Hesselbarth <sebastian.hesselbarth@gmail.com>
Tue, 2 Jul 2013 11:03:40 +0000 (13:03 +0200)
committerJason Cooper <jason@lakedaemon.net>
Thu, 25 Jul 2013 21:07:14 +0000 (21:07 +0000)
With recent support for true irqchip and clocksource drivers for Orion
SoCs, now make use of it on DT enabled Dove boards.

Signed-off-by: Sebastian Hesselbarth <sebastian.hesselbarth@gmail.com>
Signed-off-by: Jason Cooper <jason@lakedaemon.net>
arch/arm/mach-dove/Kconfig
arch/arm/mach-dove/Makefile
arch/arm/mach-dove/board-dt.c

index dff7b2fd4e203cb14a74bb93f4da12eb7133a033..0bc7cdf8cf469d760ac384a4aa5ae46fa7605270 100644 (file)
@@ -23,6 +23,8 @@ config MACH_CM_A510
 config MACH_DOVE_DT
        bool "Marvell Dove Flattened Device Tree"
        select DOVE_CLK
+       select ORION_IRQCHIP
+       select ORION_TIMER
        select REGULATOR
        select REGULATOR_FIXED_VOLTAGE
        select USE_OF
index 4d9d2ffc45358a5ca411f7b9dba7d9f06936a191..cbc5c06187883988e012a282d67e359d17b624c2 100644 (file)
@@ -1,5 +1,5 @@
-obj-y                          += common.o irq.o
-obj-$(CONFIG_DOVE_LEGACY)      += mpp.o
+obj-y                          += common.o
+obj-$(CONFIG_DOVE_LEGACY)      += irq.o mpp.o
 obj-$(CONFIG_PCI)              += pcie.o
 obj-$(CONFIG_MACH_DOVE_DB)     += dove-db-setup.o
 obj-$(CONFIG_MACH_DOVE_DT)     += board-dt.o
index b5ccc1c0556387489a787834524118e6d849d296..49f72a848423a62d3ff44943cfae84751aee09c0 100644 (file)
 
 #include <linux/init.h>
 #include <linux/clk-provider.h>
+#include <linux/clocksource.h>
+#include <linux/irqchip.h>
 #include <linux/of.h>
 #include <linux/of_platform.h>
 #include <linux/platform_data/usb-ehci-orion.h>
 #include <asm/hardware/cache-tauros2.h>
 #include <asm/mach/arch.h>
+#include <mach/dove.h>
 #include <mach/pm.h>
 #include <plat/common.h>
 #include <plat/irq.h>
@@ -42,10 +45,17 @@ static void __init dove_legacy_clk_init(void)
                         of_clk_get_from_provider(&clkspec));
 }
 
-static void __init dove_of_clk_init(void)
+static void __init dove_dt_time_init(void)
 {
        of_clk_init(NULL);
-       dove_legacy_clk_init();
+       clocksource_of_init();
+}
+
+static void __init dove_dt_init_early(void)
+{
+       mvebu_mbus_init("marvell,dove-mbus",
+                       BRIDGE_WINS_BASE, BRIDGE_WINS_SZ,
+                       DOVE_MC_WINS_BASE, DOVE_MC_WINS_SZ);
 }
 
 static void __init dove_dt_init(void)
@@ -57,8 +67,8 @@ static void __init dove_dt_init(void)
 #endif
        dove_setup_cpu_wins();
 
-       /* Setup root of clk tree */
-       dove_of_clk_init();
+       /* Setup clocks for legacy devices */
+       dove_legacy_clk_init();
 
        /* Internal devices not ported to DT yet */
        dove_pcie_init(1, 1);
@@ -73,9 +83,8 @@ static const char * const dove_dt_board_compat[] = {
 
 DT_MACHINE_START(DOVE_DT, "Marvell Dove (Flattened Device Tree)")
        .map_io         = dove_map_io,
-       .init_early     = dove_init_early,
-       .init_irq       = orion_dt_init_irq,
-       .init_time      = dove_timer_init,
+       .init_early     = dove_dt_init_early,
+       .init_time      = dove_dt_time_init,
        .init_machine   = dove_dt_init,
        .restart        = dove_restart,
        .dt_compat      = dove_dt_board_compat,