diff options
Diffstat (limited to 'drivers/scsi/qla2xxx/qla_os.c')
-rw-r--r-- | drivers/scsi/qla2xxx/qla_os.c | 78 |
1 files changed, 39 insertions, 39 deletions
diff --git a/drivers/scsi/qla2xxx/qla_os.c b/drivers/scsi/qla2xxx/qla_os.c index 072906994bf5..fd7e730bb3ba 100644 --- a/drivers/scsi/qla2xxx/qla_os.c +++ b/drivers/scsi/qla2xxx/qla_os.c | |||
@@ -64,7 +64,7 @@ MODULE_PARM_DESC(ql2xplogiabsentdevice, | |||
64 | int ql2xenablezio = 0; | 64 | int ql2xenablezio = 0; |
65 | module_param(ql2xenablezio, int, S_IRUGO|S_IRUSR); | 65 | module_param(ql2xenablezio, int, S_IRUGO|S_IRUSR); |
66 | MODULE_PARM_DESC(ql2xenablezio, | 66 | MODULE_PARM_DESC(ql2xenablezio, |
67 | "Option to enable ZIO:If 1 then enable it otherwise" | 67 | "Option to enable ZIO:If 1 then enable it otherwise" |
68 | " use the default set in the NVRAM." | 68 | " use the default set in the NVRAM." |
69 | " Default is 0 : disabled"); | 69 | " Default is 0 : disabled"); |
70 | 70 | ||
@@ -89,7 +89,7 @@ static void qla2x00_free_device(scsi_qla_host_t *); | |||
89 | static void qla2x00_config_dma_addressing(scsi_qla_host_t *ha); | 89 | static void qla2x00_config_dma_addressing(scsi_qla_host_t *ha); |
90 | 90 | ||
91 | /* | 91 | /* |
92 | * SCSI host template entry points | 92 | * SCSI host template entry points |
93 | */ | 93 | */ |
94 | static int qla2xxx_slave_configure(struct scsi_device * device); | 94 | static int qla2xxx_slave_configure(struct scsi_device * device); |
95 | static int qla2xxx_slave_alloc(struct scsi_device *); | 95 | static int qla2xxx_slave_alloc(struct scsi_device *); |
@@ -280,7 +280,7 @@ char * | |||
280 | qla2x00_fw_version_str(struct scsi_qla_host *ha, char *str) | 280 | qla2x00_fw_version_str(struct scsi_qla_host *ha, char *str) |
281 | { | 281 | { |
282 | char un_str[10]; | 282 | char un_str[10]; |
283 | 283 | ||
284 | sprintf(str, "%d.%02d.%02d ", ha->fw_major_version, | 284 | sprintf(str, "%d.%02d.%02d ", ha->fw_major_version, |
285 | ha->fw_minor_version, | 285 | ha->fw_minor_version, |
286 | ha->fw_subminor_version); | 286 | ha->fw_subminor_version); |
@@ -504,14 +504,14 @@ qla2x00_eh_wait_on_command(scsi_qla_host_t *ha, struct scsi_cmnd *cmd) | |||
504 | 504 | ||
505 | /* | 505 | /* |
506 | * qla2x00_wait_for_hba_online | 506 | * qla2x00_wait_for_hba_online |
507 | * Wait till the HBA is online after going through | 507 | * Wait till the HBA is online after going through |
508 | * <= MAX_RETRIES_OF_ISP_ABORT or | 508 | * <= MAX_RETRIES_OF_ISP_ABORT or |
509 | * finally HBA is disabled ie marked offline | 509 | * finally HBA is disabled ie marked offline |
510 | * | 510 | * |
511 | * Input: | 511 | * Input: |
512 | * ha - pointer to host adapter structure | 512 | * ha - pointer to host adapter structure |
513 | * | 513 | * |
514 | * Note: | 514 | * Note: |
515 | * Does context switching-Release SPIN_LOCK | 515 | * Does context switching-Release SPIN_LOCK |
516 | * (if any) before calling this routine. | 516 | * (if any) before calling this routine. |
517 | * | 517 | * |
@@ -519,13 +519,13 @@ qla2x00_eh_wait_on_command(scsi_qla_host_t *ha, struct scsi_cmnd *cmd) | |||
519 | * Success (Adapter is online) : 0 | 519 | * Success (Adapter is online) : 0 |
520 | * Failed (Adapter is offline/disabled) : 1 | 520 | * Failed (Adapter is offline/disabled) : 1 |
521 | */ | 521 | */ |
522 | static int | 522 | static int |
523 | qla2x00_wait_for_hba_online(scsi_qla_host_t *ha) | 523 | qla2x00_wait_for_hba_online(scsi_qla_host_t *ha) |
524 | { | 524 | { |
525 | int return_status; | 525 | int return_status; |
526 | unsigned long wait_online; | 526 | unsigned long wait_online; |
527 | 527 | ||
528 | wait_online = jiffies + (MAX_LOOP_TIMEOUT * HZ); | 528 | wait_online = jiffies + (MAX_LOOP_TIMEOUT * HZ); |
529 | while (((test_bit(ISP_ABORT_NEEDED, &ha->dpc_flags)) || | 529 | while (((test_bit(ISP_ABORT_NEEDED, &ha->dpc_flags)) || |
530 | test_bit(ABORT_ISP_ACTIVE, &ha->dpc_flags) || | 530 | test_bit(ABORT_ISP_ACTIVE, &ha->dpc_flags) || |
531 | test_bit(ISP_ABORT_RETRY, &ha->dpc_flags) || | 531 | test_bit(ISP_ABORT_RETRY, &ha->dpc_flags) || |
@@ -533,8 +533,8 @@ qla2x00_wait_for_hba_online(scsi_qla_host_t *ha) | |||
533 | 533 | ||
534 | msleep(1000); | 534 | msleep(1000); |
535 | } | 535 | } |
536 | if (ha->flags.online) | 536 | if (ha->flags.online) |
537 | return_status = QLA_SUCCESS; | 537 | return_status = QLA_SUCCESS; |
538 | else | 538 | else |
539 | return_status = QLA_FUNCTION_FAILED; | 539 | return_status = QLA_FUNCTION_FAILED; |
540 | 540 | ||
@@ -546,27 +546,27 @@ qla2x00_wait_for_hba_online(scsi_qla_host_t *ha) | |||
546 | /* | 546 | /* |
547 | * qla2x00_wait_for_loop_ready | 547 | * qla2x00_wait_for_loop_ready |
548 | * Wait for MAX_LOOP_TIMEOUT(5 min) value for loop | 548 | * Wait for MAX_LOOP_TIMEOUT(5 min) value for loop |
549 | * to be in LOOP_READY state. | 549 | * to be in LOOP_READY state. |
550 | * Input: | 550 | * Input: |
551 | * ha - pointer to host adapter structure | 551 | * ha - pointer to host adapter structure |
552 | * | 552 | * |
553 | * Note: | 553 | * Note: |
554 | * Does context switching-Release SPIN_LOCK | 554 | * Does context switching-Release SPIN_LOCK |
555 | * (if any) before calling this routine. | 555 | * (if any) before calling this routine. |
556 | * | 556 | * |
557 | * | 557 | * |
558 | * Return: | 558 | * Return: |
559 | * Success (LOOP_READY) : 0 | 559 | * Success (LOOP_READY) : 0 |
560 | * Failed (LOOP_NOT_READY) : 1 | 560 | * Failed (LOOP_NOT_READY) : 1 |
561 | */ | 561 | */ |
562 | static inline int | 562 | static inline int |
563 | qla2x00_wait_for_loop_ready(scsi_qla_host_t *ha) | 563 | qla2x00_wait_for_loop_ready(scsi_qla_host_t *ha) |
564 | { | 564 | { |
565 | int return_status = QLA_SUCCESS; | 565 | int return_status = QLA_SUCCESS; |
566 | unsigned long loop_timeout ; | 566 | unsigned long loop_timeout ; |
567 | 567 | ||
568 | /* wait for 5 min at the max for loop to be ready */ | 568 | /* wait for 5 min at the max for loop to be ready */ |
569 | loop_timeout = jiffies + (MAX_LOOP_TIMEOUT * HZ); | 569 | loop_timeout = jiffies + (MAX_LOOP_TIMEOUT * HZ); |
570 | 570 | ||
571 | while ((!atomic_read(&ha->loop_down_timer) && | 571 | while ((!atomic_read(&ha->loop_down_timer) && |
572 | atomic_read(&ha->loop_state) == LOOP_DOWN) || | 572 | atomic_read(&ha->loop_state) == LOOP_DOWN) || |
@@ -577,7 +577,7 @@ qla2x00_wait_for_loop_ready(scsi_qla_host_t *ha) | |||
577 | break; | 577 | break; |
578 | } | 578 | } |
579 | } | 579 | } |
580 | return (return_status); | 580 | return (return_status); |
581 | } | 581 | } |
582 | 582 | ||
583 | /************************************************************************** | 583 | /************************************************************************** |
@@ -647,13 +647,13 @@ qla2xxx_eh_abort(struct scsi_cmnd *cmd) | |||
647 | /* Wait for the command to be returned. */ | 647 | /* Wait for the command to be returned. */ |
648 | if (ret == SUCCESS) { | 648 | if (ret == SUCCESS) { |
649 | if (qla2x00_eh_wait_on_command(ha, cmd) != QLA_SUCCESS) { | 649 | if (qla2x00_eh_wait_on_command(ha, cmd) != QLA_SUCCESS) { |
650 | qla_printk(KERN_ERR, ha, | 650 | qla_printk(KERN_ERR, ha, |
651 | "scsi(%ld:%d:%d): Abort handler timed out -- %lx " | 651 | "scsi(%ld:%d:%d): Abort handler timed out -- %lx " |
652 | "%x.\n", ha->host_no, id, lun, serial, ret); | 652 | "%x.\n", ha->host_no, id, lun, serial, ret); |
653 | } | 653 | } |
654 | } | 654 | } |
655 | 655 | ||
656 | qla_printk(KERN_INFO, ha, | 656 | qla_printk(KERN_INFO, ha, |
657 | "scsi(%ld:%d:%d): Abort command issued -- %lx %x.\n", ha->host_no, | 657 | "scsi(%ld:%d:%d): Abort command issued -- %lx %x.\n", ha->host_no, |
658 | id, lun, serial, ret); | 658 | id, lun, serial, ret); |
659 | 659 | ||
@@ -668,7 +668,7 @@ qla2xxx_eh_abort(struct scsi_cmnd *cmd) | |||
668 | * | 668 | * |
669 | * Input: | 669 | * Input: |
670 | * ha - pointer to scsi_qla_host structure. | 670 | * ha - pointer to scsi_qla_host structure. |
671 | * t - target | 671 | * t - target |
672 | * Returns: | 672 | * Returns: |
673 | * Either SUCCESS or FAILED. | 673 | * Either SUCCESS or FAILED. |
674 | * | 674 | * |
@@ -717,7 +717,7 @@ qla2x00_eh_wait_for_pending_target_commands(scsi_qla_host_t *ha, unsigned int t) | |||
717 | * executing commands. | 717 | * executing commands. |
718 | * | 718 | * |
719 | * NOTE: The use of SP is undefined within this context. Do *NOT* | 719 | * NOTE: The use of SP is undefined within this context. Do *NOT* |
720 | * attempt to use this value, even if you determine it is | 720 | * attempt to use this value, even if you determine it is |
721 | * non-null. | 721 | * non-null. |
722 | * | 722 | * |
723 | * Input: | 723 | * Input: |
@@ -793,7 +793,7 @@ qla2xxx_eh_device_reset(struct scsi_cmnd *cmd) | |||
793 | "commands\n", __func__, ha->host_no)); | 793 | "commands\n", __func__, ha->host_no)); |
794 | qla_printk(KERN_INFO, ha, | 794 | qla_printk(KERN_INFO, ha, |
795 | "%s: failed while waiting for commands\n", | 795 | "%s: failed while waiting for commands\n", |
796 | __func__); | 796 | __func__); |
797 | 797 | ||
798 | goto eh_dev_reset_done; | 798 | goto eh_dev_reset_done; |
799 | } | 799 | } |
@@ -959,7 +959,7 @@ qla2xxx_eh_host_reset(struct scsi_cmnd *cmd) | |||
959 | 959 | ||
960 | /* | 960 | /* |
961 | * Fixme-may be dpc thread is active and processing | 961 | * Fixme-may be dpc thread is active and processing |
962 | * loop_resync,so wait a while for it to | 962 | * loop_resync,so wait a while for it to |
963 | * be completed and then issue big hammer.Otherwise | 963 | * be completed and then issue big hammer.Otherwise |
964 | * it may cause I/O failure as big hammer marks the | 964 | * it may cause I/O failure as big hammer marks the |
965 | * devices as lost kicking of the port_down_timer | 965 | * devices as lost kicking of the port_down_timer |
@@ -974,7 +974,7 @@ qla2xxx_eh_host_reset(struct scsi_cmnd *cmd) | |||
974 | 974 | ||
975 | if (qla2x00_wait_for_hba_online(ha) != QLA_SUCCESS) | 975 | if (qla2x00_wait_for_hba_online(ha) != QLA_SUCCESS) |
976 | goto eh_host_reset_lock; | 976 | goto eh_host_reset_lock; |
977 | } | 977 | } |
978 | clear_bit(ABORT_ISP_ACTIVE, &ha->dpc_flags); | 978 | clear_bit(ABORT_ISP_ACTIVE, &ha->dpc_flags); |
979 | 979 | ||
980 | /* Waiting for our command in done_queue to be returned to OS.*/ | 980 | /* Waiting for our command in done_queue to be returned to OS.*/ |
@@ -1020,7 +1020,7 @@ qla2x00_loop_reset(scsi_qla_host_t *ha) | |||
1020 | } | 1020 | } |
1021 | 1021 | ||
1022 | if (status == QLA_SUCCESS && | 1022 | if (status == QLA_SUCCESS && |
1023 | ((!ha->flags.enable_target_reset && | 1023 | ((!ha->flags.enable_target_reset && |
1024 | !ha->flags.enable_lip_reset) || | 1024 | !ha->flags.enable_lip_reset) || |
1025 | ha->flags.enable_lip_full_login)) { | 1025 | ha->flags.enable_lip_full_login)) { |
1026 | 1026 | ||
@@ -1139,7 +1139,7 @@ qla2x00_config_dma_addressing(scsi_qla_host_t *ha) | |||
1139 | 1139 | ||
1140 | if (pci_set_consistent_dma_mask(ha->pdev, | 1140 | if (pci_set_consistent_dma_mask(ha->pdev, |
1141 | DMA_64BIT_MASK)) { | 1141 | DMA_64BIT_MASK)) { |
1142 | qla_printk(KERN_DEBUG, ha, | 1142 | qla_printk(KERN_DEBUG, ha, |
1143 | "Failed to set 64 bit PCI consistent mask; " | 1143 | "Failed to set 64 bit PCI consistent mask; " |
1144 | "using 32 bit.\n"); | 1144 | "using 32 bit.\n"); |
1145 | pci_set_consistent_dma_mask(ha->pdev, | 1145 | pci_set_consistent_dma_mask(ha->pdev, |
@@ -1666,7 +1666,7 @@ void qla2x00_mark_device_lost(scsi_qla_host_t *ha, fc_port_t *fcport, | |||
1666 | { | 1666 | { |
1667 | if (atomic_read(&fcport->state) == FCS_ONLINE && fcport->rport) | 1667 | if (atomic_read(&fcport->state) == FCS_ONLINE && fcport->rport) |
1668 | fc_remote_port_block(fcport->rport); | 1668 | fc_remote_port_block(fcport->rport); |
1669 | /* | 1669 | /* |
1670 | * We may need to retry the login, so don't change the state of the | 1670 | * We may need to retry the login, so don't change the state of the |
1671 | * port but do the retries. | 1671 | * port but do the retries. |
1672 | */ | 1672 | */ |
@@ -1711,7 +1711,7 @@ void qla2x00_mark_device_lost(scsi_qla_host_t *ha, fc_port_t *fcport, | |||
1711 | * Context: | 1711 | * Context: |
1712 | */ | 1712 | */ |
1713 | void | 1713 | void |
1714 | qla2x00_mark_all_devices_lost(scsi_qla_host_t *ha) | 1714 | qla2x00_mark_all_devices_lost(scsi_qla_host_t *ha) |
1715 | { | 1715 | { |
1716 | fc_port_t *fcport; | 1716 | fc_port_t *fcport; |
1717 | 1717 | ||
@@ -2061,11 +2061,11 @@ qla2x00_mem_free(scsi_qla_host_t *ha) | |||
2061 | * | 2061 | * |
2062 | * Context: | 2062 | * Context: |
2063 | * Kernel context. | 2063 | * Kernel context. |
2064 | * | 2064 | * |
2065 | * Note: Sets the ref_count for non Null sp to one. | 2065 | * Note: Sets the ref_count for non Null sp to one. |
2066 | */ | 2066 | */ |
2067 | static int | 2067 | static int |
2068 | qla2x00_allocate_sp_pool(scsi_qla_host_t *ha) | 2068 | qla2x00_allocate_sp_pool(scsi_qla_host_t *ha) |
2069 | { | 2069 | { |
2070 | int rval; | 2070 | int rval; |
2071 | 2071 | ||
@@ -2081,10 +2081,10 @@ qla2x00_allocate_sp_pool(scsi_qla_host_t *ha) | |||
2081 | 2081 | ||
2082 | /* | 2082 | /* |
2083 | * This routine frees all adapter allocated memory. | 2083 | * This routine frees all adapter allocated memory. |
2084 | * | 2084 | * |
2085 | */ | 2085 | */ |
2086 | static void | 2086 | static void |
2087 | qla2x00_free_sp_pool( scsi_qla_host_t *ha) | 2087 | qla2x00_free_sp_pool( scsi_qla_host_t *ha) |
2088 | { | 2088 | { |
2089 | if (ha->srb_mempool) { | 2089 | if (ha->srb_mempool) { |
2090 | mempool_destroy(ha->srb_mempool); | 2090 | mempool_destroy(ha->srb_mempool); |
@@ -2223,7 +2223,7 @@ qla2x00_do_dpc(void *data) | |||
2223 | 2223 | ||
2224 | DEBUG(printk("scsi(%ld): port login OK: logged in ID 0x%x\n", | 2224 | DEBUG(printk("scsi(%ld): port login OK: logged in ID 0x%x\n", |
2225 | ha->host_no, fcport->loop_id)); | 2225 | ha->host_no, fcport->loop_id)); |
2226 | 2226 | ||
2227 | fcport->port_login_retry_count = | 2227 | fcport->port_login_retry_count = |
2228 | ha->port_down_retry_count * PORT_RETRY_TIME; | 2228 | ha->port_down_retry_count * PORT_RETRY_TIME; |
2229 | atomic_set(&fcport->state, FCS_ONLINE); | 2229 | atomic_set(&fcport->state, FCS_ONLINE); |
@@ -2254,7 +2254,7 @@ qla2x00_do_dpc(void *data) | |||
2254 | clear_bit(LOGIN_RETRY_NEEDED, &ha->dpc_flags); | 2254 | clear_bit(LOGIN_RETRY_NEEDED, &ha->dpc_flags); |
2255 | DEBUG(printk("scsi(%ld): qla2x00_login_retry()\n", | 2255 | DEBUG(printk("scsi(%ld): qla2x00_login_retry()\n", |
2256 | ha->host_no)); | 2256 | ha->host_no)); |
2257 | 2257 | ||
2258 | set_bit(LOOP_RESYNC_NEEDED, &ha->dpc_flags); | 2258 | set_bit(LOOP_RESYNC_NEEDED, &ha->dpc_flags); |
2259 | 2259 | ||
2260 | DEBUG(printk("scsi(%ld): qla2x00_login_retry - end\n", | 2260 | DEBUG(printk("scsi(%ld): qla2x00_login_retry - end\n", |
@@ -2315,7 +2315,7 @@ qla2x00_do_dpc(void *data) | |||
2315 | * ha = adapter block pointer. | 2315 | * ha = adapter block pointer. |
2316 | */ | 2316 | */ |
2317 | static void | 2317 | static void |
2318 | qla2x00_rst_aen(scsi_qla_host_t *ha) | 2318 | qla2x00_rst_aen(scsi_qla_host_t *ha) |
2319 | { | 2319 | { |
2320 | if (ha->flags.online && !ha->flags.reset_active && | 2320 | if (ha->flags.online && !ha->flags.reset_active && |
2321 | !atomic_read(&ha->loop_down_timer) && | 2321 | !atomic_read(&ha->loop_down_timer) && |
@@ -2386,7 +2386,7 @@ qla2x00_timer(scsi_qla_host_t *ha) | |||
2386 | * | 2386 | * |
2387 | * Whenever, a port is in the LOST state we start decrementing its port | 2387 | * Whenever, a port is in the LOST state we start decrementing its port |
2388 | * down timer every second until it reaches zero. Once it reaches zero | 2388 | * down timer every second until it reaches zero. Once it reaches zero |
2389 | * the port it marked DEAD. | 2389 | * the port it marked DEAD. |
2390 | */ | 2390 | */ |
2391 | t = 0; | 2391 | t = 0; |
2392 | list_for_each_entry(fcport, &ha->fcports, list) { | 2392 | list_for_each_entry(fcport, &ha->fcports, list) { |
@@ -2398,9 +2398,9 @@ qla2x00_timer(scsi_qla_host_t *ha) | |||
2398 | if (atomic_read(&fcport->port_down_timer) == 0) | 2398 | if (atomic_read(&fcport->port_down_timer) == 0) |
2399 | continue; | 2399 | continue; |
2400 | 2400 | ||
2401 | if (atomic_dec_and_test(&fcport->port_down_timer) != 0) | 2401 | if (atomic_dec_and_test(&fcport->port_down_timer) != 0) |
2402 | atomic_set(&fcport->state, FCS_DEVICE_DEAD); | 2402 | atomic_set(&fcport->state, FCS_DEVICE_DEAD); |
2403 | 2403 | ||
2404 | DEBUG(printk("scsi(%ld): fcport-%d - port retry count: " | 2404 | DEBUG(printk("scsi(%ld): fcport-%d - port retry count: " |
2405 | "%d remaining\n", | 2405 | "%d remaining\n", |
2406 | ha->host_no, | 2406 | ha->host_no, |
@@ -2422,7 +2422,7 @@ qla2x00_timer(scsi_qla_host_t *ha) | |||
2422 | ha->host_no)); | 2422 | ha->host_no)); |
2423 | 2423 | ||
2424 | if (!IS_QLA2100(ha) && ha->link_down_timeout) | 2424 | if (!IS_QLA2100(ha) && ha->link_down_timeout) |
2425 | atomic_set(&ha->loop_state, LOOP_DEAD); | 2425 | atomic_set(&ha->loop_state, LOOP_DEAD); |
2426 | 2426 | ||
2427 | /* Schedule an ISP abort to return any tape commands. */ | 2427 | /* Schedule an ISP abort to return any tape commands. */ |
2428 | spin_lock_irqsave(&ha->hardware_lock, cpu_flags); | 2428 | spin_lock_irqsave(&ha->hardware_lock, cpu_flags); |