diff options
author | Oza Pawandeep <poza@codeaurora.org> | 2018-07-19 18:58:09 -0400 |
---|---|---|
committer | Bjorn Helgaas <bhelgaas@google.com> | 2018-07-20 16:27:11 -0400 |
commit | ec752f5d54d723af3df03959637f963079643cd8 (patch) | |
tree | 0971a3766e29d77ff89e963b551d429cb7c6f0ef /drivers/pci/pcie/aer.c | |
parent | 43ec03a9e5f382ff70fdef35b4ea813263cd8270 (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.c | 15 |
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 | } |
383 | EXPORT_SYMBOL_GPL(pci_disable_pcie_error_reporting); | 383 | EXPORT_SYMBOL_GPL(pci_disable_pcie_error_reporting); |
384 | 384 | ||
385 | void 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 | |||
385 | int pci_cleanup_aer_uncorrect_error_status(struct pci_dev *dev) | 393 | int 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 | */ |
1533 | static void aer_error_resume(struct pci_dev *dev) | 1541 | static 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, ®16); | ||
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 | ||