]> www.infradead.org Git - users/hch/block.git/commitdiff
ACPI / PM: Do not reconfigure GPEs for suspend-to-idle
authorRafael J. Wysocki <rafael.j.wysocki@intel.com>
Tue, 20 Feb 2018 11:10:32 +0000 (12:10 +0100)
committerRafael J. Wysocki <rafael.j.wysocki@intel.com>
Wed, 21 Feb 2018 22:53:34 +0000 (23:53 +0100)
It is reported that commit 235d81a630ca (ACPI / PM: Clean up device
wakeup enable/disable code) broke wakeup from suspend-to-idle on
some platforms.  That is due to the acpi_enable_all_wakeup_gpes() in
acpi_s2idle_prepare() which needs acpi_enable_wakeup_devices() to be
called before it as the latter sets up the GPE masks used by the
former and commit 235d81a630ca removed acpi_enable_wakeup_devices()
invocation from the suspend-to-idle path.

However, acpi_enable_wakeup_devices() does more than just setting
the GPE masks and the remaining part of it is not necessary for
suspend-to-idle.  Moreover, non-wakeup GPEs are disabled on suspend-
to-idle entry to avoid spurious wakeups, but that should not be
strictly necessary any more after commit 33e4f80ee69b (ACPI / PM:
Ignore spurious SCI wakeups from suspend-to-idle) which prevents
spurious GPE wakeups from resuming the system.  The only consequence
of leaving non-wakeup GPEs enabled may be more interrupt-related
activity while suspended, which is not ideal (more energy is used
if that happens), but it is not critical too.

For this reason, drop the GPE reconfiguration from the suspend-to-idle
path entirely.

This change also allows Dells XPS13 9360 blacklisted by commit
71630b7a832f (ACPI / PM: Blacklist Low Power S0 Idle _DSM for Dell
XPS13 9360) to use the power button for waking up from suspend-
to-idle and it helps at least one other older Dell system (the
wakeup button GPE on that one is not listed in _PRW for any
devices, so it is not regarded as a wakeup one and gets disabled
on suspend-to-idle entry today).

Fixes: 235d81a630ca (ACPI / PM: Clean up device wakeup enable/disable code)
Reported-by: Du Wenkai <wenkai.du@intel.com>
Tested-by: Du Wenkai <wenkai.du@intel.com>
Signed-off-by: Rafael J. Wysocki <rafael.j.wysocki@intel.com>
drivers/acpi/sleep.c

index 46cde0912762e5d8d68aaa5611a7eebb9d4caedd..c53119740a3c1cf405253237be47892fd22ff4ac 100644 (file)
@@ -953,15 +953,8 @@ static int acpi_s2idle_prepare(void)
        if (lps0_device_handle) {
                acpi_sleep_run_lps0_dsm(ACPI_LPS0_SCREEN_OFF);
                acpi_sleep_run_lps0_dsm(ACPI_LPS0_ENTRY);
-       } else {
-               /*
-                * The configuration of GPEs is changed here to avoid spurious
-                * wakeups, but that should not be necessary if this is a
-                * "low-power S0" platform and the low-power S0 _DSM is present.
-                */
-               acpi_enable_all_wakeup_gpes();
-               acpi_os_wait_events_complete();
        }
+
        if (acpi_sci_irq_valid())
                enable_irq_wake(acpi_sci_irq);
 
@@ -1007,8 +1000,6 @@ static void acpi_s2idle_restore(void)
        if (lps0_device_handle) {
                acpi_sleep_run_lps0_dsm(ACPI_LPS0_EXIT);
                acpi_sleep_run_lps0_dsm(ACPI_LPS0_SCREEN_ON);
-       } else {
-               acpi_enable_all_runtime_gpes();
        }
 }