]> git.karo-electronics.de Git - linux-beck.git/commitdiff
ARM: nomadik: switch to use the Nomadik I2C driver
authorLinus Walleij <linus.walleij@linaro.org>
Sun, 9 Jun 2013 22:17:56 +0000 (00:17 +0200)
committerLinus Walleij <linus.walleij@linaro.org>
Tue, 6 Aug 2013 22:59:06 +0000 (00:59 +0200)
Instead of using bit-banged I2C, let's use the actual I2C
driver in the kernel. Since the I2C block may be communicating
with things like the PMIC, we need to select it from the Kconfig
just like the bit-banged adapter is selected today. The rest of
the configuration for this driver can be done from the device
tree.

Signed-off-by: Linus Walleij <linus.walleij@linaro.org>
arch/arm/boot/dts/ste-nomadik-stn8815.dtsi
arch/arm/mach-nomadik/Kconfig

index a3acfa7b3dc9c65fe6abded6a17a97aee3c4729e..9169d3025f39ed5fd2475f43f0d3cd261e71894d 100644 (file)
                        };
                };
                i2c0 {
+                       i2c0_default_mux: i2c0_mux {
+                               i2c0_default_mux {
+                                       ste,function = "i2c0";
+                                       ste,pins = "i2c0_a_1";
+                               };
+                       };
                        i2c0_default_mode: i2c0_default {
                                i2c0_default_cfg {
                                        ste,pins = "GPIO62_D3", "GPIO63_D2";
-                                       ste,input = <1>;
+                                       ste,input = <0>;
                                };
                        };
                };
                i2c1 {
+                       i2c1_default_mux: i2c1_mux {
+                               i2c1_default_mux {
+                                       ste,function = "i2c1";
+                                       ste,pins = "i2c1_a_1";
+                               };
+                       };
                        i2c1_default_mode: i2c1_default {
                                i2c1_default_cfg {
                                        ste,pins = "GPIO53_L4", "GPIO54_L3";
-                                       ste,input = <1>;
+                                       ste,input = <0>;
                                };
                        };
                };
                        i2c2_default_mode: i2c2_default {
                                i2c2_default_cfg {
                                        ste,pins = "GPIO73_C21", "GPIO74_C20";
-                                       ste,input = <1>;
+                                       ste,input = <0>;
                                };
                        };
                };
 
        /* I2C0 connected to the STw4811 power management chip */
        i2c0 {
-               compatible = "i2c-gpio";
-               gpios = <&gpio1 31 0>, /* sda */
-                       <&gpio1 30 0>; /* scl */
+               compatible = "st,nomadik-i2c", "arm,primecell";
+               reg = <0x101f8000 0x1000>;
+               interrupt-parent = <&vica>;
+               interrupts = <20>;
+               clock-frequency = <100000>;
                #address-cells = <1>;
                #size-cells = <0>;
+               clocks = <&i2c0clk>, <&pclki2c0>;
+               clock-names = "mclk", "apb_pclk";
                pinctrl-names = "default";
-               pinctrl-0 = <&i2c0_default_mode>;
+               pinctrl-0 = <&i2c0_default_mux>, <&i2c0_default_mode>;
 
                stw4811@2d {
                           compatible = "st,stw4811";
 
        /* I2C1 connected to various sensors */
        i2c1 {
-               compatible = "i2c-gpio";
-               gpios = <&gpio1 22 0>, /* sda */
-                       <&gpio1 21 0>; /* scl */
+               compatible = "st,nomadik-i2c", "arm,primecell";
+               reg = <0x101f7000 0x1000>;
+               interrupt-parent = <&vica>;
+               interrupts = <21>;
+               clock-frequency = <100000>;
                #address-cells = <1>;
                #size-cells = <0>;
+               clocks = <&i2c1clk>, <&pclki2c1>;
+               clock-names = "mclk", "apb_pclk";
                pinctrl-names = "default";
-               pinctrl-0 = <&i2c1_default_mode>;
+               pinctrl-0 = <&i2c1_default_mux>, <&i2c1_default_mode>;
 
                camera@2d {
                           compatible = "st,camera";
index 5981c3db9b41d33f36068bcc3a12e62a85447e23..4d42da49753c68f1afd914a0a4a4246e09b8893c 100644 (file)
@@ -27,6 +27,7 @@ config MACH_NOMADIK_8815NHK
        select NOMADIK_8815
        select I2C
        select I2C_ALGOBIT
+       select I2C_NOMADIK
 
 endmenu
 endif