diff options
author | Rafael J. Wysocki <rafael.j.wysocki@intel.com> | 2017-07-21 02:12:10 +0200 |
---|---|---|
committer | Rafael J. Wysocki <rafael.j.wysocki@intel.com> | 2017-07-24 23:53:46 +0200 |
commit | 9a3ebe3523cc8297301d5d95332536ad123856bf (patch) | |
tree | 2c99ca6d2ba28b7ed99702f0596683f0bb6c1052 /drivers/base | |
parent | 48059c095bafc2ba23da1b3fa26b6ba142cb854f (diff) | |
download | linux-stable-9a3ebe3523cc8297301d5d95332536ad123856bf.tar.gz linux-stable-9a3ebe3523cc8297301d5d95332536ad123856bf.tar.bz2 linux-stable-9a3ebe3523cc8297301d5d95332536ad123856bf.zip |
PM / sleep: Check pm_wakeup_pending() in __device_suspend_noirq()
Restore the pm_wakeup_pending() check in __device_suspend_noirq()
removed by commit eed4d47efe95 (ACPI / sleep: Ignore spurious SCI
wakeups from suspend-to-idle) as that allows the function to return
earlier if there's a wakeup event pending already (so that it may
spend less time on carrying out operations that will be reversed
shortly anyway) and rework the main suspend-to-idle loop to take
that optimization into account.
Signed-off-by: Rafael J. Wysocki <rafael.j.wysocki@intel.com>
Diffstat (limited to 'drivers/base')
-rw-r--r-- | drivers/base/power/main.c | 5 |
1 files changed, 5 insertions, 0 deletions
diff --git a/drivers/base/power/main.c b/drivers/base/power/main.c index f64e5b819e5c..ea1732ed7a9d 100644 --- a/drivers/base/power/main.c +++ b/drivers/base/power/main.c @@ -1105,6 +1105,11 @@ static int __device_suspend_noirq(struct device *dev, pm_message_t state, bool a if (async_error) goto Complete; + if (pm_wakeup_pending()) { + async_error = -EBUSY; + goto Complete; + } + if (dev->power.syscore || dev->power.direct_complete) goto Complete; |