diff options
author | Rafael J. Wysocki <rafael.j.wysocki@intel.com> | 2018-05-09 00:18:32 +0200 |
---|---|---|
committer | Rafael J. Wysocki <rafael.j.wysocki@intel.com> | 2018-05-10 16:50:26 +0200 |
commit | cfcadfaad7251d8b640713724b388164d75465b2 (patch) | |
tree | 7884aafbceb05c029aef956448a55c60fe6a5b36 /drivers/pci/iov.c | |
parent | PCI / PM: Always check PME wakeup capability for runtime wakeup support (diff) | |
download | linux-cfcadfaad7251d8b640713724b388164d75465b2.tar.xz linux-cfcadfaad7251d8b640713724b388164d75465b2.zip |
PCI / PM: Check device_may_wakeup() in pci_enable_wake()
Commit 0847684cfc5f0 (PCI / PM: Simplify device wakeup settings code)
went too far and dropped the device_may_wakeup() check from
pci_enable_wake() which causes wakeup to be enabled during system
suspend, hibernation or shutdown for some PCI devices that are not
allowed by user space to wake up the system from sleep (or power off).
As a result of this, excessive power is drawn by some of the affected
systems while in sleep states or off.
Restore the device_may_wakeup() check in pci_enable_wake(), but make
sure that the PCI bus type's runtime suspend callback will not call
device_may_wakeup() which is about system wakeup from sleep and not
about device wakeup from runtime suspend.
Fixes: 0847684cfc5f0 (PCI / PM: Simplify device wakeup settings code)
Reported-by: Joseph Salisbury <joseph.salisbury@canonical.com>
Cc: 4.13+ <stable@vger.kernel.org> # 4.13+
Signed-off-by: Rafael J. Wysocki <rafael.j.wysocki@intel.com>
Acked-by: Bjorn Helgaas <bhelgaas@google.com>
Diffstat (limited to 'drivers/pci/iov.c')
0 files changed, 0 insertions, 0 deletions