[PATCH v2 03/23] sunxi: pinctrl: Implement get_pin_muxing function

Andre Przywara andre.przywara at arm.com
Fri Apr 1 01:36:14 CEST 2022


On Thu, 17 Mar 2022 22:54:00 -0500
Samuel Holland <samuel at sholland.org> wrote:

> The pinmux command uses this function to display pinmux status.
> 
> Since the driver cannot map pin numbers to a list of supported
> functions, only functions which are common across all pins can be
> reported by name.
> 
> Signed-off-by: Samuel Holland <samuel at sholland.org>

I can surely live with that drawback:

Reviewed-by: Andre Przywara <andre.przywara at arm.com>

Cheers,
Andre

> ---
> 
> (no changes since v1)
> 
>  drivers/pinctrl/sunxi/pinctrl-sunxi.c | 27 +++++++++++++++++++++++++++
>  1 file changed, 27 insertions(+)
> 
> diff --git a/drivers/pinctrl/sunxi/pinctrl-sunxi.c b/drivers/pinctrl/sunxi/pinctrl-sunxi.c
> index 6ea8245c8e..4e453cec54 100644
> --- a/drivers/pinctrl/sunxi/pinctrl-sunxi.c
> +++ b/drivers/pinctrl/sunxi/pinctrl-sunxi.c
> @@ -82,6 +82,32 @@ static int sunxi_pinctrl_pinmux_set(struct udevice *dev, uint pin_selector,
>  	return 0;
>  }
>  
> +static int sunxi_pinctrl_get_pin_muxing(struct udevice *dev, uint pin_selector,
> +					char *buf, int size)
> +{
> +	struct sunxi_pinctrl_plat *plat = dev_get_plat(dev);
> +	int bank = pin_selector / SUNXI_GPIOS_PER_BANK;
> +	int pin	 = pin_selector % SUNXI_GPIOS_PER_BANK;
> +	int mux  = sunxi_gpio_get_cfgbank(plat->base + bank, pin);
> +
> +	switch (mux) {
> +	case SUNXI_GPIO_INPUT:
> +		strlcpy(buf, "gpio input", size);
> +		break;
> +	case SUNXI_GPIO_OUTPUT:
> +		strlcpy(buf, "gpio output", size);
> +		break;
> +	case SUNXI_GPIO_DISABLE:
> +		strlcpy(buf, "disabled", size);
> +		break;
> +	default:
> +		snprintf(buf, size, "function %d", mux);
> +		break;
> +	}
> +
> +	return 0;
> +}
> +
>  static const struct pinctrl_ops sunxi_pinctrl_ops = {
>  	.get_pins_count		= sunxi_pinctrl_get_pins_count,
>  	.get_pin_name		= sunxi_pinctrl_get_pin_name,
> @@ -89,6 +115,7 @@ static const struct pinctrl_ops sunxi_pinctrl_ops = {
>  	.get_function_name	= sunxi_pinctrl_get_function_name,
>  	.pinmux_set		= sunxi_pinctrl_pinmux_set,
>  	.set_state		= pinctrl_generic_set_state,
> +	.get_pin_muxing		= sunxi_pinctrl_get_pin_muxing,
>  };
>  
>  static int sunxi_pinctrl_bind(struct udevice *dev)



More information about the U-Boot mailing list