diff --git a/arch/arm/boot/dts/overlays/README b/arch/arm/boot/dts/overlays/README
index 58b053bc57ba65..a162cad147ffea 100644
--- a/arch/arm/boot/dts/overlays/README
+++ b/arch/arm/boot/dts/overlays/README
@@ -555,6 +555,7 @@ Params: addr I2C bus address of device. Set based on how the
overlay - BCM2711 only)
i2c6 Choose the I2C6 bus (configure with the i2c6
overlay - BCM2711 only)
+ i2c-path Override I2C path to allow for i2c-gpio buses
Channel parameters can be set for each enabled channel.
A maximum of 4 channels can be enabled (letters a thru d).
@@ -1253,6 +1254,7 @@ Params: sizex Touchscreen size x (default 800)
addr Sets the address for the touch controller. Note
that the device must be configured to use the
specified address.
+ i2c-path Override I2C path to allow for i2c-gpio buses
Name: enc28j60
@@ -1454,6 +1456,7 @@ Info: Enables I2C connected Goodix gt9271 multiple touch controller using
Load: dtoverlay=goodix,=
Params: interrupt GPIO used for interrupt (default 4)
reset GPIO used for reset (default 17)
+ i2c-path Override I2C path to allow for i2c-gpio buses
Name: googlevoicehat-soundcard
@@ -1745,6 +1748,7 @@ Params: addr I2C address of PCF8574
display_height Height of the display in characters (default 2)
display_width Width of the display in characters (default 16)
+ i2c-path Override I2C path to allow for i2c-gpio buses
Name: hd44780-lcd
@@ -2110,6 +2114,8 @@ Params: addr Sets the address for the fan controller. Note
i2c6 Choose the I2C6 bus (configure with the i2c6
overlay - BCM2711 only)
+ i2c-path Override I2C path to allow for i2c-gpio buses
+
minpwm PWM setting for the fan when the SoC is below
mintemp (range 0-255. default 0)
maxpwm PWM setting for the fan when the SoC is above
@@ -2180,6 +2186,8 @@ Params: pca9542 Select the NXP PCA9542 device
i2c6 Choose the I2C6 bus (configure with the i2c6
overlay - BCM2711 only)
+ i2c-path Override I2C path to allow for i2c-gpio buses
+
disconnect_on_idle Force the mux to disconnect all child buses
after every transaction.
@@ -2201,6 +2209,7 @@ Params: addr I2C address of PCA9685A (default 0x40)
overlay - BCM2711 only)
i2c6 Choose the I2C6 bus (configure with the i2c6
overlay - BCM2711 only)
+ i2c-path Override I2C path to allow for i2c-gpio buses
Name: i2c-rtc
@@ -2270,6 +2279,8 @@ Params: abx80x Select one of the ABx80x family:
i2c6 Choose the I2C6 bus (configure with the i2c6
overlay - BCM2711 only)
+ i2c-path Override I2C path to allow for i2c-gpio buses
+
addr Sets the address for the RTC. Note that the
device must be configured to use the specified
address.
@@ -2551,6 +2562,8 @@ Params: addr Set the address for the ADT7410, AS73211,
i2c6 Choose the I2C6 bus (configure with the i2c6
overlay - BCM2711 only)
+ i2c-path Override I2C path to allow for i2c-gpio buses
+
Name: i2c0
Info: Change i2c0 pin usage. Not all pin combinations are usable on all
@@ -2693,6 +2706,7 @@ Params: interrupt GPIO used for interrupt (default 4)
touchscreen (in pixels)
sizey Touchscreen size y, vertical resolution of
touchscreen (in pixels)
+ i2c-path Override I2C path to allow for i2c-gpio buses
Name: imx219
@@ -3170,6 +3184,7 @@ Params: gpiopin Gpio pin connected to the INTA output of the
overlay - BCM2711 only)
i2c6 Choose the I2C6 bus (configure with the i2c6
overlay - BCM2711 only)
+ i2c-path Override I2C path to allow for i2c-gpio buses
Name: mcp23s17
@@ -3619,6 +3634,17 @@ Params: addr I2C address of expander. Default 0x20.
cat9554 Select the Onnn CAT9554 (8 bit)
pca9654 Select the Onnn PCA9654 (8 bit)
xra1202 Select the Exar XRA1202 (8 bit)
+ 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 I2C3 bus (configure with the i2c3
+ overlay - BCM2711 only)
+ i2c5 Choose the I2C5 bus (configure with the i2c4
+ overlay - BCM2711 only)
+ i2c6 Choose the I2C6 bus (configure with the i2c6
+ overlay - BCM2711 only)
+ i2c-path Override I2C path to allow for i2c-gpio buses
Name: pcf857x
@@ -3630,6 +3656,17 @@ Params: addr I2C address of expander. Default
pcf8574a Select the NXP PCF8574A (8 bit)
pcf8575 Select the NXP PCF8575 (16 bit)
pca8574 Select the NXP PCA8574 (8 bit)
+ 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 I2C3 bus (configure with the i2c3
+ overlay - BCM2711 only)
+ i2c5 Choose the I2C5 bus (configure with the i2c4
+ overlay - BCM2711 only)
+ i2c6 Choose the I2C6 bus (configure with the i2c6
+ overlay - BCM2711 only)
+ i2c-path Override I2C path to allow for i2c-gpio buses
Name: pcie-32bit-dma
@@ -4291,6 +4328,17 @@ Load: dtoverlay=sc16is750-i2c,=
Params: int_pin GPIO used for IRQ (default 24)
addr Address (default 0x48)
xtal On-board crystal frequency (default 14745600)
+ 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)
+ i2c-path Override I2C path to allow for i2c-gpio buses
Name: sc16is750-spi0
@@ -4309,6 +4357,17 @@ Load: dtoverlay=sc16is752-i2c,=
Params: int_pin GPIO used for IRQ (default 24)
addr Address (default 0x48)
xtal On-board crystal frequency (default 14745600)
+ 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)
+ i2c-path Override I2C path to allow for i2c-gpio buses
Name: sc16is752-spi0
diff --git a/arch/arm/boot/dts/overlays/ads1115-overlay.dts b/arch/arm/boot/dts/overlays/ads1115-overlay.dts
index 64ada16de9c72e..473798abb76a5d 100644
--- a/arch/arm/boot/dts/overlays/ads1115-overlay.dts
+++ b/arch/arm/boot/dts/overlays/ads1115-overlay.dts
@@ -131,5 +131,7 @@
<&frag100>, "target-path=i2c5";
i2c6 = <&frag100>, "target?=0",
<&frag100>, "target-path=i2c6";
+ i2c-path = <&frag100>, "target?=0",
+ <&frag100>, "target-path";
};
};
diff --git a/arch/arm/boot/dts/overlays/edt-ft5406-overlay.dts b/arch/arm/boot/dts/overlays/edt-ft5406-overlay.dts
index 6e40c0ebb3bf91..b05b569836769c 100644
--- a/arch/arm/boot/dts/overlays/edt-ft5406-overlay.dts
+++ b/arch/arm/boot/dts/overlays/edt-ft5406-overlay.dts
@@ -41,6 +41,9 @@
i2c6 = <&ts_i2c_frag>, "target?=0",
<&ts_i2c_frag>, "target-path=i2c6",
<0>,"-0-1";
+ i2c-path = <&ts_i2c_frag>, "target?=0",
+ <&ts_i2c_frag>, "target-path",
+ <0>,"-0-1";
addr = <&ft5406>,"reg:0";
};
};
diff --git a/arch/arm/boot/dts/overlays/goodix-overlay.dts b/arch/arm/boot/dts/overlays/goodix-overlay.dts
index 8571527de49a6e..926f35695c7375 100644
--- a/arch/arm/boot/dts/overlays/goodix-overlay.dts
+++ b/arch/arm/boot/dts/overlays/goodix-overlay.dts
@@ -16,7 +16,7 @@
};
};
- fragment@1 {
+ i2c_frag: fragment@1 {
target = <&i2c1>;
__overlay__ {
#address-cells = <1>;
@@ -42,5 +42,7 @@
<>9271>,"irq-gpios:4";
reset = <&goodix_pins>,"brcm,pins:4",
<>9271>,"reset-gpios:4";
+ i2c-path = <&i2c_frag>, "target?=0",
+ <&i2c_frag>, "target-path";
};
};
diff --git a/arch/arm/boot/dts/overlays/hd44780-i2c-lcd-overlay.dts b/arch/arm/boot/dts/overlays/hd44780-i2c-lcd-overlay.dts
index 36fcf049ffbfe2..d5bfd762fe2eb5 100644
--- a/arch/arm/boot/dts/overlays/hd44780-i2c-lcd-overlay.dts
+++ b/arch/arm/boot/dts/overlays/hd44780-i2c-lcd-overlay.dts
@@ -4,7 +4,7 @@
/ {
compatible = "brcm,bcm2835";
- fragment@0 {
+ i2c_frag: fragment@0 {
target = <&i2c_arm>;
__overlay__ {
status = "okay";
@@ -52,6 +52,8 @@
display_height = <&lcd_screen>,"display-height-chars:0";
display_width = <&lcd_screen>,"display-width-chars:0";
addr = <&pcf857x>,"reg:0";
+ i2c-path = <&i2c_frag>, "target?=0",
+ <&i2c_frag>, "target-path";
};
};
diff --git a/arch/arm/boot/dts/overlays/i2c-fan-overlay.dts b/arch/arm/boot/dts/overlays/i2c-fan-overlay.dts
index f2f4a2aa797a6b..49b62789b55c0a 100644
--- a/arch/arm/boot/dts/overlays/i2c-fan-overlay.dts
+++ b/arch/arm/boot/dts/overlays/i2c-fan-overlay.dts
@@ -93,6 +93,8 @@
<&frag100>, "target-path=i2c5";
i2c6 = <&frag100>, "target?=0",
<&frag100>, "target-path=i2c6";
+ i2c-path = <&frag100>, "target?=0",
+ <&frag100>, "target-path";
addr = <&emc2301>,"reg:0";
minpwm = <&emc2301>,"emc2305,pwm-min.0";
maxpwm = <&emc2301>,"emc2305,pwm-max.0";
diff --git a/arch/arm/boot/dts/overlays/i2c-mux-overlay.dts b/arch/arm/boot/dts/overlays/i2c-mux-overlay.dts
index 0575b276cd2697..ed8517dfddd05a 100644
--- a/arch/arm/boot/dts/overlays/i2c-mux-overlay.dts
+++ b/arch/arm/boot/dts/overlays/i2c-mux-overlay.dts
@@ -175,6 +175,8 @@
<&frag100>, "target-path=i2c5";
i2c6 = <&frag100>, "target?=0",
<&frag100>, "target-path=i2c6";
+ i2c-path = <&frag100>, "target?=0",
+ <&frag100>, "target-path";
disconnect_on_idle =
<&pca9542>,"idle-state:0=", ,
<&pca9545>,"idle-state:0=", ,
diff --git a/arch/arm/boot/dts/overlays/i2c-pwm-pca9685a-overlay.dts b/arch/arm/boot/dts/overlays/i2c-pwm-pca9685a-overlay.dts
index b8dfbd56d12166..06efa684b08c42 100644
--- a/arch/arm/boot/dts/overlays/i2c-pwm-pca9685a-overlay.dts
+++ b/arch/arm/boot/dts/overlays/i2c-pwm-pca9685a-overlay.dts
@@ -57,5 +57,7 @@
<&frag100>, "target-path=i2c5";
i2c6 = <&frag100>, "target?=0",
<&frag100>, "target-path=i2c6";
+ i2c-path = <&frag100>, "target?=0",
+ <&frag100>, "target-path";
};
};
diff --git a/arch/arm/boot/dts/overlays/i2c-rtc-overlay.dts b/arch/arm/boot/dts/overlays/i2c-rtc-overlay.dts
index cd31eac7e33357..ef2c33cbe45b5e 100644
--- a/arch/arm/boot/dts/overlays/i2c-rtc-overlay.dts
+++ b/arch/arm/boot/dts/overlays/i2c-rtc-overlay.dts
@@ -38,5 +38,7 @@
<&frag100>, "target-path=i2c5";
i2c6 = <&frag100>, "target?=0",
<&frag100>, "target-path=i2c6";
+ i2c-path = <&frag100>, "target?=0",
+ <&frag100>, "target-path";
};
};
diff --git a/arch/arm/boot/dts/overlays/i2c-sensor-overlay.dts b/arch/arm/boot/dts/overlays/i2c-sensor-overlay.dts
index f8a39659d83e41..fe3169924b5f1f 100755
--- a/arch/arm/boot/dts/overlays/i2c-sensor-overlay.dts
+++ b/arch/arm/boot/dts/overlays/i2c-sensor-overlay.dts
@@ -38,5 +38,7 @@
<&frag100>, "target-path=i2c5";
i2c6 = <&frag100>, "target?=0",
<&frag100>, "target-path=i2c6";
+ i2c-path = <&frag100>, "target?=0",
+ <&frag100>, "target-path";
};
};
diff --git a/arch/arm/boot/dts/overlays/ilitek251x-overlay.dts b/arch/arm/boot/dts/overlays/ilitek251x-overlay.dts
index 551aba591d263d..226d490ce092fe 100644
--- a/arch/arm/boot/dts/overlays/ilitek251x-overlay.dts
+++ b/arch/arm/boot/dts/overlays/ilitek251x-overlay.dts
@@ -16,7 +16,7 @@
};
};
- fragment@1 {
+ frag1: fragment@1 {
target = <&i2c1>;
__overlay__ {
#address-cells = <1>;
@@ -41,5 +41,7 @@
<&ili251x>,"interrupts:0";
sizex = <&ili251x>,"touchscreen-size-x:0";
sizey = <&ili251x>,"touchscreen-size-y:0";
+ i2c-path = <&frag1>, "target?=0",
+ <&frag1>, "target-path";
};
};
diff --git a/arch/arm/boot/dts/overlays/mcp23017-overlay.dts b/arch/arm/boot/dts/overlays/mcp23017-overlay.dts
index 0f9e89484c55ee..253ac698235375 100644
--- a/arch/arm/boot/dts/overlays/mcp23017-overlay.dts
+++ b/arch/arm/boot/dts/overlays/mcp23017-overlay.dts
@@ -98,6 +98,8 @@
<&frag100>, "target-path=i2c5";
i2c6 = <&frag100>, "target?=0",
<&frag100>, "target-path=i2c6";
+ i2c-path = <&frag100>, "target?=0",
+ <&frag100>, "target-path";
};
};
diff --git a/arch/arm/boot/dts/overlays/pca953x-overlay.dts b/arch/arm/boot/dts/overlays/pca953x-overlay.dts
index ab414e92e3669c..36aeaac324fbdc 100644
--- a/arch/arm/boot/dts/overlays/pca953x-overlay.dts
+++ b/arch/arm/boot/dts/overlays/pca953x-overlay.dts
@@ -5,7 +5,7 @@
/{
compatible = "brcm,bcm2835";
- fragment@0 {
+ frag0: fragment@0 {
target = <&i2c_arm>;
__overlay__ {
#address-cells = <1>;
@@ -204,6 +204,20 @@
};
};
+ fragment@100 {
+ target = <&i2c0if>;
+ __dormant__ {
+ status = "okay";
+ };
+ };
+
+ fragment@101 {
+ target = <&i2c0mux>;
+ __dormant__ {
+ status = "okay";
+ };
+ };
+
__overrides__ {
addr = <&pca>,"reg:0";
pca6416 = <0>, "+1";
@@ -236,5 +250,19 @@
cat9554 = <0>, "+28";
pca9654 = <0>, "+29";
xra1202 = <0>, "+30";
+ i2c0 = <&frag0>, "target:0=",<&i2c0>,
+ <0>,"+100+101";
+ i2c_csi_dsi = <&frag0>, "target:0=",<&i2c_csi_dsi>,
+ <0>,"+100+101";
+ i2c3 = <&frag0>, "target?=0",
+ <&frag0>, "target-path=i2c3";
+ i2c4 = <&frag0>, "target?=0",
+ <&frag0>, "target-path=i2c4";
+ i2c5 = <&frag0>, "target?=0",
+ <&frag0>, "target-path=i2c5";
+ i2c6 = <&frag0>, "target?=0",
+ <&frag0>, "target-path=i2c6";
+ i2c-path = <&frag0>, "target?=0",
+ <&frag0>, "target-path";
};
};
diff --git a/arch/arm/boot/dts/overlays/pcf857x-overlay.dts b/arch/arm/boot/dts/overlays/pcf857x-overlay.dts
index 68943e1c332015..fd2ba1e98e9041 100644
--- a/arch/arm/boot/dts/overlays/pcf857x-overlay.dts
+++ b/arch/arm/boot/dts/overlays/pcf857x-overlay.dts
@@ -6,7 +6,7 @@
/ {
compatible = "brcm,bcm2835";
- fragment@0 {
+ frag0: fragment@0 {
target = <&i2c_arm>;
__overlay__ {
#address-cells = <1>;
@@ -22,11 +22,39 @@
};
};
+ fragment@100 {
+ target = <&i2c0if>;
+ __dormant__ {
+ status = "okay";
+ };
+ };
+
+ fragment@101 {
+ target = <&i2c0mux>;
+ __dormant__ {
+ status = "okay";
+ };
+ };
+
__overrides__ {
pcf8574 = <&pcf857x>,"compatible=nxp,pcf8574", <&pcf857x>,"reg:0=0x20";
pcf8574a = <&pcf857x>,"compatible=nxp,pcf8574a", <&pcf857x>,"reg:0=0x38";
pcf8575 = <&pcf857x>,"compatible=nxp,pcf8575", <&pcf857x>,"reg:0=0x20";
pca8574 = <&pcf857x>,"compatible=nxp,pca8574", <&pcf857x>,"reg:0=0x20";
addr = <&pcf857x>,"reg:0";
+ i2c0 = <&frag0>, "target:0=",<&i2c0>,
+ <0>,"+100+101";
+ i2c_csi_dsi = <&frag0>, "target:0=",<&i2c_csi_dsi>,
+ <0>,"+100+101";
+ i2c3 = <&frag0>, "target?=0",
+ <&frag0>, "target-path=i2c3";
+ i2c4 = <&frag0>, "target?=0",
+ <&frag0>, "target-path=i2c4";
+ i2c5 = <&frag0>, "target?=0",
+ <&frag0>, "target-path=i2c5";
+ i2c6 = <&frag0>, "target?=0",
+ <&frag0>, "target-path=i2c6";
+ i2c-path = <&frag0>, "target?=0",
+ <&frag0>, "target-path";
};
};
diff --git a/arch/arm/boot/dts/overlays/sc16is750-i2c-overlay.dts b/arch/arm/boot/dts/overlays/sc16is750-i2c-overlay.dts
index 09c08c1c543327..61579edf3d2e6b 100644
--- a/arch/arm/boot/dts/overlays/sc16is750-i2c-overlay.dts
+++ b/arch/arm/boot/dts/overlays/sc16is750-i2c-overlay.dts
@@ -4,7 +4,7 @@
/ {
compatible = "brcm,bcm2835";
- fragment@0 {
+ frag0: fragment@0 {
target = <&i2c_arm>;
__overlay__ {
#address-cells = <1>;
@@ -48,10 +48,38 @@
};
};
+ fragment@100 {
+ target = <&i2c0if>;
+ __dormant__ {
+ status = "okay";
+ };
+ };
+
+ fragment@101 {
+ target = <&i2c0mux>;
+ __dormant__ {
+ status = "okay";
+ };
+ };
+
__overrides__ {
int_pin = <&sc16is750>,"interrupts:0", <&int_pins>,"brcm,pins:0",
<&int_pins>,"reg:0";
addr = <&sc16is750>,"reg:0", <&sc16is750_clk>,"name";
xtal = <&sc16is750_clk>,"clock-frequency:0";
+ i2c0 = <&frag0>, "target:0=",<&i2c0>,
+ <0>,"+100+101";
+ i2c_csi_dsi = <&frag0>, "target:0=",<&i2c_csi_dsi>,
+ <0>,"+100+101";
+ i2c3 = <&frag0>, "target?=0",
+ <&frag0>, "target-path=i2c3";
+ i2c4 = <&frag0>, "target?=0",
+ <&frag0>, "target-path=i2c4";
+ i2c5 = <&frag0>, "target?=0",
+ <&frag0>, "target-path=i2c5";
+ i2c6 = <&frag0>, "target?=0",
+ <&frag0>, "target-path=i2c6";
+ i2c-path = <&frag0>, "target?=0",
+ <&frag0>, "target-path";
};
};
diff --git a/arch/arm/boot/dts/overlays/sc16is752-i2c-overlay.dts b/arch/arm/boot/dts/overlays/sc16is752-i2c-overlay.dts
index a7c538943859e5..e9646e273c1da3 100644
--- a/arch/arm/boot/dts/overlays/sc16is752-i2c-overlay.dts
+++ b/arch/arm/boot/dts/overlays/sc16is752-i2c-overlay.dts
@@ -4,7 +4,7 @@
/ {
compatible = "brcm,bcm2835";
- fragment@0 {
+ frag0: fragment@0 {
target = <&i2c_arm>;
__overlay__ {
#address-cells = <1>;
@@ -48,10 +48,38 @@
};
};
+ fragment@100 {
+ target = <&i2c0if>;
+ __dormant__ {
+ status = "okay";
+ };
+ };
+
+ fragment@101 {
+ target = <&i2c0mux>;
+ __dormant__ {
+ status = "okay";
+ };
+ };
+
__overrides__ {
int_pin = <&sc16is752>,"interrupts:0", <&int_pins>,"brcm,pins:0",
<&int_pins>,"reg:0";
addr = <&sc16is752>,"reg:0",<&sc16is752_clk>,"name";
xtal = <&sc16is752_clk>,"clock-frequency:0";
+ i2c0 = <&frag0>, "target:0=",<&i2c0>,
+ <0>,"+100+101";
+ i2c_csi_dsi = <&frag0>, "target:0=",<&i2c_csi_dsi>,
+ <0>,"+100+101";
+ i2c3 = <&frag0>, "target?=0",
+ <&frag0>, "target-path=i2c3";
+ i2c4 = <&frag0>, "target?=0",
+ <&frag0>, "target-path=i2c4";
+ i2c5 = <&frag0>, "target?=0",
+ <&frag0>, "target-path=i2c5";
+ i2c6 = <&frag0>, "target?=0",
+ <&frag0>, "target-path=i2c6";
+ i2c-path = <&frag0>, "target?=0",
+ <&frag0>, "target-path";
};
};