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"; }; };