From: Vikas Chaudhary <vikas.chaudhary@xxxxxxxxxx> Created variables to reference h, b, t, l, because if scsi passthru command completes within eh_device_reset, the cmd structure may no longer be valid. Signed-off-by: Karen Higgins <karen.higgins@xxxxxxxxxx> Signed-off-by: Vikas Chaudhary <vikas.chaudhary@xxxxxxxxxx> Signed-off-by: Ravi Anand <ravi.anand@xxxxxxxxxx> --- drivers/scsi/qla4xxx/ql4_os.c | 53 +++++++++++++++++++++++++++++++--------- 1 files changed, 41 insertions(+), 12 deletions(-) diff --git a/drivers/scsi/qla4xxx/ql4_os.c b/drivers/scsi/qla4xxx/ql4_os.c index e5c9b85..b780d29 100644 --- a/drivers/scsi/qla4xxx/ql4_os.c +++ b/drivers/scsi/qla4xxx/ql4_os.c @@ -1619,16 +1619,34 @@ static int qla4xxx_eh_wait_for_commands(struct scsi_qla_host *ha, **/ static int qla4xxx_eh_device_reset(struct scsi_cmnd *cmd) { - struct scsi_qla_host *ha = to_qla_host(cmd->device->host); - struct ddb_entry *ddb_entry = cmd->device->hostdata; + struct scsi_qla_host *ha; + struct ddb_entry *ddb_entry; int ret = FAILED, stat; + struct Scsi_Host *h; + unsigned int b, t, l; + + if (cmd == NULL) { + DEBUG2(printk("%s: **** SCSI mid-layer passing in NULL cmd" + "DEVICE RESET - cmd already completed.\n", + __func__)); + return SUCCESS; + } - if (!ddb_entry) + h = cmd->device->host; + b = cmd->device->channel; + t = cmd->device->id; + l = cmd->device->lun; + ha = to_qla_host(h); + ddb_entry = cmd->device->hostdata; + + if (!ddb_entry) { + DEBUG2(printk("scsi%ld: DEVICE RESET - NULL ddb entry.\n" + , ha->host_no)); return ret; + } - dev_info(&ha->pdev->dev, - "scsi%ld:%d:%d:%d: DEVICE RESET ISSUED.\n", ha->host_no, - cmd->device->channel, cmd->device->id, cmd->device->lun); + dev_info(&ha->pdev->dev, "scsi%ld:%d:%d:%d: DEVICE RESET ISSUED.\n" + , ha->host_no, b, t, l); DEBUG2(printk(KERN_INFO "scsi%ld: DEVICE_RESET cmd=%p jiffies = 0x%lx, to=%x," @@ -1636,8 +1654,13 @@ static int qla4xxx_eh_device_reset(struct scsi_cmnd *cmd) cmd, jiffies, cmd->request->timeout / HZ, ha->dpc_flags, cmd->result, cmd->allowed)); - /* FIXME: wait for hba to go online */ - stat = qla4xxx_reset_lun(ha, ddb_entry, cmd->device->lun); + /* wait for hba to go online */ + if (qla4xxx_wait_for_hba_online(ha) != QLA_SUCCESS) { + dev_info(&ha->pdev->dev, "%s: DEVICE RESET." + "Adapter Offline.\n", __func__); + return FAILED; + } + stat = qla4xxx_reset_lun(ha, ddb_entry, l); if (stat != QLA_SUCCESS) { dev_info(&ha->pdev->dev, "DEVICE RESET FAILED. %d\n", stat); goto eh_dev_reset_done; @@ -1652,14 +1675,13 @@ static int qla4xxx_eh_device_reset(struct scsi_cmnd *cmd) } /* Send marker. */ - if (qla4xxx_send_marker_iocb(ha, ddb_entry, cmd->device->lun, - MM_LUN_RESET) != QLA_SUCCESS) + if (qla4xxx_send_marker_iocb(ha, ddb_entry, l, MM_LUN_RESET) + != QLA_SUCCESS) goto eh_dev_reset_done; dev_info(&ha->pdev->dev, "scsi(%ld:%d:%d:%d): DEVICE RESET SUCCEEDED.\n", - ha->host_no, cmd->device->channel, cmd->device->id, - cmd->device->lun); + ha->host_no, b, t, l); ret = SUCCESS; @@ -1733,6 +1755,13 @@ static int qla4xxx_eh_host_reset(struct scsi_cmnd *cmd) int return_status = FAILED; struct scsi_qla_host *ha; + if (cmd == NULL) { + DEBUG2(printk("%s: **** SCSI mid-layer passing in NULL cmd" + "HOST RESET - cmd already completed.\n", + __func__)); + return SUCCESS; + } + ha = (struct scsi_qla_host *) cmd->device->host->hostdata; dev_info(&ha->pdev->dev, -- 1.6.0.2 -- To unsubscribe from this list: send the line "unsubscribe linux-scsi" in the body of a message to majordomo@xxxxxxxxxxxxxxx More majordomo info at http://vger.kernel.org/majordomo-info.html