@@ -1030,8 +1030,9 @@ void pci_wakeup_bus(struct pci_bus *bus)
pci_walk_bus(bus, pci_wakeup, NULL);
}
-static int pci_dev_wait(struct pci_dev *dev, char *reset_type)
+static int pci_dev_wait(struct pci_dev *dev, enum pci_init_event event)
{
+ const char *event_name = pci_init_event_name(event);
int timeout = PCIE_RESET_READY_POLL_MS;
int delay = 1;
u32 id;
@@ -1052,13 +1053,13 @@ static int pci_dev_wait(struct pci_dev *dev, char *reset_type)
while (id == ~0) {
if (delay > timeout) {
pci_warn(dev, "not ready %dms after %s; giving up\n",
- delay - 1, reset_type);
+ delay - 1, event_name);
return -ETIMEDOUT;
}
if (delay > 1000)
pci_info(dev, "not ready %dms after %s; waiting\n",
- delay - 1, reset_type);
+ delay - 1, event_name);
msleep(delay);
delay *= 2;
@@ -1067,7 +1068,7 @@ static int pci_dev_wait(struct pci_dev *dev, char *reset_type)
if (delay > 1000)
pci_info(dev, "ready %dms after %s\n", delay - 1,
- reset_type);
+ event_name);
return 0;
}
@@ -4515,7 +4516,7 @@ int pcie_flr(struct pci_dev *dev)
msleep(dev->delay[PCI_INIT_EVENT_FLR]);
- return pci_dev_wait(dev, "FLR");
+ return pci_dev_wait(dev, PCI_INIT_EVENT_FLR);
}
EXPORT_SYMBOL_GPL(pcie_flr);
@@ -4554,7 +4555,7 @@ static int pci_af_flr(struct pci_dev *dev, int probe)
msleep(dev->delay[PCI_INIT_EVENT_FLR]);
- return pci_dev_wait(dev, "AF_FLR");
+ return pci_dev_wait(dev, PCI_INIT_EVENT_FLR);
}
/**
@@ -4601,7 +4602,7 @@ static int pci_pm_reset(struct pci_dev *dev, int probe)
pci_write_config_word(dev, dev->pm_cap + PCI_PM_CTRL, csr);
pci_dev_d3_sleep(dev);
- return pci_dev_wait(dev, "PM D3hot->D0");
+ return pci_dev_wait(dev, PCI_INIT_EVENT_D3HOT_TO_D0);
}
/**
@@ -4843,7 +4844,7 @@ int pci_bridge_secondary_bus_reset(struct pci_dev *dev)
{
pcibios_reset_secondary_bus(dev);
- return pci_dev_wait(dev, "bus reset");
+ return pci_dev_wait(dev, PCI_INIT_EVENT_RESET);
}
EXPORT_SYMBOL_GPL(pci_bridge_secondary_bus_reset);