Move retries check to scsi_queue_insert. Signed-off-by: Mike Christie <michaelc@xxxxxxxxxxx> Signed-off-by: Mike Anderson <andmike@xxxxxxxxxxxxxxxxxx> --- drivers/scsi/scsi_error.c | 8 ++------ drivers/scsi/scsi_lib.c | 7 +++++++ 2 files changed, 9 insertions(+), 6 deletions(-) diff --git a/drivers/scsi/scsi_error.c b/drivers/scsi/scsi_error.c index 4e30343..eb4290a 100644 --- a/drivers/scsi/scsi_error.c +++ b/drivers/scsi/scsi_error.c @@ -1347,8 +1347,6 @@ int scsi_decide_disposition(struct scsi_cmnd *scmd) case DID_SOFT_ERROR: goto maybe_retry; case DID_IMM_RETRY: - return NEEDS_RETRY; - case DID_REQUEUE: return ADD_TO_MLQUEUE; case DID_TRANSPORT_DISRUPTED: @@ -1456,8 +1454,7 @@ int scsi_decide_disposition(struct scsi_cmnd *scmd) * the request was not marked fast fail. Note that above, * even if the request is marked fast fail, we still requeue * for queue congestion conditions (QUEUE_FULL or BUSY) */ - if ((++scmd->retries) <= scmd->allowed - && !blk_noretry_request(scmd->request)) { + if (!blk_noretry_request(scmd->request)) { return NEEDS_RETRY; } else { /* @@ -1582,8 +1579,7 @@ void scsi_eh_flush_done_q(struct list_head *done_q) list_for_each_entry_safe(scmd, next, done_q, eh_entry) { list_del_init(&scmd->eh_entry); if (scsi_device_online(scmd->device) && - !blk_noretry_request(scmd->request) && - (++scmd->retries <= scmd->allowed)) { + !blk_noretry_request(scmd->request)) { SCSI_LOG_ERROR_RECOVERY(3, printk("%s: flush" " retry cmd: %p\n", current->comm, diff --git a/drivers/scsi/scsi_lib.c b/drivers/scsi/scsi_lib.c index b340087..afb4b33 100644 --- a/drivers/scsi/scsi_lib.c +++ b/drivers/scsi/scsi_lib.c @@ -146,6 +146,13 @@ int scsi_queue_insert(struct scsi_cmnd *cmd, int reason) host->host_blocked = host->max_host_blocked; else if (reason == SCSI_MLQUEUE_DEVICE_BUSY) device->device_blocked = device->max_device_blocked; + else if (reason == SCSI_MLQUEUE_EH_RETRY) { + if (++cmd->retries > cmd->allowed) { + set_driver_byte(cmd, DRIVER_TIMEOUT); + scsi_finish_command(cmd); + return 0; + } + } /* * Decrement the counters, since these commands are no longer -- 1.5.5.1 -- 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