From 7f133a328dda8fcb408049088db6c18f6fca5dc0 Mon Sep 17 00:00:00 2001 From: Janis Streib Date: Sun, 15 Oct 2023 15:38:46 +0200 Subject: [PATCH] MCP23017: allow specification of the i2c bus Analogous to i2c-rtc-overlay.dts --- arch/arm/boot/dts/overlays/README | 10 +++++++++ .../boot/dts/overlays/mcp23017-overlay.dts | 22 +++++++++++++++++-- 2 files changed, 30 insertions(+), 2 deletions(-) diff --git a/arch/arm/boot/dts/overlays/README b/arch/arm/boot/dts/overlays/README index 7f5fda92d62305..73a5a3431fc58f 100644 --- a/arch/arm/boot/dts/overlays/README +++ b/arch/arm/boot/dts/overlays/README @@ -2810,6 +2810,16 @@ Params: gpiopin Gpio pin connected to the INTA output of the mcp23008 Configure an MCP23008 instead. noints Disable the interrupt GPIO line. + i2c0 Choose the I2C0 bus on GPIOs 0&1 + i2c_csi_dsi Choose the I2C0 bus on GPIOs 44&45 + i2c3 Choose the I2C3 bus (configure with the i2c3 + overlay - BCM2711 only) + i2c4 Choose the I2C4 bus (configure with the i2c4 + overlay - BCM2711 only) + i2c5 Choose the I2C5 bus (configure with the i2c5 + overlay - BCM2711 only) + i2c6 Choose the I2C6 bus (configure with the i2c6 + overlay - BCM2711 only) Name: mcp23s17 diff --git a/arch/arm/boot/dts/overlays/mcp23017-overlay.dts b/arch/arm/boot/dts/overlays/mcp23017-overlay.dts index c546d8ba7e6d27..38e5972b7bb86d 100644 --- a/arch/arm/boot/dts/overlays/mcp23017-overlay.dts +++ b/arch/arm/boot/dts/overlays/mcp23017-overlay.dts @@ -7,7 +7,7 @@ compatible = "brcm,bcm2835"; fragment@0 { - target = <&i2c1>; + target = <&i2cbus>; __overlay__ { status = "okay"; }; @@ -24,7 +24,7 @@ }; fragment@2 { - target = <&i2c1>; + target = <&i2cbus>; __overlay__ { #address-cells = <1>; #size-cells = <0>; @@ -58,12 +58,30 @@ }; }; + frag100: fragment@100 { + target = <&i2c1>; + i2cbus: __overlay__ { + status = "okay"; + }; + }; + __overrides__ { gpiopin = <&mcp23017_pins>,"brcm,pins:0", <&mcp23017_irq>,"interrupts:0"; addr = <&mcp23017>,"reg:0", <&mcp23017_pins>,"reg:0"; mcp23008 = <0>,"=3"; noints = <0>,"!1!4"; + i2c0 = <&frag100>, "target:0=",<&i2c0>; + i2c_csi_dsi = <&frag100>, "target:0=",<&i2c_csi_dsi>, + <0>,"+101+102"; + i2c3 = <&frag100>, "target?=0", + <&frag100>, "target-path=i2c3"; + i2c4 = <&frag100>, "target?=0", + <&frag100>, "target-path=i2c4"; + i2c5 = <&frag100>, "target?=0", + <&frag100>, "target-path=i2c5"; + i2c6 = <&frag100>, "target?=0", + <&frag100>, "target-path=i2c6"; }; };