ACPI: suspend: Wrong order of GPE restore.
acpi_leave_sleep_state() should have correct list of wake and runtime GPEs, which is available only after disable_wakeup_device() is called. Signed-off-by: Alexey Starikovskiy <astarikovskiy@suse.de> Acked-by: Rafael J. Wysocki <rjw@sisk.pl> Signed-off-by: Len Brown <len.brown@intel.com>
This commit is contained in:
committed by
Len Brown
parent
9c1c6a1ba7
commit
1dbc1fda5d
@@ -167,8 +167,8 @@ static void acpi_pm_finish(void)
|
|||||||
{
|
{
|
||||||
u32 acpi_state = acpi_target_sleep_state;
|
u32 acpi_state = acpi_target_sleep_state;
|
||||||
|
|
||||||
acpi_leave_sleep_state(acpi_state);
|
|
||||||
acpi_disable_wakeup_device(acpi_state);
|
acpi_disable_wakeup_device(acpi_state);
|
||||||
|
acpi_leave_sleep_state(acpi_state);
|
||||||
|
|
||||||
/* reset firmware waking vector */
|
/* reset firmware waking vector */
|
||||||
acpi_set_firmware_waking_vector((acpi_physical_address) 0);
|
acpi_set_firmware_waking_vector((acpi_physical_address) 0);
|
||||||
@@ -272,8 +272,8 @@ static void acpi_hibernation_finish(void)
|
|||||||
* enable it here.
|
* enable it here.
|
||||||
*/
|
*/
|
||||||
acpi_enable();
|
acpi_enable();
|
||||||
acpi_leave_sleep_state(ACPI_STATE_S4);
|
|
||||||
acpi_disable_wakeup_device(ACPI_STATE_S4);
|
acpi_disable_wakeup_device(ACPI_STATE_S4);
|
||||||
|
acpi_leave_sleep_state(ACPI_STATE_S4);
|
||||||
|
|
||||||
/* reset firmware waking vector */
|
/* reset firmware waking vector */
|
||||||
acpi_set_firmware_waking_vector((acpi_physical_address) 0);
|
acpi_set_firmware_waking_vector((acpi_physical_address) 0);
|
||||||
|
Reference in New Issue
Block a user