ARM: dts: lager: use demuxer for IIC1/I2C1
authorSimon Horman <horms+renesas@verge.net.au>
Sun, 6 Nov 2016 20:20:20 +0000 (21:20 +0100)
committerSimon Horman <horms+renesas@verge.net.au>
Wed, 23 Nov 2016 19:52:22 +0000 (20:52 +0100)
Make it possible to select which I2C1 IP core you want to run on the
EXIO-A connector.

This is based on reference work for the I2C0 core of the lager board
by Wolfram Sang.

Signed-off-by: Simon Horman <horms+renesas@verge.net.au>
[wsa: rebased and fixed aliases]
Signed-off-by: Wolfram Sang <wsa+renesas@sang-engineering.com>
arch/arm/boot/dts/r8a7790-lager.dts

index 5645444cd21ae4c8dd1467be520bdd9a6598e67e..9b9748548702d54e87bb5c465c45cfd7c7210bca 100644 (file)
@@ -50,7 +50,9 @@
        aliases {
                serial0 = &scif0;
                serial1 = &scifa1;
+               i2c8 = &gpioi2c1;
                i2c10 = &i2cexio0;
+               i2c11 = &i2cexio1;
        };
 
        chosen {
                clock-frequency = <148500000>;
        };
 
+       gpioi2c1: i2c-8 {
+               #address-cells = <1>;
+               #size-cells = <0>;
+               compatible = "i2c-gpio";
+               status = "disabled";
+               gpios = <&gpio1 17 GPIO_ACTIVE_HIGH /* sda */
+                        &gpio1 16 GPIO_ACTIVE_HIGH /* scl */
+                       >;
+               i2c-gpio,delay-us = <5>;
+       };
+
        /*
         * IIC0/I2C0 is routed to EXIO connector A, pins 114 (SCL) + 116 (SDA) only.
         * We use the I2C demuxer, so the desired IP core can be selected at runtime
                #address-cells = <1>;
                #size-cells = <0>;
        };
+
+       /*
+        * IIC1/I2C1 is routed to EXIO connector A, pins 78 (SCL) + 80 (SDA).
+        * This is similar to the arangement described for i2cexio0 (above)
+        * with a fallback to GPIO also provided.
+        */
+       i2cexio1: i2c-11 {
+               compatible = "i2c-demux-pinctrl";
+               i2c-parent = <&iic1>, <&i2c1>, <&gpioi2c1>;
+               i2c-bus-name = "i2c-exio1";
+               #address-cells = <1>;
+               #size-cells = <0>;
+       };
 };
 
 &du {
                function = "iic0";
        };
 
+       i2c1_pins: i2c1 {
+               groups = "i2c1";
+               function = "i2c1";
+       };
+
        iic1_pins: iic1 {
                groups = "iic1";
                function = "iic1";
        pinctrl-names = "i2c-exio0";
 };
 
+&i2c1  {
+       pinctrl-0 = <&i2c1_pins>;
+       pinctrl-names = "i2c-exio1";
+};
+
 &iic1  {
-       status = "okay";
        pinctrl-0 = <&iic1_pins>;
-       pinctrl-names = "default";
+       pinctrl-names = "i2c-exio1";
 };
 
 &iic2  {