For "freeze" mode of suspend, cpu will go into idle and those wakeup sources' irq should NOT be disabled during devices suspend, so we need to add IRQF_NO_SUSPEND flag for those wakeup sources. Steps to test this patch: 1. echo freeze > /sys/power/state; 2. press gpio key which has wakeup function, then system will resume. Signed-off-by: Anson Huang <b20788@xxxxxxxxxxxxx> --- drivers/input/keyboard/gpio_keys.c | 2 ++ 1 file changed, 2 insertions(+) diff --git a/drivers/input/keyboard/gpio_keys.c b/drivers/input/keyboard/gpio_keys.c index 2db1324..aadb1db 100644 --- a/drivers/input/keyboard/gpio_keys.c +++ b/drivers/input/keyboard/gpio_keys.c @@ -473,6 +473,8 @@ static int gpio_keys_setup_key(struct platform_device *pdev, isr = gpio_keys_gpio_isr; irqflags = IRQF_TRIGGER_RISING | IRQF_TRIGGER_FALLING; + if (bdata->button->wakeup) + irqflags |= IRQF_NO_SUSPEND; } else { if (!button->irq) { -- 1.7.9.5 -- To unsubscribe from this list: send the line "unsubscribe linux-input" in the body of a message to majordomo@xxxxxxxxxxxxxxx More majordomo info at http://vger.kernel.org/majordomo-info.html