Rockchip RV1126 is using old style i2c controller, the i2c2
bus uses a non-sequential offset in the grf register for the
mask/value bits for this bus.
This patch fixes i2c2 bus on rv1126 SoCs.
Signed-off-by: Tim Lunn <tim@feathertop.org>
Acked-by: Heiko Stuebner <heiko@sntech.de>
Reviewed-by: Andi Shyti <andi.shyti@kernel.org>
Signed-off-by: Wolfram Sang <wsa@kernel.org>
                        return -EINVAL;
                }
 
-               /* 27+i: write mask, 11+i: value */
-               value = BIT(27 + bus_nr) | BIT(11 + bus_nr);
+               /* rv1126 i2c2 uses non-sequential write mask 20, value 4 */
+               if (i2c->soc_data == &rv1126_soc_data && bus_nr == 2)
+                       value = BIT(20) | BIT(4);
+               else
+                       /* 27+i: write mask, 11+i: value */
+                       value = BIT(27 + bus_nr) | BIT(11 + bus_nr);
 
                ret = regmap_write(grf, i2c->soc_data->grf_offset, value);
                if (ret != 0) {