Commit 0791721d authored by Sean V Kelley's avatar Sean V Kelley Committed by Bjorn Helgaas

PCI/ERR: Use "bridge" for clarity in pcie_do_recovery()

pcie_do_recovery() may be called with "dev" being either a bridge (Root
Port or Switch Downstream Port) or an Endpoint.  The bulk of the function
deals with the bridge, so if we start with an Endpoint, we reset "dev" to
be the bridge leading to it.

For clarity, replace "dev" in the body of the function with "bridge".  No
functional change intended.

Link: https://lore.kernel.org/r/20201121001036.8560-8-sean.v.kelley@intel.com
Tested-by: Jonathan Cameron <Jonathan.Cameron@huawei.com> # non-native/no RCEC
Signed-off-by: default avatarSean V Kelley <sean.v.kelley@intel.com>
Signed-off-by: default avatarBjorn Helgaas <bhelgaas@google.com>
Reviewed-by: default avatarKuppuswamy Sathyanarayanan <sathyanarayanan.kuppuswamy@linux.intel.com>
Acked-by: default avatarJonathan Cameron <Jonathan.Cameron@huawei.com>
parent 480ef7cb
...@@ -151,24 +151,27 @@ pci_ers_result_t pcie_do_recovery(struct pci_dev *dev, ...@@ -151,24 +151,27 @@ pci_ers_result_t pcie_do_recovery(struct pci_dev *dev,
pci_ers_result_t (*reset_subordinates)(struct pci_dev *pdev)) pci_ers_result_t (*reset_subordinates)(struct pci_dev *pdev))
{ {
int type = pci_pcie_type(dev); int type = pci_pcie_type(dev);
pci_ers_result_t status = PCI_ERS_RESULT_CAN_RECOVER; struct pci_dev *bridge;
struct pci_bus *bus; struct pci_bus *bus;
pci_ers_result_t status = PCI_ERS_RESULT_CAN_RECOVER;
/* /*
* Error recovery runs on all subordinates of the first downstream port. * Error recovery runs on all subordinates of the bridge. If the
* If the downstream port detected the error, it is cleared at the end. * bridge detected the error, it is cleared at the end.
*/ */
if (!(type == PCI_EXP_TYPE_ROOT_PORT || if (!(type == PCI_EXP_TYPE_ROOT_PORT ||
type == PCI_EXP_TYPE_DOWNSTREAM)) type == PCI_EXP_TYPE_DOWNSTREAM))
dev = pci_upstream_bridge(dev); bridge = pci_upstream_bridge(dev);
bus = dev->subordinate; else
bridge = dev;
pci_dbg(dev, "broadcast error_detected message\n"); bus = bridge->subordinate;
pci_dbg(bridge, "broadcast error_detected message\n");
if (state == pci_channel_io_frozen) { if (state == pci_channel_io_frozen) {
pci_walk_bus(bus, report_frozen_detected, &status); pci_walk_bus(bus, report_frozen_detected, &status);
status = reset_subordinates(dev); status = reset_subordinates(bridge);
if (status != PCI_ERS_RESULT_RECOVERED) { if (status != PCI_ERS_RESULT_RECOVERED) {
pci_warn(dev, "subordinate device reset failed\n"); pci_warn(bridge, "subordinate device reset failed\n");
goto failed; goto failed;
} }
} else { } else {
...@@ -177,7 +180,7 @@ pci_ers_result_t pcie_do_recovery(struct pci_dev *dev, ...@@ -177,7 +180,7 @@ pci_ers_result_t pcie_do_recovery(struct pci_dev *dev,
if (status == PCI_ERS_RESULT_CAN_RECOVER) { if (status == PCI_ERS_RESULT_CAN_RECOVER) {
status = PCI_ERS_RESULT_RECOVERED; status = PCI_ERS_RESULT_RECOVERED;
pci_dbg(dev, "broadcast mmio_enabled message\n"); pci_dbg(bridge, "broadcast mmio_enabled message\n");
pci_walk_bus(bus, report_mmio_enabled, &status); pci_walk_bus(bus, report_mmio_enabled, &status);
} }
...@@ -188,27 +191,27 @@ pci_ers_result_t pcie_do_recovery(struct pci_dev *dev, ...@@ -188,27 +191,27 @@ pci_ers_result_t pcie_do_recovery(struct pci_dev *dev,
* drivers' slot_reset callbacks? * drivers' slot_reset callbacks?
*/ */
status = PCI_ERS_RESULT_RECOVERED; status = PCI_ERS_RESULT_RECOVERED;
pci_dbg(dev, "broadcast slot_reset message\n"); pci_dbg(bridge, "broadcast slot_reset message\n");
pci_walk_bus(bus, report_slot_reset, &status); pci_walk_bus(bus, report_slot_reset, &status);
} }
if (status != PCI_ERS_RESULT_RECOVERED) if (status != PCI_ERS_RESULT_RECOVERED)
goto failed; goto failed;
pci_dbg(dev, "broadcast resume message\n"); pci_dbg(bridge, "broadcast resume message\n");
pci_walk_bus(bus, report_resume, &status); pci_walk_bus(bus, report_resume, &status);
if (pcie_aer_is_native(dev)) if (pcie_aer_is_native(bridge))
pcie_clear_device_status(dev); pcie_clear_device_status(bridge);
pci_aer_clear_nonfatal_status(dev); pci_aer_clear_nonfatal_status(bridge);
pci_info(dev, "device recovery successful\n"); pci_info(bridge, "device recovery successful\n");
return status; return status;
failed: failed:
pci_uevent_ers(dev, PCI_ERS_RESULT_DISCONNECT); pci_uevent_ers(bridge, PCI_ERS_RESULT_DISCONNECT);
/* TODO: Should kernel panic here? */ /* TODO: Should kernel panic here? */
pci_info(dev, "device recovery failed\n"); pci_info(bridge, "device recovery failed\n");
return status; return status;
} }
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