0
0
mirror of https://git.openwrt.org/openwrt/openwrt.git synced 2024-11-22 04:56:15 +00:00
openwrt/target/linux/bcm27xx/patches-6.6/950-0672-overlays-mcp23017-allow-specification-of-the-i2c-bus.patch
Álvaro Fernández Rojas 8c405cdccc bcm27xx: add 6.6 kernel patches
The patches were generated from the RPi repo with the following command:
git format-patch v6.6.34..rpi-6.1.y

Some patches needed rebasing and, as usual, the applied and reverted, wireless
drivers, Github workflows, READMEs and defconfigs patches were removed.

Signed-off-by: Álvaro Fernández Rojas <noltari@gmail.com>
2024-06-18 18:52:49 +02:00

140 lines
3.7 KiB
Diff

From 2541eaca2c169ca90e017b5a3b014b41c0988909 Mon Sep 17 00:00:00 2001
From: Janis Streib <janis+github@dogcraft.de>
Date: Sun, 15 Oct 2023 21:08:40 +0200
Subject: [PATCH 0672/1085] overlays: mcp23017: allow specification of the i2c
bus
Analogous to i2c-rtc-overlay.dts
See: https://github.com/raspberrypi/linux/pull/5650
---
arch/arm/boot/dts/overlays/README | 10 +++
.../boot/dts/overlays/mcp23017-overlay.dts | 68 ++++++++++++++-----
2 files changed, 61 insertions(+), 17 deletions(-)
--- a/arch/arm/boot/dts/overlays/README
+++ b/arch/arm/boot/dts/overlays/README
@@ -2810,6 +2810,16 @@ Params: gpiopin Gpio pin
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
--- 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,13 +24,33 @@
};
fragment@2 {
- target = <&i2c1>;
+ target = <&mcp23017>;
+ __dormant__ {
+ compatible = "microchip,mcp23008";
+ };
+ };
+
+ fragment@3 {
+ target = <&mcp23017>;
+ mcp23017_irq: __overlay__ {
+ #interrupt-cells=<2>;
+ interrupt-parent = <&gpio>;
+ interrupts = <4 2>;
+ interrupt-controller;
+ microchip,irq-mirror;
+ };
+ };
+
+ fragment@4 {
+ target = <&i2cbus>;
__overlay__ {
#address-cells = <1>;
#size-cells = <0>;
mcp23017: mcp@20 {
compatible = "microchip,mcp23017";
+ pinctrl-name = "default";
+ pinctrl-0 = <&mcp23017_pins>;
reg = <0x20>;
gpio-controller;
#gpio-cells = <2>;
@@ -40,30 +60,44 @@
};
};
- fragment@3 {
- target = <&mcp23017>;
- __dormant__ {
- compatible = "microchip,mcp23008";
+ frag100: fragment@100 {
+ target = <&i2c1>;
+ i2cbus: __overlay__ {
+ status = "okay";
};
};
- fragment@4 {
- target = <&mcp23017>;
- mcp23017_irq: __overlay__ {
- #interrupt-cells=<2>;
- interrupt-parent = <&gpio>;
- interrupts = <4 2>;
- interrupt-controller;
- microchip,irq-mirror;
- };
+ fragment@101 {
+ target = <&i2c0if>;
+ __dormant__ {
+ status = "okay";
+ };
+ };
+
+ fragment@102 {
+ target = <&i2c0mux>;
+ __dormant__ {
+ 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";
+ mcp23008 = <0>,"=2";
+ noints = <0>,"!1!3";
+ 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";
};
};