aboutsummaryrefslogtreecommitdiffstats
path: root/drivers
diff options
context:
space:
mode:
authorLinas Vepstas <linas@austin.ibm.com>2007-03-08 16:19:11 -0600
committerJames Bottomley <jejb@mulgrave.il.steeleye.com>2007-03-11 10:42:17 -0500
commit5daa49ef05c44ce94bed0bab0f9ba4a9e952863b (patch)
tree7af047846343ffee0d047a60c9ad81e2d5de8e76 /drivers
parentbe521466feb3bb1cd89de82a2b1d080e9ebd3cb6 (diff)
downloadkernel_samsung_crespo-5daa49ef05c44ce94bed0bab0f9ba4a9e952863b.zip
kernel_samsung_crespo-5daa49ef05c44ce94bed0bab0f9ba4a9e952863b.tar.gz
kernel_samsung_crespo-5daa49ef05c44ce94bed0bab0f9ba4a9e952863b.tar.bz2
[SCSI] lpfc: avoid double-free during PCI error failure
If a PCI error is detected that cannot be recovered from, there will be a double call of lpfc_pci_remove_one(), with the second call resulting in a null-pointer dereference. The first call occurs in lpfc_io_error_detected(), and the second call during pci device remove. This patch eliminates the first call; its un-needed. Signed-off-by: Linas Vepstas <linas@austin.ibm.com> Acked-by: James Smart <James.Smart@Emulex.Com> Signed-off-by: James Bottomley <James.Bottomley@SteelEye.com>
Diffstat (limited to 'drivers')
-rw-r--r--drivers/scsi/lpfc/lpfc_init.c5
1 files changed, 2 insertions, 3 deletions
diff --git a/drivers/scsi/lpfc/lpfc_init.c b/drivers/scsi/lpfc/lpfc_init.c
index 9d014e5..057fd7e0 100644
--- a/drivers/scsi/lpfc/lpfc_init.c
+++ b/drivers/scsi/lpfc/lpfc_init.c
@@ -1817,10 +1817,9 @@ static pci_ers_result_t lpfc_io_error_detected(struct pci_dev *pdev,
struct lpfc_sli *psli = &phba->sli;
struct lpfc_sli_ring *pring;
- if (state == pci_channel_io_perm_failure) {
- lpfc_pci_remove_one(pdev);
+ if (state == pci_channel_io_perm_failure)
return PCI_ERS_RESULT_DISCONNECT;
- }
+
pci_disable_device(pdev);
/*
* There may be I/Os dropped by the firmware.