Commit 6f1bbfb9 authored by Andrew Vasquez's avatar Andrew Vasquez Committed by James Bottomley

[PATCH] [9/18] qla2xxx: Tape command handling fixes

  Address several outstanding problem within the various
  eh_*() functions:

  	o Fixup nested spinlock usage in error-hanlding
  	  functions.

  	o Set the Loop down timer during abort isp if loop
  	  was already down for the driver to detect cable
  	  is unplugged at min time.
Signed-off-by: default avatarAndrew Vasquez <andrew.vasquez@qlogic.com>
Signed-off-by: default avatarJames Bottomley <James.Bottomley@SteelEye.com>
parent 25a48bb9
...@@ -4116,6 +4116,10 @@ qla2x00_abort_isp(scsi_qla_host_t *ha) ...@@ -4116,6 +4116,10 @@ qla2x00_abort_isp(scsi_qla_host_t *ha)
atomic_set(&ha->loop_state, LOOP_DOWN); atomic_set(&ha->loop_state, LOOP_DOWN);
atomic_set(&ha->loop_down_timer, LOOP_DOWN_TIME); atomic_set(&ha->loop_down_timer, LOOP_DOWN_TIME);
qla2x00_mark_all_devices_lost(ha); qla2x00_mark_all_devices_lost(ha);
} else {
if (!atomic_read(&ha->loop_down_timer))
atomic_set(&ha->loop_down_timer,
LOOP_DOWN_TIME);
} }
spin_lock_irqsave(&ha->hardware_lock, flags); spin_lock_irqsave(&ha->hardware_lock, flags);
......
...@@ -882,13 +882,12 @@ qla2x00_eh_wait_on_command(scsi_qla_host_t *ha, struct scsi_cmnd *cmd) ...@@ -882,13 +882,12 @@ qla2x00_eh_wait_on_command(scsi_qla_host_t *ha, struct scsi_cmnd *cmd)
int done = 0; int done = 0;
srb_t *rp; srb_t *rp;
struct list_head *list, *temp; struct list_head *list, *temp;
u_long cpu_flags = 0;
u_long max_wait_time = ABORT_WAIT_TIME; u_long max_wait_time = ABORT_WAIT_TIME;
do { do {
/* Check on done queue */ /* Check on done queue */
if (!found) { if (!found) {
spin_lock_irqsave(&ha->list_lock, cpu_flags); spin_lock(&ha->list_lock);
list_for_each_safe(list, temp, &ha->done_queue) { list_for_each_safe(list, temp, &ha->done_queue) {
rp = list_entry(list, srb_t, list); rp = list_entry(list, srb_t, list);
...@@ -903,7 +902,7 @@ qla2x00_eh_wait_on_command(scsi_qla_host_t *ha, struct scsi_cmnd *cmd) ...@@ -903,7 +902,7 @@ qla2x00_eh_wait_on_command(scsi_qla_host_t *ha, struct scsi_cmnd *cmd)
break; break;
} }
} }
spin_unlock_irqrestore(&ha->list_lock, cpu_flags); spin_unlock(&ha->list_lock);
} }
/* Checking to see if its returned to OS */ /* Checking to see if its returned to OS */
...@@ -951,7 +950,7 @@ qla2x00_eh_wait_on_command(scsi_qla_host_t *ha, struct scsi_cmnd *cmd) ...@@ -951,7 +950,7 @@ qla2x00_eh_wait_on_command(scsi_qla_host_t *ha, struct scsi_cmnd *cmd)
* Success (Adapter is online) : 0 * Success (Adapter is online) : 0
* Failed (Adapter is offline/disabled) : 1 * Failed (Adapter is offline/disabled) : 1
*/ */
static inline int int
qla2x00_wait_for_hba_online(scsi_qla_host_t *ha) qla2x00_wait_for_hba_online(scsi_qla_host_t *ha)
{ {
int return_status; int return_status;
...@@ -960,8 +959,8 @@ qla2x00_wait_for_hba_online(scsi_qla_host_t *ha) ...@@ -960,8 +959,8 @@ qla2x00_wait_for_hba_online(scsi_qla_host_t *ha)
wait_online = jiffies + (MAX_LOOP_TIMEOUT * HZ); wait_online = jiffies + (MAX_LOOP_TIMEOUT * HZ);
while (((test_bit(ISP_ABORT_NEEDED, &ha->dpc_flags)) || while (((test_bit(ISP_ABORT_NEEDED, &ha->dpc_flags)) ||
test_bit(ABORT_ISP_ACTIVE, &ha->dpc_flags) || test_bit(ABORT_ISP_ACTIVE, &ha->dpc_flags) ||
test_bit(ISP_ABORT_RETRY, &ha->dpc_flags)) && test_bit(ISP_ABORT_RETRY, &ha->dpc_flags) ||
time_before(jiffies, wait_online)) { ha->dpc_active) && time_before(jiffies, wait_online)) {
set_current_state(TASK_UNINTERRUPTIBLE); set_current_state(TASK_UNINTERRUPTIBLE);
schedule_timeout(HZ); schedule_timeout(HZ);
...@@ -969,7 +968,6 @@ qla2x00_wait_for_hba_online(scsi_qla_host_t *ha) ...@@ -969,7 +968,6 @@ qla2x00_wait_for_hba_online(scsi_qla_host_t *ha)
if (ha->flags.online == TRUE) if (ha->flags.online == TRUE)
return_status = QLA_SUCCESS; return_status = QLA_SUCCESS;
else else
/* Adapter is disabled/offline */
return_status = QLA_FUNCTION_FAILED; return_status = QLA_FUNCTION_FAILED;
DEBUG2(printk("%s return_status=%d\n",__func__,return_status)); DEBUG2(printk("%s return_status=%d\n",__func__,return_status));
...@@ -1044,7 +1042,6 @@ qla2xxx_eh_abort(struct scsi_cmnd *cmd) ...@@ -1044,7 +1042,6 @@ qla2xxx_eh_abort(struct scsi_cmnd *cmd)
struct Scsi_Host *host; struct Scsi_Host *host;
uint8_t found = 0; uint8_t found = 0;
unsigned int b, t, l; unsigned int b, t, l;
unsigned long flags;
/* Get the SCSI request ptr */ /* Get the SCSI request ptr */
sp = (srb_t *) CMD_SP(cmd); sp = (srb_t *) CMD_SP(cmd);
...@@ -1059,7 +1056,7 @@ qla2xxx_eh_abort(struct scsi_cmnd *cmd) ...@@ -1059,7 +1056,7 @@ qla2xxx_eh_abort(struct scsi_cmnd *cmd)
qla_printk(KERN_INFO, to_qla_host(cmd->device->host), qla_printk(KERN_INFO, to_qla_host(cmd->device->host),
"qla2xxx_eh_abort: cmd already done sp=%p\n", sp); "qla2xxx_eh_abort: cmd already done sp=%p\n", sp);
DEBUG(printk("qla2xxx_eh_abort: cmd already done sp=%p\n", sp);) DEBUG(printk("qla2xxx_eh_abort: cmd already done sp=%p\n", sp);)
return(SUCCESS); return SUCCESS;
} }
if (sp) { if (sp) {
DEBUG(printk("qla2xxx_eh_abort: refcount %i \n", DEBUG(printk("qla2xxx_eh_abort: refcount %i \n",
...@@ -1090,7 +1087,7 @@ qla2xxx_eh_abort(struct scsi_cmnd *cmd) ...@@ -1090,7 +1087,7 @@ qla2xxx_eh_abort(struct scsi_cmnd *cmd)
"qla2x00: (%x:%x:%x) No LUN queue.\n", b, t, l); "qla2x00: (%x:%x:%x) No LUN queue.\n", b, t, l);
/* no action - we don't have command */ /* no action - we don't have command */
return(FAILED); return FAILED;
} }
DEBUG2(printk("scsi(%ld): ABORTing cmd=%p sp=%p jiffies = 0x%lx, " DEBUG2(printk("scsi(%ld): ABORTing cmd=%p sp=%p jiffies = 0x%lx, "
...@@ -1100,16 +1097,15 @@ qla2xxx_eh_abort(struct scsi_cmnd *cmd) ...@@ -1100,16 +1097,15 @@ qla2xxx_eh_abort(struct scsi_cmnd *cmd)
DEBUG2(qla2x00_print_scsi_cmd(cmd)); DEBUG2(qla2x00_print_scsi_cmd(cmd));
spin_unlock_irq(ha->host->host_lock); spin_unlock_irq(ha->host->host_lock);
/* Blocking call-Does context switching if abort isp is active etc */
if (qla2x00_wait_for_hba_online(ha) != QLA_SUCCESS) { if (qla2x00_wait_for_hba_online(ha) != QLA_SUCCESS) {
DEBUG2(printk("%s failed:board disabled\n", __func__);) DEBUG2(printk("%s failed:board disabled\n", __func__);)
spin_lock_irq(ha->host->host_lock); spin_lock_irq(ha->host->host_lock);
return (FAILED); return FAILED;
} }
spin_lock_irq(ha->host->host_lock); spin_lock_irq(ha->host->host_lock);
/* Search done queue */ /* Search done queue */
spin_lock_irqsave(&ha->list_lock,flags); spin_lock(&ha->list_lock);
list_for_each_safe(list, temp, &ha->done_queue) { list_for_each_safe(list, temp, &ha->done_queue) {
rp = list_entry(list, srb_t, list); rp = list_entry(list, srb_t, list);
...@@ -1126,7 +1122,7 @@ qla2xxx_eh_abort(struct scsi_cmnd *cmd) ...@@ -1126,7 +1122,7 @@ qla2xxx_eh_abort(struct scsi_cmnd *cmd)
break; break;
} /* list_for_each_safe() */ } /* list_for_each_safe() */
spin_unlock_irqrestore(&ha->list_lock, flags); spin_unlock(&ha->list_lock);
/* /*
* Return immediately if the aborted command was already in the done * Return immediately if the aborted command was already in the done
...@@ -1147,7 +1143,7 @@ qla2xxx_eh_abort(struct scsi_cmnd *cmd) ...@@ -1147,7 +1143,7 @@ qla2xxx_eh_abort(struct scsi_cmnd *cmd)
DEBUG3(printk("qla2xxx_eh_abort: searching sp %p in retry " DEBUG3(printk("qla2xxx_eh_abort: searching sp %p in retry "
"queue.\n", sp);) "queue.\n", sp);)
spin_lock_irqsave(&ha->list_lock, flags); spin_lock(&ha->list_lock);
list_for_each_safe(list, temp, &ha->retry_queue) { list_for_each_safe(list, temp, &ha->retry_queue) {
rp = list_entry(list, srb_t, list); rp = list_entry(list, srb_t, list);
...@@ -1168,7 +1164,7 @@ qla2xxx_eh_abort(struct scsi_cmnd *cmd) ...@@ -1168,7 +1164,7 @@ qla2xxx_eh_abort(struct scsi_cmnd *cmd)
break; break;
} }
spin_unlock_irqrestore(&ha->list_lock, flags); spin_unlock(&ha->list_lock);
/* /*
...@@ -1179,7 +1175,7 @@ qla2xxx_eh_abort(struct scsi_cmnd *cmd) ...@@ -1179,7 +1175,7 @@ qla2xxx_eh_abort(struct scsi_cmnd *cmd)
DEBUG3(printk("qla2xxx_eh_abort: searching sp %p " DEBUG3(printk("qla2xxx_eh_abort: searching sp %p "
"in pending queue.\n", sp);) "in pending queue.\n", sp);)
spin_lock_irqsave(&vis_ha->list_lock, flags); spin_lock(&vis_ha->list_lock);
list_for_each_safe(list, temp, &vis_ha->pending_queue) { list_for_each_safe(list, temp, &vis_ha->pending_queue) {
rp = list_entry(list, srb_t, list); rp = list_entry(list, srb_t, list);
...@@ -1203,14 +1199,14 @@ qla2xxx_eh_abort(struct scsi_cmnd *cmd) ...@@ -1203,14 +1199,14 @@ qla2xxx_eh_abort(struct scsi_cmnd *cmd)
found++; found++;
break; break;
} /* list_for_each_safe() */ } /* list_for_each_safe() */
spin_unlock_irqrestore(&vis_ha->list_lock, flags); spin_unlock(&vis_ha->list_lock);
} /*End of if !found */ } /*End of if !found */
if (!found) { /* find the command in our active list */ if (!found) { /* find the command in our active list */
DEBUG3(printk("qla2xxx_eh_abort: searching sp %p " DEBUG3(printk("qla2xxx_eh_abort: searching sp %p "
"in outstanding queue.\n", sp);) "in outstanding queue.\n", sp);)
spin_lock_irqsave(&ha->hardware_lock, flags); spin_lock(&ha->hardware_lock);
for (i = 1; i < MAX_OUTSTANDING_COMMANDS; i++) { for (i = 1; i < MAX_OUTSTANDING_COMMANDS; i++) {
sp = ha->outstanding_cmds[i]; sp = ha->outstanding_cmds[i];
...@@ -1229,8 +1225,8 @@ qla2xxx_eh_abort(struct scsi_cmnd *cmd) ...@@ -1229,8 +1225,8 @@ qla2xxx_eh_abort(struct scsi_cmnd *cmd)
/* Get a reference to the sp and drop the lock.*/ /* Get a reference to the sp and drop the lock.*/
sp_get(ha, sp); sp_get(ha, sp);
spin_unlock_irqrestore(&ha->hardware_lock, flags); spin_unlock(&ha->hardware_lock);
spin_unlock(ha->host->host_lock); spin_unlock_irq(ha->host->host_lock);
if (qla2x00_abort_command(ha, sp)) { if (qla2x00_abort_command(ha, sp)) {
DEBUG2(printk("qla2xxx_eh_abort: abort_command " DEBUG2(printk("qla2xxx_eh_abort: abort_command "
...@@ -1245,7 +1241,7 @@ qla2xxx_eh_abort(struct scsi_cmnd *cmd) ...@@ -1245,7 +1241,7 @@ qla2xxx_eh_abort(struct scsi_cmnd *cmd)
sp_put(ha,sp); sp_put(ha,sp);
spin_lock_irq(ha->host->host_lock); spin_lock_irq(ha->host->host_lock);
spin_lock_irqsave(&ha->hardware_lock, flags); spin_lock(&ha->hardware_lock);
/* /*
* Regardless of mailbox command status, go check on * Regardless of mailbox command status, go check on
...@@ -1254,11 +1250,11 @@ qla2xxx_eh_abort(struct scsi_cmnd *cmd) ...@@ -1254,11 +1250,11 @@ qla2xxx_eh_abort(struct scsi_cmnd *cmd)
break; break;
}/*End of for loop */ }/*End of for loop */
spin_unlock_irqrestore(&ha->hardware_lock, flags); spin_unlock(&ha->hardware_lock);
} /*End of if !found */ } /*End of if !found */
/*Waiting for our command in done_queue to be returned to OS.*/ /* Waiting for our command in done_queue to be returned to OS.*/
if (qla2x00_eh_wait_on_command(ha, cmd) != 0) { if (qla2x00_eh_wait_on_command(ha, cmd) != 0) {
DEBUG2(printk("qla2xxx_eh_abort: cmd returned back to OS.\n");) DEBUG2(printk("qla2xxx_eh_abort: cmd returned back to OS.\n");)
return_status = SUCCESS; return_status = SUCCESS;
...@@ -1273,7 +1269,7 @@ qla2xxx_eh_abort(struct scsi_cmnd *cmd) ...@@ -1273,7 +1269,7 @@ qla2xxx_eh_abort(struct scsi_cmnd *cmd)
DEBUG2(printk("qla2xxx_eh_abort: Exiting. return_status=0x%x.\n", DEBUG2(printk("qla2xxx_eh_abort: Exiting. return_status=0x%x.\n",
return_status)); return_status));
return(return_status); return return_status;
} }
/************************************************************************** /**************************************************************************
...@@ -1295,7 +1291,6 @@ qla2x00_eh_wait_for_pending_target_commands(scsi_qla_host_t *ha, unsigned int t) ...@@ -1295,7 +1291,6 @@ qla2x00_eh_wait_for_pending_target_commands(scsi_qla_host_t *ha, unsigned int t)
{ {
int cnt; int cnt;
int status; int status;
unsigned long flags;
srb_t *sp; srb_t *sp;
struct scsi_cmnd *cmd; struct scsi_cmnd *cmd;
...@@ -1306,11 +1301,11 @@ qla2x00_eh_wait_for_pending_target_commands(scsi_qla_host_t *ha, unsigned int t) ...@@ -1306,11 +1301,11 @@ qla2x00_eh_wait_for_pending_target_commands(scsi_qla_host_t *ha, unsigned int t)
* array * array
*/ */
for (cnt = 1; cnt < MAX_OUTSTANDING_COMMANDS; cnt++) { for (cnt = 1; cnt < MAX_OUTSTANDING_COMMANDS; cnt++) {
spin_lock_irqsave(&ha->hardware_lock, flags); spin_lock(&ha->hardware_lock);
sp = ha->outstanding_cmds[cnt]; sp = ha->outstanding_cmds[cnt];
if (sp) { if (sp) {
cmd = sp->cmd; cmd = sp->cmd;
spin_unlock_irqrestore(&ha->hardware_lock, flags); spin_unlock(&ha->hardware_lock);
if (cmd->device->id == t) { if (cmd->device->id == t) {
if (!qla2x00_eh_wait_on_command(ha, cmd)) { if (!qla2x00_eh_wait_on_command(ha, cmd)) {
status = 1; status = 1;
...@@ -1319,7 +1314,7 @@ qla2x00_eh_wait_for_pending_target_commands(scsi_qla_host_t *ha, unsigned int t) ...@@ -1319,7 +1314,7 @@ qla2x00_eh_wait_for_pending_target_commands(scsi_qla_host_t *ha, unsigned int t)
} }
} }
else { else {
spin_unlock_irqrestore(&ha->hardware_lock, flags); spin_unlock(&ha->hardware_lock);
} }
} }
return (status); return (status);
...@@ -1354,7 +1349,6 @@ qla2xxx_eh_device_reset(struct scsi_cmnd *cmd) ...@@ -1354,7 +1349,6 @@ qla2xxx_eh_device_reset(struct scsi_cmnd *cmd)
os_tgt_t *tq; os_tgt_t *tq;
os_lun_t *lq; os_lun_t *lq;
fc_port_t *fcport_to_reset; fc_port_t *fcport_to_reset;
unsigned long flags;
srb_t *rp; srb_t *rp;
struct list_head *list, *temp; struct list_head *list, *temp;
...@@ -1402,7 +1396,7 @@ qla2xxx_eh_device_reset(struct scsi_cmnd *cmd) ...@@ -1402,7 +1396,7 @@ qla2xxx_eh_device_reset(struct scsi_cmnd *cmd)
ha->dpc_flags, cmd->result, cmd->allowed, cmd->state)); ha->dpc_flags, cmd->result, cmd->allowed, cmd->state));
/* Clear commands from the retry queue. */ /* Clear commands from the retry queue. */
spin_lock_irqsave(&ha->list_lock, flags); spin_lock(&ha->list_lock);
list_for_each_safe(list, temp, &ha->retry_queue) { list_for_each_safe(list, temp, &ha->retry_queue) {
rp = list_entry(list, srb_t, list); rp = list_entry(list, srb_t, list);
...@@ -1416,11 +1410,10 @@ qla2xxx_eh_device_reset(struct scsi_cmnd *cmd) ...@@ -1416,11 +1410,10 @@ qla2xxx_eh_device_reset(struct scsi_cmnd *cmd)
rp->cmd->result = DID_RESET << 16; rp->cmd->result = DID_RESET << 16;
__add_to_done_queue(ha, rp); __add_to_done_queue(ha, rp);
} }
spin_unlock_irqrestore(&ha->list_lock, flags); spin_unlock(&ha->list_lock);
spin_unlock_irq(ha->host->host_lock); spin_unlock_irq(ha->host->host_lock);
/* Blocking call-Does context switching if abort isp is active etc */
if (qla2x00_wait_for_hba_online(ha) != QLA_SUCCESS) { if (qla2x00_wait_for_hba_online(ha) != QLA_SUCCESS) {
DEBUG2(printk(KERN_INFO DEBUG2(printk(KERN_INFO
"%s failed:board disabled\n",__func__)); "%s failed:board disabled\n",__func__));
...@@ -1429,7 +1422,6 @@ qla2xxx_eh_device_reset(struct scsi_cmnd *cmd) ...@@ -1429,7 +1422,6 @@ qla2xxx_eh_device_reset(struct scsi_cmnd *cmd)
goto eh_dev_reset_done; goto eh_dev_reset_done;
} }
/* Blocking call-Does context switching if loop is Not Ready */
if (qla2x00_wait_for_loop_ready(ha) == QLA_SUCCESS) { if (qla2x00_wait_for_loop_ready(ha) == QLA_SUCCESS) {
if (qla2x00_device_reset(ha, fcport_to_reset) == 0) { if (qla2x00_device_reset(ha, fcport_to_reset) == 0) {
return_status = SUCCESS; return_status = SUCCESS;
...@@ -1453,7 +1445,7 @@ qla2xxx_eh_device_reset(struct scsi_cmnd *cmd) ...@@ -1453,7 +1445,7 @@ qla2xxx_eh_device_reset(struct scsi_cmnd *cmd)
if (return_status == FAILED) { if (return_status == FAILED) {
DEBUG3(printk("%s(%ld): device reset failed\n", DEBUG3(printk("%s(%ld): device reset failed\n",
__func__,ha->host_no)); __func__, ha->host_no));
qla_printk(KERN_INFO, ha, "%s: device reset failed\n", qla_printk(KERN_INFO, ha, "%s: device reset failed\n",
__func__); __func__);
...@@ -1511,7 +1503,6 @@ qla2x00_eh_wait_for_pending_commands(scsi_qla_host_t *ha) ...@@ -1511,7 +1503,6 @@ qla2x00_eh_wait_for_pending_commands(scsi_qla_host_t *ha)
{ {
int cnt; int cnt;
int status; int status;
unsigned long flags;
srb_t *sp; srb_t *sp;
struct scsi_cmnd *cmd; struct scsi_cmnd *cmd;
...@@ -1522,17 +1513,17 @@ qla2x00_eh_wait_for_pending_commands(scsi_qla_host_t *ha) ...@@ -1522,17 +1513,17 @@ qla2x00_eh_wait_for_pending_commands(scsi_qla_host_t *ha)
* array * array
*/ */
for (cnt = 1; cnt < MAX_OUTSTANDING_COMMANDS; cnt++) { for (cnt = 1; cnt < MAX_OUTSTANDING_COMMANDS; cnt++) {
spin_lock_irqsave(&ha->hardware_lock, flags); spin_lock(&ha->hardware_lock);
sp = ha->outstanding_cmds[cnt]; sp = ha->outstanding_cmds[cnt];
if (sp) { if (sp) {
cmd = sp->cmd; cmd = sp->cmd;
spin_unlock_irqrestore(&ha->hardware_lock, flags); spin_unlock(&ha->hardware_lock);
status = qla2x00_eh_wait_on_command(ha, cmd); status = qla2x00_eh_wait_on_command(ha, cmd);
if (status == 0) if (status == 0)
break; break;
} }
else { else {
spin_unlock_irqrestore(&ha->hardware_lock, flags); spin_unlock(&ha->hardware_lock);
} }
} }
return (status); return (status);
...@@ -1570,14 +1561,12 @@ qla2xxx_eh_bus_reset(struct scsi_cmnd *cmd) ...@@ -1570,14 +1561,12 @@ qla2xxx_eh_bus_reset(struct scsi_cmnd *cmd)
spin_unlock_irq(ha->host->host_lock); spin_unlock_irq(ha->host->host_lock);
/* Blocking call-Does context switching if abort isp is active etc*/
if (qla2x00_wait_for_hba_online(ha) != QLA_SUCCESS) { if (qla2x00_wait_for_hba_online(ha) != QLA_SUCCESS) {
DEBUG2(printk("%s failed:board disabled\n",__func__)); DEBUG2(printk("%s failed:board disabled\n",__func__));
spin_lock_irq(ha->host->host_lock); spin_lock_irq(ha->host->host_lock);
return FAILED; return FAILED;
} }
/* Blocking call-Does context switching if loop is Not Ready */
if (qla2x00_wait_for_loop_ready(ha) == QLA_SUCCESS) { if (qla2x00_wait_for_loop_ready(ha) == QLA_SUCCESS) {
if (qla2x00_loop_reset(ha)) if (qla2x00_loop_reset(ha))
rval = SUCCESS; rval = SUCCESS;
...@@ -1637,7 +1626,6 @@ qla2xxx_eh_host_reset(struct scsi_cmnd *cmd) ...@@ -1637,7 +1626,6 @@ qla2xxx_eh_host_reset(struct scsi_cmnd *cmd)
spin_unlock_irq(ha->host->host_lock); spin_unlock_irq(ha->host->host_lock);
/* Blocking call-Does context switching if abort isp is active etc*/
if (qla2x00_wait_for_hba_online(ha) != QLA_SUCCESS) if (qla2x00_wait_for_hba_online(ha) != QLA_SUCCESS)
goto board_disabled; goto board_disabled;
......
Markdown is supported
0%
or
You are about to add 0 people to the discussion. Proceed with caution.
Finish editing this message first!
Please register or to comment