diff options
author | Vikas Chaudhary <vikas.chaudhary@qlogic.com> | 2010-10-07 01:50:56 -0400 |
---|---|---|
committer | James Bottomley <James.Bottomley@suse.de> | 2010-10-25 15:53:42 -0400 |
commit | 7b3595df0e064c8d85ddb6836aaa2af3956fb2ba (patch) | |
tree | 21081bc21edc0421c96036e347e2a4cc11a04a5c | |
parent | b25ee66f2d4e5f14e69d75a7363e55889e9aff92 (diff) |
[SCSI] qla4xxx: update AER support for ISP82XX
* Cleanup qla4xxx_pci_mmio_enabled():
don't want to return PCI_ERS_NEED_RESET if firmware hung.
IDC will take care of it.
* Request irq after initialize_adapter() in qla82xx_error_recovery().
* Return all active commands from qla4xxx_pci_error_detected().
* Cleanup ql4_def.h
Signed-off-by: Vikas Chaudhary <vikas.chaudhary@qlogic.com>
Signed-off-by: Ravi Anand <ravi.anand@qlogic.com>
Reviewed-by: Mike Christie <michaelc@cs.wisc.edu>
Signed-off-by: James Bottomley <James.Bottomley@suse.de>
-rw-r--r-- | drivers/scsi/qla4xxx/ql4_def.h | 19 | ||||
-rw-r--r-- | drivers/scsi/qla4xxx/ql4_os.c | 45 |
2 files changed, 29 insertions, 35 deletions
diff --git a/drivers/scsi/qla4xxx/ql4_def.h b/drivers/scsi/qla4xxx/ql4_def.h index f595ab13c2e1..0f3bfc3da5cf 100644 --- a/drivers/scsi/qla4xxx/ql4_def.h +++ b/drivers/scsi/qla4xxx/ql4_def.h | |||
@@ -24,6 +24,7 @@ | |||
24 | #include <linux/delay.h> | 24 | #include <linux/delay.h> |
25 | #include <linux/interrupt.h> | 25 | #include <linux/interrupt.h> |
26 | #include <linux/mutex.h> | 26 | #include <linux/mutex.h> |
27 | #include <linux/aer.h> | ||
27 | 28 | ||
28 | #include <net/tcp.h> | 29 | #include <net/tcp.h> |
29 | #include <scsi/scsi.h> | 30 | #include <scsi/scsi.h> |
@@ -36,24 +37,6 @@ | |||
36 | #include "ql4_dbg.h" | 37 | #include "ql4_dbg.h" |
37 | #include "ql4_nx.h" | 38 | #include "ql4_nx.h" |
38 | 39 | ||
39 | #if defined(CONFIG_PCIEAER) | ||
40 | #include <linux/aer.h> | ||
41 | #else | ||
42 | /* AER releated */ | ||
43 | static inline int pci_enable_pcie_error_reporting(struct pci_dev *dev) | ||
44 | { | ||
45 | return -EINVAL; | ||
46 | } | ||
47 | static inline int pci_disable_pcie_error_reporting(struct pci_dev *dev) | ||
48 | { | ||
49 | return -EINVAL; | ||
50 | } | ||
51 | static inline int pci_cleanup_aer_uncorrect_error_status(struct pci_dev *dev) | ||
52 | { | ||
53 | return -EINVAL; | ||
54 | } | ||
55 | #endif | ||
56 | |||
57 | #ifndef PCI_DEVICE_ID_QLOGIC_ISP4010 | 40 | #ifndef PCI_DEVICE_ID_QLOGIC_ISP4010 |
58 | #define PCI_DEVICE_ID_QLOGIC_ISP4010 0x4010 | 41 | #define PCI_DEVICE_ID_QLOGIC_ISP4010 0x4010 |
59 | #endif | 42 | #endif |
diff --git a/drivers/scsi/qla4xxx/ql4_os.c b/drivers/scsi/qla4xxx/ql4_os.c index 779745f4e59c..4b6cdb68a52a 100644 --- a/drivers/scsi/qla4xxx/ql4_os.c +++ b/drivers/scsi/qla4xxx/ql4_os.c | |||
@@ -2252,6 +2252,8 @@ qla4xxx_pci_error_detected(struct pci_dev *pdev, pci_channel_state_t state) | |||
2252 | qla4xxx_mailbox_premature_completion(ha); | 2252 | qla4xxx_mailbox_premature_completion(ha); |
2253 | qla4xxx_free_irqs(ha); | 2253 | qla4xxx_free_irqs(ha); |
2254 | pci_disable_device(pdev); | 2254 | pci_disable_device(pdev); |
2255 | /* Return back all IOs */ | ||
2256 | qla4xxx_abort_active_cmds(ha, DID_RESET << 16); | ||
2255 | return PCI_ERS_RESULT_NEED_RESET; | 2257 | return PCI_ERS_RESULT_NEED_RESET; |
2256 | case pci_channel_io_perm_failure: | 2258 | case pci_channel_io_perm_failure: |
2257 | set_bit(AF_EEH_BUSY, &ha->flags); | 2259 | set_bit(AF_EEH_BUSY, &ha->flags); |
@@ -2275,17 +2277,13 @@ qla4xxx_pci_mmio_enabled(struct pci_dev *pdev) | |||
2275 | if (!is_aer_supported(ha)) | 2277 | if (!is_aer_supported(ha)) |
2276 | return PCI_ERS_RESULT_NONE; | 2278 | return PCI_ERS_RESULT_NONE; |
2277 | 2279 | ||
2278 | if (test_bit(AF_FW_RECOVERY, &ha->flags)) { | 2280 | return PCI_ERS_RESULT_RECOVERED; |
2279 | ql4_printk(KERN_WARNING, ha, "scsi%ld: %s: firmware hang -- " | ||
2280 | "mmio_enabled\n", ha->host_no, __func__); | ||
2281 | return PCI_ERS_RESULT_NEED_RESET; | ||
2282 | } else | ||
2283 | return PCI_ERS_RESULT_RECOVERED; | ||
2284 | } | 2281 | } |
2285 | 2282 | ||
2286 | uint32_t qla4_8xxx_error_recovery(struct scsi_qla_host *ha) | 2283 | static uint32_t qla4_8xxx_error_recovery(struct scsi_qla_host *ha) |
2287 | { | 2284 | { |
2288 | uint32_t rval = QLA_ERROR; | 2285 | uint32_t rval = QLA_ERROR; |
2286 | uint32_t ret = 0; | ||
2289 | int fn; | 2287 | int fn; |
2290 | struct pci_dev *other_pdev = NULL; | 2288 | struct pci_dev *other_pdev = NULL; |
2291 | 2289 | ||
@@ -2297,7 +2295,6 @@ uint32_t qla4_8xxx_error_recovery(struct scsi_qla_host *ha) | |||
2297 | clear_bit(AF_ONLINE, &ha->flags); | 2295 | clear_bit(AF_ONLINE, &ha->flags); |
2298 | qla4xxx_mark_all_devices_missing(ha); | 2296 | qla4xxx_mark_all_devices_missing(ha); |
2299 | qla4xxx_process_aen(ha, FLUSH_DDB_CHANGED_AENS); | 2297 | qla4xxx_process_aen(ha, FLUSH_DDB_CHANGED_AENS); |
2300 | qla4xxx_abort_active_cmds(ha, DID_RESET << 16); | ||
2301 | } | 2298 | } |
2302 | 2299 | ||
2303 | fn = PCI_FUNC(ha->pdev->devfn); | 2300 | fn = PCI_FUNC(ha->pdev->devfn); |
@@ -2360,7 +2357,16 @@ uint32_t qla4_8xxx_error_recovery(struct scsi_qla_host *ha) | |||
2360 | /* Clear driver state register */ | 2357 | /* Clear driver state register */ |
2361 | qla4_8xxx_wr_32(ha, QLA82XX_CRB_DRV_STATE, 0); | 2358 | qla4_8xxx_wr_32(ha, QLA82XX_CRB_DRV_STATE, 0); |
2362 | qla4_8xxx_set_drv_active(ha); | 2359 | qla4_8xxx_set_drv_active(ha); |
2363 | ha->isp_ops->enable_intrs(ha); | 2360 | ret = qla4xxx_request_irqs(ha); |
2361 | if (ret) { | ||
2362 | ql4_printk(KERN_WARNING, ha, "Failed to " | ||
2363 | "reserve interrupt %d already in use.\n", | ||
2364 | ha->pdev->irq); | ||
2365 | rval = QLA_ERROR; | ||
2366 | } else { | ||
2367 | ha->isp_ops->enable_intrs(ha); | ||
2368 | rval = QLA_SUCCESS; | ||
2369 | } | ||
2364 | } | 2370 | } |
2365 | qla4_8xxx_idc_unlock(ha); | 2371 | qla4_8xxx_idc_unlock(ha); |
2366 | } else { | 2372 | } else { |
@@ -2372,8 +2378,18 @@ uint32_t qla4_8xxx_error_recovery(struct scsi_qla_host *ha) | |||
2372 | clear_bit(AF_FW_RECOVERY, &ha->flags); | 2378 | clear_bit(AF_FW_RECOVERY, &ha->flags); |
2373 | rval = qla4xxx_initialize_adapter(ha, | 2379 | rval = qla4xxx_initialize_adapter(ha, |
2374 | PRESERVE_DDB_LIST); | 2380 | PRESERVE_DDB_LIST); |
2375 | if (rval == QLA_SUCCESS) | 2381 | if (rval == QLA_SUCCESS) { |
2376 | ha->isp_ops->enable_intrs(ha); | 2382 | ret = qla4xxx_request_irqs(ha); |
2383 | if (ret) { | ||
2384 | ql4_printk(KERN_WARNING, ha, "Failed to" | ||
2385 | " reserve interrupt %d already in" | ||
2386 | " use.\n", ha->pdev->irq); | ||
2387 | rval = QLA_ERROR; | ||
2388 | } else { | ||
2389 | ha->isp_ops->enable_intrs(ha); | ||
2390 | rval = QLA_SUCCESS; | ||
2391 | } | ||
2392 | } | ||
2377 | qla4_8xxx_idc_lock(ha); | 2393 | qla4_8xxx_idc_lock(ha); |
2378 | qla4_8xxx_set_drv_active(ha); | 2394 | qla4_8xxx_set_drv_active(ha); |
2379 | qla4_8xxx_idc_unlock(ha); | 2395 | qla4_8xxx_idc_unlock(ha); |
@@ -2415,12 +2431,7 @@ qla4xxx_pci_slot_reset(struct pci_dev *pdev) | |||
2415 | goto exit_slot_reset; | 2431 | goto exit_slot_reset; |
2416 | } | 2432 | } |
2417 | 2433 | ||
2418 | ret = qla4xxx_request_irqs(ha); | 2434 | ha->isp_ops->disable_intrs(ha); |
2419 | if (ret) { | ||
2420 | ql4_printk(KERN_WARNING, ha, "Failed to reserve interrupt %d" | ||
2421 | " already in use.\n", pdev->irq); | ||
2422 | goto exit_slot_reset; | ||
2423 | } | ||
2424 | 2435 | ||
2425 | if (is_qla8022(ha)) { | 2436 | if (is_qla8022(ha)) { |
2426 | if (qla4_8xxx_error_recovery(ha) == QLA_SUCCESS) { | 2437 | if (qla4_8xxx_error_recovery(ha) == QLA_SUCCESS) { |