[PATCH] input: gpio-keys: initialize the input value with the current gpioval

Sascha Hauer s.hauer at pengutronix.de
Thu Jul 2 01:18:24 PDT 2026


Hi Marco,

I just sent an alternative patch which avoids some code duplication.
It's untested, maybe you could spin a test for your case.

Sascha

On 2026-06-25 13:51, Marco Felsch wrote:
> This is required for deep-probe systems which prove the "gpio-keys"
> device on demand. In such case the input value is not yet accessible
> once the probe finished. However, board code queries the input device
> value directly after the of.*ensure.*probed().
> 
> Therefore provide a sane default by reading the gpio value during probe
> and init the input device value.
> 
> Signed-off-by: Marco Felsch <m.felsch at pengutronix.de>
> ---
>  drivers/input/gpio_keys.c | 22 ++++++++++++++++++++++
>  1 file changed, 22 insertions(+)
> 
> diff --git a/drivers/input/gpio_keys.c b/drivers/input/gpio_keys.c
> index b52738f5ccb2..316ed73ddfd1 100644
> --- a/drivers/input/gpio_keys.c
> +++ b/drivers/input/gpio_keys.c
> @@ -143,6 +143,26 @@ static int gpio_keys_probe_dt(struct gpio_keys *gk, struct device *dev)
>  	return 0;
>  }
>  
> +static int gpio_keys_set_initialval(struct gpio_keys *gk)
> +{
> +	struct gpio_key *gb;
> +	int i, pressed;
> +
> +	for (i = 0; i < gk->nbuttons; i++) {
> +
> +		gb = &gk->buttons[i];
> +		pressed = gpiod_get_value(gb->gpio);
> +
> +		if (pressed != gb->previous_state) {
> +			gb->debounce_start = get_time_ns();
> +			input_report_key_event(&gk->input, gb->code, pressed);
> +			dev_dbg(gk->input.parent, "%s gpio #%d as %d\n",
> +				pressed ? "pressed" : "released", i, gb->code);
> +			gb->previous_state = pressed;
> +		}
> +	}
> +}
> +
>  static int __init gpio_keys_probe(struct device *dev)
>  {
>  	int ret;
> @@ -163,6 +183,8 @@ static int __init gpio_keys_probe(struct device *dev)
>  	if (ret)
>  		return ret;
>  
> +	gpio_keys_set_initialval(gk);
> +
>  	ret = poller_async_register(&gk->poller, dev_name(dev));
>  	if (ret)
>  		return ret;
> -- 
> 2.47.3
> 
> 
> 

-- 
Pengutronix e.K.                           |                             |
Steuerwalder Str. 21                       | http://www.pengutronix.de/  |
31137 Hildesheim, Germany                  | Phone: +49-5121-206917-0    |
Amtsgericht Hildesheim, HRA 2686           | Fax:   +49-5121-206917-5555 |



More information about the barebox mailing list