diff options
author | Keith Busch <kbusch@kernel.org> | 2021-01-04 15:03:00 -0800 |
---|---|---|
committer | Bjorn Helgaas <bhelgaas@google.com> | 2021-02-23 17:10:42 -0600 |
commit | ba952824e6c106f979c07814c8e3ef7405dd7b29 (patch) | |
tree | 85dd9804b3d4009f390acb26cbc887e15500bd23 /drivers/pci/pcie | |
parent | 33ac78bd3b509d36e7f109a447e28af42e637cb2 (diff) | |
download | lwn-ba952824e6c106f979c07814c8e3ef7405dd7b29.tar.gz lwn-ba952824e6c106f979c07814c8e3ef7405dd7b29.zip |
PCI/portdrv: Report reset for frozen channel
The PCI error recovery always resets the link for a frozen state, so the
port driver should return that a reset is required for its result. This
will get the .slot_reset() callback invoked, which is necessary to
restore the port's config space. Without this, the driver had been
relying on downstream drivers to return this status.
Link: https://lore.kernel.org/r/20210104230300.1277180-6-kbusch@kernel.org
Tested-by: Hedi Berriche <hedi.berriche@hpe.com>
Signed-off-by: Keith Busch <kbusch@kernel.org>
Signed-off-by: Bjorn Helgaas <bhelgaas@google.com>
Acked-by: Hedi Berriche <hedi.berriche@hpe.com>
Diffstat (limited to 'drivers/pci/pcie')
-rw-r--r-- | drivers/pci/pcie/portdrv_pci.c | 3 |
1 files changed, 2 insertions, 1 deletions
diff --git a/drivers/pci/pcie/portdrv_pci.c b/drivers/pci/pcie/portdrv_pci.c index 0b250bc5f405..de141bfb0bc2 100644 --- a/drivers/pci/pcie/portdrv_pci.c +++ b/drivers/pci/pcie/portdrv_pci.c @@ -153,7 +153,8 @@ static void pcie_portdrv_remove(struct pci_dev *dev) static pci_ers_result_t pcie_portdrv_error_detected(struct pci_dev *dev, pci_channel_state_t error) { - /* Root Port has no impact. Always recovers. */ + if (error == pci_channel_io_frozen) + return PCI_ERS_RESULT_NEED_RESET; return PCI_ERS_RESULT_CAN_RECOVER; } |