[PATCH v8 02/19] pinctrl: nxp: add a pin controller driver based on SCMI pin control protocol
Marek Vasut
marex at denx.de
Sat Mar 22 01:46:02 CET 2025
On 3/21/25 8:15 AM, Alice Guo (OSS) wrote:
[...]
> +static int imx_scmi_pinctrl_probe(struct udevice *dev)
> +{
> + struct imx_scmi_pinctrl_priv *priv = dev_get_priv(dev);
> +
> + priv->daisy_offset = is_imx93() ? DAISY_OFFSET_IMX93 : DAISY_OFFSET_IMX95;
> +
> + return devm_scmi_of_get_channel(dev);
> +}
> +
> +static int imx_scmi_pinctrl_bind(struct udevice *dev)
> +{
> + if (IS_ENABLED(CONFIG_IMX95))
> + return 0;
Why does this driver support iMX93 , but it is explicitly not going to
bind on iMX93 ?
In case the MX93 support is going to be added, you probably need
something like:
if (IS_ENABLED(CONFIG_IMX95) && is_imx95())
return 0;
Because IS_ENABLED(CONFIG_IMX95) does not automatically imply that this
code is started on MX95 , that is when is_imx95() comes into play and
does runtime check for MX95 .
> + return -ENODEV;
> +}
> +
> +U_BOOT_DRIVER(scmi_pinctrl_imx) = {
> + .name = "scmi_pinctrl_imx",
> + .id = UCLASS_PINCTRL,
> + .bind = imx_scmi_pinctrl_bind,
> + .probe = imx_scmi_pinctrl_probe,
> + .priv_auto = sizeof(struct imx_scmi_pinctrl_priv),
> + .ops = &imx_scmi_pinctrl_ops,
> + .flags = DM_FLAG_PRE_RELOC,
> +};
> diff --git a/include/scmi_protocols.h b/include/scmi_protocols.h
> index 7abb2a6f36b..279ebbad440 100644
> --- a/include/scmi_protocols.h
> +++ b/include/scmi_protocols.h
> @@ -24,6 +24,7 @@ enum scmi_std_protocol {
> SCMI_PROTOCOL_ID_SENSOR = 0x15,
> SCMI_PROTOCOL_ID_RESET_DOMAIN = 0x16,
> SCMI_PROTOCOL_ID_VOLTAGE_DOMAIN = 0x17,
> + SCMI_PROTOCOL_ID_PINCTRL = 0x19,
If this is the IMX specific pinctrl protocol, please make sure to name
it accordingly , SCMI_PROTOCOL_ID_PINCTRL_IMX or something .
More information about the U-Boot
mailing list