Re: Adding I2C devices to the SMBus (PIIX4) via the ACPI SSDT overlay method

[Date Prev][Date Next][Thread Prev][Thread Next][Date Index][Thread Index]

 



Hello Konstantin,

On 2024-11-08 09:46, Andy Shevchenko wrote:
+Cc: Florian (as this indeed rang a bell to me)

https://lore.kernel.org/all/d84fb798722762862a7fb08f1e343b6a@xxxxxxxxxx/

The message was forwarded by Andy because I had a similar problem with my APU3 [1]
from PC-engine [2], which is also using the PIIX4 for I2C (SMBUS).

Maybe I need to modify ACPI code somehow to create these
'physical_nodesX' folders for the relevant i2c-7/8/9 buses?

I don't know if that helps, but with the following SSDT overlay I managed to get the driver to feel responsible for the mcp23017 via the I2C (SMBUS) of the APU3. The mcp23017 is used on my APU3 to add additional LEDs to '/sys/class/leds'.

```
DefinitionBlock ("mcp.aml", "SSDT", 5, "TEST", "MCP", 2)
{
        External (\_SB.PCI0.SBUS, DeviceObj)

        Scope (\_SB.PCI0.SBUS)
        {
                Device (I2C0)
                {
                        Name (_ADR, Zero)
                        Device (GPIO)
                        {
                                Name (_HID, "PRP0001")
                                Name (_DDN, "MCP23017 pinctrl")
                                Name (_CRS, ResourceTemplate ()
                                {
                                        I2cSerialBus (
                                                0x24,
                                                ControllerInitiated,
                                                100000,
                                                AddressingMode7Bit,
                                                "\\_SB.PCI0.SBUS.I2C0",
                                                0x00
                                        )
                                })
                                Name (_DSD, Package ()
                                {
ToUUID("daffd814-6eba-4d8c-8a91-bc9bbf4aa301"),
                                        Package () {
Package () { "compatible", "microchip,mcp23017" },
                                        }
                                })

                                Device (LEDS)
                                {
                                        Name (_HID, "PRP0001")
                                        Name (_DDN, "GPIO LEDs device")
Name (_CRS, ResourceTemplate () {
                                                GpioIo (
                                                        Exclusive,
                                                        PullNone,
                                                        0,
                                                        0,
IoRestrictionOutputOnly, "\\_SB.PCI0.SBUS.I2C0.GPIO",
                                                        0)
                                                {
                                                        0,
                                                        1,
                                                        2,
                                                        3,
                                                        4,
                                                        5,
                                                        6,
                                                        7,
                                                }
                                        })

                                        Name (_DSD, Package () {
ToUUID("daffd814-6eba-4d8c-8a91-bc9bbf4aa301"),
                                                Package () {
Package () { "compatible", Package() { "gpio-leds" } },
                                                },
ToUUID("dbb8e3e6-5886-4ba6-8795-1319f52a966b"),
                                                Package () {
Package () {"led-0", "LED0"}, Package () {"led-1", "LED1"}, Package () {"led-2", "LED2"}, Package () {"led-3", "LED3"}, Package () {"led-4", "LED4"}, Package () {"led-5", "LED5"}, Package () {"led-6", "LED6"}, Package () {"led-7", "LED7"},
                                                }
                                        })

                                        Name (LED0, Package () {
ToUUID("daffd814-6eba-4d8c-8a91-bc9bbf4aa301"),
                                                Package () {
Package () {"label", "khan:green:led1"}, Package () {"default-state", "off"}, Package () {"linux,default-trigger", "default-off"}, Package () {"gpios", Package () {^LEDS, 0, 0, 1}}, Package () {"retain-state-suspended", 1},
                                                }
                                        })

                                        Name (LED1, Package () {
ToUUID("daffd814-6eba-4d8c-8a91-bc9bbf4aa301"),
                                                Package () {
Package () {"label", "khan:green:led2"}, Package () {"default-state", "off"}, Package () {"linux,default-trigger", "default-off"}, Package () {"gpios", Package () {^LEDS, 0, 1, 1}}, Package () {"retain-state-suspended", 1},
                                                }
                                        })

                                        Name (LED2, Package () {
ToUUID("daffd814-6eba-4d8c-8a91-bc9bbf4aa301"),
                                                Package () {
Package () {"label", "khan:green:led3"}, Package () {"default-state", "off"}, Package () {"linux,default-trigger", "default-off"}, Package () {"gpios", Package () {^LEDS, 0, 2, 1}}, Package () {"retain-state-suspended", 1},
                                                }
                                        })

                                        Name (LED3, Package () {
ToUUID("daffd814-6eba-4d8c-8a91-bc9bbf4aa301"),
                                                Package () {
Package () {"label", "khan:green:led4"}, Package () {"default-state", "off"}, Package () {"linux,default-trigger", "default-off"}, Package () {"gpios", Package () {^LEDS, 0, 3, 1}}, Package () {"retain-state-suspended", 1},
                                                }
                                        })

                                        Name (LED4, Package () {
ToUUID("daffd814-6eba-4d8c-8a91-bc9bbf4aa301"),
                                                Package () {
Package () {"label", "khan:green:led5"}, Package () {"default-state", "off"}, Package () {"linux,default-trigger", "default-off"}, Package () {"gpios", Package () {^LEDS, 0, 4, 1}}, Package () {"retain-state-suspended", 1},
                                                }
                                        })

                                        Name (LED5, Package () {
ToUUID("daffd814-6eba-4d8c-8a91-bc9bbf4aa301"),
                                                Package () {
Package () {"label", "khan:green:led6"}, Package () {"default-state", "off"}, Package () {"linux,default-trigger", "default-off"}, Package () {"gpios", Package () {^LEDS, 0, 5, 1}}, Package () {"retain-state-suspended", 1},
                                                }
                                        })

                                        Name (LED6, Package () {
ToUUID("daffd814-6eba-4d8c-8a91-bc9bbf4aa301"),
                                                Package () {
Package () {"label", "khan:green:led7"}, Package () {"default-state", "off"}, Package () {"linux,default-trigger", "default-off"}, Package () {"gpios", Package () {^LEDS, 0, 6, 1}}, Package () {"retain-state-suspended", 1},
                                                }
                                        })

                                        Name (LED7, Package () {
ToUUID("daffd814-6eba-4d8c-8a91-bc9bbf4aa301"),
                                                Package () {
Package () {"label", "khan:red:led8"}, Package () {"default-state", "off"}, Package () {"linux,default-trigger", "default-off"}, Package () {"gpios", Package () {^LEDS, 0, 7, 1}}, Package () {"retain-state-suspended", 1},
                                                }
                                        })
                                }
                        }
                }
        }
}
```

Best regards

Florian

[1] https://pcengines.ch/apu3d4.htm
[2] https://pcengines.ch/
[3] https://github.com/pcengines/coreboot/blob/8d3e714804b1b2bb5bc89e3ffd9cb3c34f8eb0c6/src/southbridge/amd/pi/hudson/acpi/fch.asl#L29




[Index of Archives]     [Linux GPIO]     [Linux SPI]     [Linux Hardward Monitoring]     [LM Sensors]     [Linux USB Devel]     [Linux Media]     [Video for Linux]     [Linux Audio Users]     [Yosemite News]     [Linux Kernel]     [Linux SCSI]

  Powered by Linux