diff options
author | Konstantin Khlebnikov <khlebnikov@openvz.org> | 2013-02-04 12:56:01 +0100 |
---|---|---|
committer | Bjorn Helgaas <bhelgaas@google.com> | 2013-02-12 01:25:04 +0100 |
commit | fd6dceab017e6be6c158dc56ec6dacf817f21a5b (patch) | |
tree | 0c46af88031a7e334044a892dcf24fca6efe2e44 | |
parent | PCI: Disable Bus Master unconditionally in pci_device_shutdown() (diff) | |
download | linux-fd6dceab017e6be6c158dc56ec6dacf817f21a5b.tar.xz linux-fd6dceab017e6be6c158dc56ec6dacf817f21a5b.zip |
PCI: Catch attempts to disable already-disabled devices
Warn when disabling a device that has already been disabled.
[bhelgaas: message wording]
Signed-off-by: Konstantin Khlebnikov <khlebnikov@openvz.org>
Signed-off-by: Bjorn Helgaas <bhelgaas@google.com>
Acked-by: Rafael J. Wysocki <rafael.j.wysocki@intel.com>
-rw-r--r-- | drivers/pci/pci.c | 3 |
1 files changed, 3 insertions, 0 deletions
diff --git a/drivers/pci/pci.c b/drivers/pci/pci.c index 5cb5820fae40..29a09b705f04 100644 --- a/drivers/pci/pci.c +++ b/drivers/pci/pci.c @@ -1401,6 +1401,9 @@ pci_disable_device(struct pci_dev *dev) if (dr) dr->enabled = 0; + dev_WARN_ONCE(&dev->dev, atomic_read(&dev->enable_cnt) <= 0, + "disabling already-disabled device"); + if (atomic_sub_return(1, &dev->enable_cnt) != 0) return; |