ralink: add pinctrl driver
[openwrt/svn-archive/archive.git] / target / linux / ramips / dts / rt3352.dtsi
index 652e361ce0b6c8a22750e6f9167d3de37548c259..db38b00e6353a2f255e34dbedb6bb4a272a8bc80 100644 (file)
                watchdog@120 {
                        compatible = "ralink,rt3352-wdt", "ralink,rt2880-wdt";
                        reg = <0x120 0x10>;
+
+                       resets = <&rstctrl 8>;
+                       reset-names = "wdt";
+
+                       interrupt-parent = <&intc>;
+                       interrupts = <1>;
                };
 
                intc: intc@200 {
                memc@300 {
                        compatible = "ralink,rt3352-memc", "ralink,rt3050-memc";
                        reg = <0x300 0x100>;
+
+                       resets = <&rstctrl 20>;
+                       reset-names = "mc";
+
+                       interrupt-parent = <&intc>;
+                       interrupts = <3>;
+               };
+
+               uart@500 {
+                       compatible = "ralink,rt3352-uart", "ralink,rt2880-uart", "ns16550a";
+                       reg = <0x500 0x100>;
+
+                       resets = <&rstctrl 12>;
+                       reset-names = "uart";
+
+                       interrupt-parent = <&intc>;
+                       interrupts = <5>;
+
+                       reg-shift = <2>;
+
+                       status = "disabled";
                };
 
                gpio0: gpio@600 {
                        gpio-controller;
                        #gpio-cells = <2>;
 
+                       ralink,gpio-base = <0>;
                        ralink,num-gpios = <24>;
                        ralink,register-map = [ 00 04 08 0c
                                                20 24 28 2c
                                                30 34 ];
+                       resets = <&rstctrl 13>;
+                       reset-names = "pio";
 
-                       status = "disabled";
+                       interrupt-parent = <&intc>;
+                       interrupts = <6>;
                };
 
                gpio1: gpio@638 {
                        gpio-controller;
                        #gpio-cells = <2>;
 
+                       ralink,gpio-base = <24>;
                        ralink,num-gpios = <16>;
                        ralink,register-map = [ 00 04 08 0c
                                                10 14 18 1c
                        gpio-controller;
                        #gpio-cells = <2>;
 
+                       ralink,gpio-base = <40>;
                        ralink,num-gpios = <12>;
                        ralink,register-map = [ 00 04 08 0c
                                                10 14 18 1c
                        #address-cells = <1>;
                        #size-cells = <1>;
 
+                       resets = <&rstctrl 18>;
+                       reset-names = "spi";
+       
+                       pinctrl-names = "default";
+                       pinctrl-0 = <&spi_pins>;
+
                        status = "disabled";
                };
 
                        compatible = "ralink,rt3352-uart", "ralink,rt2880-uart", "ns16550a";
                        reg = <0xc00 0x100>;
 
+                       resets = <&rstctrl 19>;
+                       reset-names = "uartl";
+
                        interrupt-parent = <&intc>;
                        interrupts = <12>;
 
                        reg-shift = <2>;
+
+                       pinctrl-names = "default";
+                       pinctrl-0 = <&uartlite_pins>;
                };
        };
 
+       pinctrl {
+               compatible = "ralink,rt2880-pinmux";
+
+               pinctrl-names = "default";
+               pinctrl-0 = <&state_default>;
+
+               state_default: pinctrl0 {
+               };
+
+               spi_pins: spi {
+                       spi {
+                               ralink,group = "spi";
+                               ralink,function = "spi";
+                       };
+               };
+               uartlite_pins: uartlite {
+                       uart {
+                               ralink,group = "uartlite";
+                               ralink,function = "uartlite";
+                       };
+               };
+       };
+
+       rstctrl: rstctrl {
+               compatible = "ralink,rt3352-reset", "ralink,rt2880-reset";
+               #reset-cells = <1>;
+       };
+
        ethernet@10100000 {
                compatible = "ralink,rt3352-eth", "ralink,rt3050-eth";
                reg = <0x10100000 10000>;
 
                interrupt-parent = <&cpuintc>;
                interrupts = <5>;
-
-               status = "disabled";
        };
 
        esw@10110000 {
 
                interrupt-parent = <&intc>;
                interrupts = <17>;
-
-               status = "disabled";
        };
 
        wmac@10180000 {
                interrupts = <6>;
 
                ralink,eeprom = "soc_wmac.eeprom";
-
-               status = "disabled";
        };
 
        ehci@101c0000 {