ARM: nomadik: convert all clocks except timer to dt
authorLinus Walleij <linus.walleij@linaro.org>
Tue, 16 Apr 2013 19:38:29 +0000 (21:38 +0200)
committerLinus Walleij <linus.walleij@linaro.org>
Sun, 12 May 2013 19:49:56 +0000 (21:49 +0200)
This moves all Nomadik clocks except the one used for the
timer/clocksource over to the device tree.

Acked-by: Mike Turquette <mturquette@linaro.org>
Signed-off-by: Linus Walleij <linus.walleij@linaro.org>
Documentation/devicetree/bindings/arm/ste-nomadik.txt
arch/arm/boot/dts/ste-nomadik-stn8815.dtsi
arch/arm/mach-nomadik/cpu-8815.c
drivers/clk/clk-nomadik.c

index 19bca04b81c91c3dab487177f88a3057dd991f92..6256ec31666d51cb833c5d78ecfcf30293cefed2 100644 (file)
@@ -3,6 +3,11 @@ ST-Ericsson Nomadik Device Tree Bindings
 For various board the "board" node may contain specific properties
 that pertain to this particular board, such as board-specific GPIOs.
 
+Required root node property: src
+- Nomadik System and reset controller used for basic chip control, clock
+  and reset line control.
+- compatible: must be "stericsson,nomadik,src"
+
 Boards with the Nomadik SoC include:
 
 S8815 "MiniKit" manufactured by Calao Systems:
index 4a4aab395141b97b0f13e834896c76da13c8a977..f0df9482cb6f4d6f79999766bc21e7215cf0acc1 100644 (file)
@@ -45,6 +45,7 @@
                gpio-controller;
                #gpio-cells = <2>;
                gpio-bank = <0>;
+               clocks = <&pclk>;
        };
 
        gpio1: gpio@101e5000 {
@@ -57,6 +58,7 @@
                gpio-controller;
                #gpio-cells = <2>;
                gpio-bank = <1>;
+               clocks = <&pclk>;
        };
 
        gpio2: gpio@101e6000 {
@@ -69,6 +71,7 @@
                gpio-controller;
                #gpio-cells = <2>;
                gpio-bank = <2>;
+               clocks = <&pclk>;
        };
 
        gpio3: gpio@101e7000 {
                gpio-controller;
                #gpio-cells = <2>;
                gpio-bank = <3>;
+               clocks = <&pclk>;
        };
 
        pinctrl {
                compatible = "stericsson,nmk-pinctrl-stn8815";
        };
 
+       src: src@101e0000 {
+               compatible = "stericsson,nomadik-src";
+               reg = <0x101e0000 0x1000>;
+               clocks {
+                       /*
+                        * Dummy clock for primecells
+                        */
+                       pclk: pclk@0 {
+                               #clock-cells = <0>;
+                               compatible = "fixed-clock";
+                               clock-frequency = <2400000>;
+                       };
+                       /*
+                        * The 2.4 MHz TIMCLK reference clock is active at
+                        * boot time, this is actually the MXTALCLK @19.2 MHz
+                        * divided by 8. This clock is used by the timers and
+                        * watchdog. See page 105 ff.
+                        */
+                       timclk: timclk@2.4M {
+                               #clock-cells = <0>;
+                               compatible = "fixed-clock";
+                               clock-frequency = <2400000>;
+                       };
+                       /*
+                        * At boot time, PLL2 is set to generate a set of
+                        * fixed clocks, one of them is CLK48, the 48 MHz
+                        * clock, routed to the UART, MMC/SD, I2C, IrDA,
+                        * USB and SSP blocks.
+                        */
+                       clk48: clk48@48M {
+                               #clock-cells = <0>;
+                               compatible = "fixed-clock";
+                               clock-frequency = <48000000>;
+                       };
+               };
+       };
+
        /* A NAND flash of 128 MiB */
        fsmc: flash@40000000 {
                compatible = "stericsson,fsmc-nand";
                        <0x41000000 0x2000>,    /* NAND Base ADDR */
                        <0x40800000 0x2000>;    /* NAND Base CMD */
                reg-names = "fsmc_regs", "nand_data", "nand_addr", "nand_cmd";
+               clocks = <&pclk>;
                status = "okay";
 
                partition@0 {
                        reg = <0x101fd000 0x1000>;
                        interrupt-parent = <&vica>;
                        interrupts = <12>;
+                       clocks = <&clk48>, <&pclk>;
+                       clock-names = "uartclk", "apb_pclk";
                };
 
                uart1: uart@101fb000 {
                        reg = <0x101fb000 0x1000>;
                        interrupt-parent = <&vica>;
                        interrupts = <17>;
+                       clocks = <&clk48>, <&pclk>;
+                       clock-names = "uartclk", "apb_pclk";
                };
 
                uart2: uart@101f2000 {
                        reg = <0x101f2000 0x1000>;
                        interrupt-parent = <&vica>;
                        interrupts = <28>;
+                       clocks = <&clk48>, <&pclk>;
+                       clock-names = "uartclk", "apb_pclk";
                        status = "disabled";
                };
 
                rng: rng@101b0000 {
                        compatible = "arm,primecell";
                        reg = <0x101b0000 0x1000>;
+                       clocks = <&clk48>, <&pclk>;
+                       clock-names = "rng", "apb_pclk";
                };
 
                rtc: rtc@101e8000 {
                        compatible = "arm,pl031", "arm,primecell";
                        reg = <0x101e8000 0x1000>;
+                       clocks = <&pclk>;
+                       clock-names = "apb_pclk";
                        interrupt-parent = <&vica>;
                        interrupts = <10>;
                };
                mmcsd: sdi@101f6000 {
                        compatible = "arm,pl18x", "arm,primecell";
                        reg = <0x101f6000 0x1000>;
+                       clocks = <&clk48>, <&pclk>;
+                       clock-names = "mclk", "apb_pclk";
                        interrupt-parent = <&vica>;
                        interrupts = <22>;
                        max-frequency = <48000000>;
index 59f6ff5c9baeb843d189dcbb2e9f4a6534ee4091..0e2c5e0cd65e9562efd556857992f01f263c44d1 100644 (file)
@@ -280,28 +280,12 @@ device_initcall(cpu8815_mmcsd_init);
 
 /* These are mostly to get the right device names for the clock lookups */
 static struct of_dev_auxdata cpu8815_auxdata_lookup[] __initdata = {
-       OF_DEV_AUXDATA("st,nomadik-gpio", NOMADIK_GPIO0_BASE,
-               "gpio.0", NULL),
-       OF_DEV_AUXDATA("st,nomadik-gpio", NOMADIK_GPIO1_BASE,
-               "gpio.1", NULL),
-       OF_DEV_AUXDATA("st,nomadik-gpio", NOMADIK_GPIO2_BASE,
-               "gpio.2", NULL),
-       OF_DEV_AUXDATA("st,nomadik-gpio", NOMADIK_GPIO3_BASE,
-               "gpio.3", NULL),
        OF_DEV_AUXDATA("stericsson,nmk-pinctrl-stn8815", 0,
                "pinctrl-stn8815", NULL),
-       OF_DEV_AUXDATA("arm,primecell", NOMADIK_UART0_BASE,
-               "uart0", NULL),
-       OF_DEV_AUXDATA("arm,primecell", NOMADIK_UART1_BASE,
-               "uart1", NULL),
-       OF_DEV_AUXDATA("arm,primecell", NOMADIK_RNG_BASE,
-               "rng", NULL),
-       OF_DEV_AUXDATA("arm,primecell", NOMADIK_RTC_BASE,
-               "rtc-pl031", NULL),
        OF_DEV_AUXDATA("stericsson,fsmc-nand", NOMADIK_FSMC_BASE,
-               "fsmc-nand", &cpu8815_nand_data),
+               NULL, &cpu8815_nand_data),
        OF_DEV_AUXDATA("arm,primecell", NOMADIK_SDI_BASE,
-               "mmci", &mmcsd_plat_data),
+               NULL, &mmcsd_plat_data),
        { /* sentinel */ },
 };
 
index 6b4c70f7d23d4dfa99b5e566185e9e20b17397bf..19f197ccf28deebcc9c24990e904f9310d8b9faf 100644 (file)
@@ -3,24 +3,24 @@
 #include <linux/err.h>
 #include <linux/io.h>
 #include <linux/clk-provider.h>
+#include <linux/of.h>
 
 /*
  * The Nomadik clock tree is described in the STN8815A12 DB V4.2
  * reference manual for the chip, page 94 ff.
  */
 
+static const __initconst struct of_device_id cpu8815_clk_match[] = {
+       { .compatible = "fixed-clock", .data = of_fixed_clk_setup, },
+       { /* sentinel */ }
+};
+
 void __init nomadik_clk_init(void)
 {
        struct clk *clk;
 
        clk = clk_register_fixed_rate(NULL, "apb_pclk", NULL, CLK_IS_ROOT, 0);
        clk_register_clkdev(clk, "apb_pclk", NULL);
-       clk_register_clkdev(clk, NULL, "gpio.0");
-       clk_register_clkdev(clk, NULL, "gpio.1");
-       clk_register_clkdev(clk, NULL, "gpio.2");
-       clk_register_clkdev(clk, NULL, "gpio.3");
-       clk_register_clkdev(clk, NULL, "rng");
-       clk_register_clkdev(clk, NULL, "fsmc-nand");
 
        /*
         * The 2.4 MHz TIMCLK reference clock is active at boot time, this is
@@ -32,17 +32,5 @@ void __init nomadik_clk_init(void)
        clk_register_clkdev(clk, NULL, "mtu0");
        clk_register_clkdev(clk, NULL, "mtu1");
 
-       /*
-        * At boot time, PLL2 is set to generate a set of fixed clocks,
-        * one of them is CLK48, the 48 MHz clock, routed to the UART, MMC/SD
-        * I2C, IrDA, USB and SSP blocks.
-        */
-       clk = clk_register_fixed_rate(NULL, "CLK48", NULL, CLK_IS_ROOT,
-                                     48000000);
-       clk_register_clkdev(clk, NULL, "uart0");
-       clk_register_clkdev(clk, NULL, "uart1");
-       clk_register_clkdev(clk, NULL, "mmci");
-       clk_register_clkdev(clk, NULL, "ssp");
-       clk_register_clkdev(clk, NULL, "nmk-i2c.0");
-       clk_register_clkdev(clk, NULL, "nmk-i2c.1");
+       of_clk_init(cpu8815_clk_match);
 }