diff options
author | Dean Nelson <dnelson@redhat.com> | 2009-07-31 05:14:03 -0400 |
---|---|---|
committer | David S. Miller <davem@davemloft.net> | 2009-08-02 02:12:12 -0400 |
commit | e33b992d1504f21a8c2173245aeca4fc2ad632ab (patch) | |
tree | 75f5ffee79bbfe7eba06abb38fb76393ac787773 | |
parent | 1e3c8bd63854a620680323681f28e60a44e26f0e (diff) |
vxge: return PCI_ERS_RESULT_DISCONNECT on permanent failure
PCI drivers that implement the struct pci_error_handlers' error_detected
callback should return PCI_ERS_RESULT_DISCONNECT if the state passed in is
pci_channel_io_perm_failure. This patch fixes the issue for vxge.
Signed-off-by: Dean Nelson <dnelson@redhat.com>
Signed-off-by: David S. Miller <davem@davemloft.net>
-rw-r--r-- | drivers/net/vxge/vxge-main.c | 3 |
1 files changed, 3 insertions, 0 deletions
diff --git a/drivers/net/vxge/vxge-main.c b/drivers/net/vxge/vxge-main.c index 7b5402b50d0a..335140d2834a 100644 --- a/drivers/net/vxge/vxge-main.c +++ b/drivers/net/vxge/vxge-main.c | |||
@@ -3956,6 +3956,9 @@ static pci_ers_result_t vxge_io_error_detected(struct pci_dev *pdev, | |||
3956 | 3956 | ||
3957 | netif_device_detach(netdev); | 3957 | netif_device_detach(netdev); |
3958 | 3958 | ||
3959 | if (state == pci_channel_io_perm_failure) | ||
3960 | return PCI_ERS_RESULT_DISCONNECT; | ||
3961 | |||
3959 | if (netif_running(netdev)) { | 3962 | if (netif_running(netdev)) { |
3960 | /* Bring down the card, while avoiding PCI I/O */ | 3963 | /* Bring down the card, while avoiding PCI I/O */ |
3961 | do_vxge_close(netdev, 0); | 3964 | do_vxge_close(netdev, 0); |