gpio-button-hotplug: debounce the initial button state, the first reads at boot time might be wrong

Signed-off-by: Felix Fietkau <nbd@openwrt.org>

SVN-Revision: 37702
master
Felix Fietkau 11 years ago
parent 158cc23d39
commit 6743f2625b
  1. 6
      package/kernel/gpio-button-hotplug/src/gpio-button-hotplug.c

@ -298,7 +298,9 @@ static void gpio_keys_polled_check_state(struct gpio_keys_button *button,
return; return;
} }
button_hotplug_event(bdata, type, button->code, state); if (bdata->last_state != -1)
button_hotplug_event(bdata, type, button->code, state);
bdata->last_state = state; bdata->last_state = state;
} }
@ -508,7 +510,7 @@ static int gpio_keys_polled_probe(struct platform_device *pdev)
} }
bdata->can_sleep = gpio_cansleep(gpio); bdata->can_sleep = gpio_cansleep(gpio);
bdata->last_state = gpio_button_get_value(button, bdata); bdata->last_state = -1;
bdata->threshold = DIV_ROUND_UP(button->debounce_interval, bdata->threshold = DIV_ROUND_UP(button->debounce_interval,
pdata->poll_interval); pdata->poll_interval);
} }

Loading…
Cancel
Save