Re: 回复: 回复: 回复: [PATCH v4 04/20] firmware: scmi: add pin control protocol support to SCMI agent

Marek Vasut marex at denx.de
Mon Mar 3 21:52:56 CET 2025


On 3/3/25 9:04 AM, Alice Guo (OSS) wrote:

[...]

>>> In Linux Kernel, there are two drivers, pinctrl-scmi.c and pinctrl-imx-scmi.c.
>>> Both follows ARM SCMI 3.2, but pinctrl-imx-scmi has some special
>>> settings to align with i.mx iomuxc array based settings, mux,input,pad and etc.
>>>
>>> In gerneral, imx part could be merged with pinctrl-scmi.c but that
>>> will make code not clean.
>> In that case, why does U-Boot not have pinctrl-imx-scmi.c to contain the iMX
>> customization too ? If this protocol is IMX specific, it shouldn't be ifdeffed in
>> common code.
> 
> Is it acceptable to rename " drivers/pinctrl/nxp/pinctrl-scmi.c" to "drivers/pinctrl/nxp/ pinctrl-imx-scmi.c"? SCMI_PROTOCOL_ID_PINCTRL = 0x19 is not i.MX specific.

Look at this commit, which allows drivers placed in some driver.c file 
insert their driver entry into a linker list, and then some common code 
can iterate over this linker list and match drivers against some properties.

In this case, it is a PHY driver which does list supported PHY IDs in 
each U_BOOT_PHY_DRIVER, and the common code checks whether the PHY IDs 
match when a new PHY gets registered:

7940a93eb977 ("net: phy: Iterate over both registered PHYs and struct 
phy_driver linker list")

This is the driver side conversion example:

20bd8e4fcbb5 ("net: phy: gen10g: Convert to U_BOOT_PHY_DRIVER()")

What you could do is the same:

- Basically duplicate the mechanism in 7940a93eb977 ("net: phy: Iterate 
over both registered PHYs and struct phy_driver linker list"), call it 
e.g. U_BOOT_SCMI_DRIVER()
- Switch SCMI drivers to use U_BOOT_SCMI_DRIVER , have each one list a 
protocol ID (instead of the PHY IDs), and then use the 
scmi_agent-uclass.c to iterate over all the linker lists

About the MX95 specifics and handling those, it is possible to have two 
drivers which support the same hardware compiled into U-Boot and have 
them decide at bind time which driver should bind and which not, look at 
drivers/mtd/renesas_rpc_hf.c rpc_hf_probe() and 
drivers/spi/renesas_rpc_spi.c rpc_spi_bind() for example of doing this.

I hope this helps untangle the SCMI implementation.


More information about the U-Boot mailing list