Commit 8d92bc22 authored by Jean Delvare's avatar Jean Delvare Committed by Greg Kroah-Hartman

[PATCH] PCI: Error handling on PCI device resume

We currently don't handle errors properly when resuming a PCI device:
* In pci_default_resume() we capture the error code returned by
  pci_enable_device() but don't pass it up to the caller.
  Introduced by commit 95a62965
* In pci_resume_device(), the errors possibly returned by the driver's
  .resume method or by the generic pci_default_resume() function are
  ignored.

This patch fixes both issues.
Signed-off-by: default avatarJean Delvare <khali@linux-fr.org>
Signed-off-by: default avatarGreg Kroah-Hartman <gregkh@suse.de>
parent 0ce03039
...@@ -285,9 +285,9 @@ static int pci_device_suspend(struct device * dev, pm_message_t state) ...@@ -285,9 +285,9 @@ static int pci_device_suspend(struct device * dev, pm_message_t state)
* Default resume method for devices that have no driver provided resume, * Default resume method for devices that have no driver provided resume,
* or not even a driver at all. * or not even a driver at all.
*/ */
static void pci_default_resume(struct pci_dev *pci_dev) static int pci_default_resume(struct pci_dev *pci_dev)
{ {
int retval; int retval = 0;
/* restore the PCI config space */ /* restore the PCI config space */
pci_restore_state(pci_dev); pci_restore_state(pci_dev);
...@@ -297,18 +297,21 @@ static void pci_default_resume(struct pci_dev *pci_dev) ...@@ -297,18 +297,21 @@ static void pci_default_resume(struct pci_dev *pci_dev)
/* if the device was busmaster before the suspend, make it busmaster again */ /* if the device was busmaster before the suspend, make it busmaster again */
if (pci_dev->is_busmaster) if (pci_dev->is_busmaster)
pci_set_master(pci_dev); pci_set_master(pci_dev);
return retval;
} }
static int pci_device_resume(struct device * dev) static int pci_device_resume(struct device * dev)
{ {
int error;
struct pci_dev * pci_dev = to_pci_dev(dev); struct pci_dev * pci_dev = to_pci_dev(dev);
struct pci_driver * drv = pci_dev->driver; struct pci_driver * drv = pci_dev->driver;
if (drv && drv->resume) if (drv && drv->resume)
drv->resume(pci_dev); error = drv->resume(pci_dev);
else else
pci_default_resume(pci_dev); error = pci_default_resume(pci_dev);
return 0; return error;
} }
static void pci_device_shutdown(struct device *dev) static void pci_device_shutdown(struct device *dev)
......
Markdown is supported
0%
or
You are about to add 0 people to the discussion. Proceed with caution.
Finish editing this message first!
Please register or to comment