diff options
author | Oza Pawandeep | 2018-05-17 16:44:18 -0500 |
---|---|---|
committer | Bjorn Helgaas | 2018-06-02 19:29:25 -0500 |
commit | 6927868e7ae929f037eea973c582b870808880b6 (patch) | |
tree | 721399b304db004b3fcd94c6f0aabfe46674d941 /include/uapi/linux/pg.h | |
parent | e76d596aef0caa7296e42e29a0a81bc4155807df (diff) |
PCI/DPC: Disable ERR_NONFATAL handling by DPC
PCIe ERR_NONFATAL errors mean a particular transaction is unreliable but
the Link is otherwise fully functional (PCIe r4.0, sec 6.2.2).
The AER driver handles these by logging the error details and calling
driver-supplied pci_error_handlers callbacks. It does not reset downstream
devices, does not remove them from the PCI subsystem, does not re-enumerate
them, and does not call their driver .remove() or .probe() methods.
But DPC driver previously enabled DPC on ERR_NONFATAL, so if the hardware
supports DPC, these errors caused a Link reset (performed automatically by
the hardware), followed by the DPC driver removing affected devices (which
calls their .remove() methods), bringing the Link back up, and
re-enumerating (which calls driver .probe() methods).
Disable ERR_NONFATAL DPC triggering so these errors will only be handled by
AER. This means drivers won't have to deal with different usage of their
pci_error_handlers callbacks and .probe() and .remove() methods based on
whether the platform has DPC support.
Signed-off-by: Oza Pawandeep <poza@codeaurora.org>
[bhelgaas: changelog]
Signed-off-by: Bjorn Helgaas <bhelgaas@google.com>
Diffstat (limited to 'include/uapi/linux/pg.h')
0 files changed, 0 insertions, 0 deletions