[PATCH] pinctrl: meson: support gpio toggle command
Yang Xiwen
forbidden405 at outlook.com
Mon Jun 16 18:58:25 CEST 2025
On 6/17/2025 12:40 AM, Neil Armstrong wrote:
> On 16/06/2025 18:23, Yang Xiwen via B4 Relay wrote:
>> From: Yang Xiwen <forbidden405 at outlook.com>
>>
>> meson_gpio_get() always assumes gpio is configured to input mode. This
>> is incorrect and breaks `gpio toggle` command:
>>
>> gpio: pin aobus-banks2 (gpio 2) value is 0
>> Warning: value of pin is still 1
>>
>> Fix it by adding the logic to handle both input and output mode.
>>
>> Fixes: 2009a8d03fe5 ("pinctrl: meson: add GPIO support")
>> Signed-off-by: Yang Xiwen <forbidden405 at outlook.com>
>> ---
>> drivers/pinctrl/meson/pinctrl-meson.c | 21 ++++++++++++++++++++-
>> 1 file changed, 20 insertions(+), 1 deletion(-)
>>
>> diff --git a/drivers/pinctrl/meson/pinctrl-meson.c
>> b/drivers/pinctrl/meson/pinctrl-meson.c
>> index babf1bccc969..a1f4afd11f94 100644
>> --- a/drivers/pinctrl/meson/pinctrl-meson.c
>> +++ b/drivers/pinctrl/meson/pinctrl-meson.c
>> @@ -117,8 +117,27 @@ int meson_gpio_get(struct udevice *dev, unsigned
>> int offset)
>> struct meson_pinctrl *priv = dev_get_priv(dev->parent);
>> unsigned int reg, bit;
>> int ret;
>> + enum gpio_func_t direction;
>> + enum meson_reg_type reg_type;
>> - ret = meson_gpio_calc_reg_and_bit(dev->parent, offset, REG_IN,
>> ®,
>> + direction = meson_gpio_get_direction(dev, offset);
>> +
>> + switch (direction) {
>> + case GPIOF_INPUT:
>> + reg_type = REG_IN;
>> + break;
>> +
>> + case GPIOF_OUTPUT:
>> + reg_type = REG_OUT;
>> + break;
>> +
>> + default:
>> + reg_type = REG_IN;
>> + dev_warn(dev, "Failed to get current direction of Pin %u\n",
>> offset);
>> + break;
>
> Just return -EINVAL here
Fixed in v2
>
> Thanks,
> Neil
>
>> + }
>> +
>> + ret = meson_gpio_calc_reg_and_bit(dev->parent, offset, reg_type,
>> ®,
>> &bit);
>> if (ret)
>> return ret;
>>
>> ---
>> base-commit: c5afa1fef49f55146e78d6157470520391c40eca
>> change-id: 20250617-meson_ppinctrl-5139ca06b828
>>
>> Best regards,
>
--
Regards,
Yang Xiwen
More information about the U-Boot
mailing list