aboutsummaryrefslogtreecommitdiffstats
path: root/drivers/pci/pcie/aer.c
diff options
context:
space:
mode:
authorOza Pawandeep <poza@codeaurora.org>2018-07-19 18:58:09 -0400
committerBjorn Helgaas <bhelgaas@google.com>2018-07-20 16:27:11 -0400
commitec752f5d54d723af3df03959637f963079643cd8 (patch)
tree0971a3766e29d77ff89e963b551d429cb7c6f0ef /drivers/pci/pcie/aer.c
parent43ec03a9e5f382ff70fdef35b4ea813263cd8270 (diff)
PCI/AER: Clear device status bits during ERR_FATAL and ERR_NONFATAL
Clear the device status bits while handling both ERR_FATAL and ERR_NONFATAL cases. Signed-off-by: Oza Pawandeep <poza@codeaurora.org> [bhelgaas: rename to pci_aer_clear_device_status(), declare internal to PCI core instead of exposing it everywhere] Signed-off-by: Bjorn Helgaas <bhelgaas@google.com>
Diffstat (limited to 'drivers/pci/pcie/aer.c')
-rw-r--r--drivers/pci/pcie/aer.c15
1 files changed, 9 insertions, 6 deletions
diff --git a/drivers/pci/pcie/aer.c b/drivers/pci/pcie/aer.c
index 4411ada4a91c..2a40b24ae4e3 100644
--- a/drivers/pci/pcie/aer.c
+++ b/drivers/pci/pcie/aer.c
@@ -382,6 +382,14 @@ int pci_disable_pcie_error_reporting(struct pci_dev *dev)
382} 382}
383EXPORT_SYMBOL_GPL(pci_disable_pcie_error_reporting); 383EXPORT_SYMBOL_GPL(pci_disable_pcie_error_reporting);
384 384
385void pci_aer_clear_device_status(struct pci_dev *dev)
386{
387 u16 sta;
388
389 pcie_capability_read_word(dev, PCI_EXP_DEVSTA, &sta);
390 pcie_capability_write_word(dev, PCI_EXP_DEVSTA, sta);
391}
392
385int pci_cleanup_aer_uncorrect_error_status(struct pci_dev *dev) 393int pci_cleanup_aer_uncorrect_error_status(struct pci_dev *dev)
386{ 394{
387 int pos; 395 int pos;
@@ -1532,12 +1540,7 @@ static pci_ers_result_t aer_root_reset(struct pci_dev *dev)
1532 */ 1540 */
1533static void aer_error_resume(struct pci_dev *dev) 1541static void aer_error_resume(struct pci_dev *dev)
1534{ 1542{
1535 u16 reg16; 1543 pci_aer_clear_device_status(dev);
1536
1537 /* Clean up Root device status */
1538 pcie_capability_read_word(dev, PCI_EXP_DEVSTA, &reg16);
1539 pcie_capability_write_word(dev, PCI_EXP_DEVSTA, reg16);
1540
1541 pci_cleanup_aer_uncorrect_error_status(dev); 1544 pci_cleanup_aer_uncorrect_error_status(dev);
1542} 1545}
1543 1546