From: Mike Christie <michaelc@xxxxxxxxxxx> This renames scsi_queue_insert to scsi_attempt_requeue_command, because it may not be able to requeue the command if there are not retries left or if failfast is set. The naming is also meant to better match the other requeue function, scsi_requeue_command, which will always requeue a command. Signed-off-by: Mike Christie <michaelc@xxxxxxxxxxx> Signed-off-by: Mike Anderson <andmike@xxxxxxxxxxxxxxxxxx> --- drivers/scsi/scsi.c | 4 ++-- drivers/scsi/scsi_error.c | 3 ++- drivers/scsi/scsi_lib.c | 22 ++++++++++++++-------- drivers/scsi/scsi_priv.h | 2 +- 4 files changed, 19 insertions(+), 12 deletions(-) diff --git a/drivers/scsi/scsi.c b/drivers/scsi/scsi.c index f8b79d4..5c116d9 100644 --- a/drivers/scsi/scsi.c +++ b/drivers/scsi/scsi.c @@ -678,7 +678,7 @@ int scsi_dispatch_cmd(struct scsi_cmnd *cmd) * suspend state. */ - scsi_queue_insert(cmd, SCSI_MLQUEUE_DEVICE_BUSY); + scsi_attempt_requeue_command(cmd, SCSI_MLQUEUE_DEVICE_BUSY); SCSI_LOG_MLQUEUE(3, printk("queuecommand : device blocked \n")); @@ -758,7 +758,7 @@ int scsi_dispatch_cmd(struct scsi_cmnd *cmd) rtn != SCSI_MLQUEUE_TARGET_BUSY) rtn = SCSI_MLQUEUE_HOST_BUSY; - scsi_queue_insert(cmd, rtn); + scsi_attempt_requeue_command(cmd, rtn); SCSI_LOG_MLQUEUE(3, printk("queuecommand : request rejected\n")); diff --git a/drivers/scsi/scsi_error.c b/drivers/scsi/scsi_error.c index ae46cb0..02f999b 100644 --- a/drivers/scsi/scsi_error.c +++ b/drivers/scsi/scsi_error.c @@ -1536,7 +1536,8 @@ void scsi_eh_flush_done_q(struct list_head *done_q) " retry cmd: %p\n", current->comm, scmd)); - scsi_queue_insert(scmd, SCSI_MLQUEUE_DIS_RETRY); + scsi_attempt_requeue_command(scmd, + SCSI_MLQUEUE_DIS_RETRY); } else { /* * If just we got sense for the device (called diff --git a/drivers/scsi/scsi_lib.c b/drivers/scsi/scsi_lib.c index d78147a..34a50e0 100644 --- a/drivers/scsi/scsi_lib.c +++ b/drivers/scsi/scsi_lib.c @@ -92,9 +92,9 @@ static void scsi_unprep_request(struct request *req) } /* - * Function: scsi_queue_insert() + * Function: scsi_attempt_requeue_command() * - * Purpose: Insert a command in the midlevel queue. + * Purpose: Attempt to insert a command in the midlevel queue. * * Arguments: cmd - command that we are adding to queue. * reason - why we are inserting command to queue. @@ -103,14 +103,20 @@ static void scsi_unprep_request(struct request *req) * * Returns: Nothing. * - * Notes: We do this for one of two cases. Either the host is busy - * and it cannot accept any more commands for the time being, - * or the device returned QUEUE_FULL and can accept no more - * commands. + * Notes: We do this for multiple cases. + * + * Host or device queueing: + * Either the host or device is busy and it cannot accept any more + * commands for the time being. + * + * SCSI error processing: + * The scsi-eh has decided to requeue a command after getting + * a command it believes ir retryable. + * * Notes: This could be called either from an interrupt context or a * normal process context. */ -int scsi_queue_insert(struct scsi_cmnd *cmd, int reason) +int scsi_attempt_requeue_command(struct scsi_cmnd *cmd, int reason) { struct Scsi_Host *host = cmd->device->host; struct scsi_device *device = cmd->device; @@ -1539,7 +1545,7 @@ static void scsi_softirq_done(struct request *rq) if (scsi_disposition_finish(disposition)) scsi_finish_command(cmd); else if (scsi_disposition_retry(disposition)) - scsi_queue_insert(cmd, disposition); + scsi_attempt_requeue_command(cmd, disposition); else if (!scsi_eh_scmd_add(cmd, 0)) scsi_finish_command(cmd); diff --git a/drivers/scsi/scsi_priv.h b/drivers/scsi/scsi_priv.h index e185090..0de6769 100644 --- a/drivers/scsi/scsi_priv.h +++ b/drivers/scsi/scsi_priv.h @@ -64,7 +64,7 @@ int scsi_noretry_cmd(struct scsi_cmnd *scmd); /* scsi_lib.c */ extern int scsi_maybe_unblock_host(struct scsi_device *sdev); extern void scsi_device_unbusy(struct scsi_device *sdev); -extern int scsi_queue_insert(struct scsi_cmnd *cmd, int reason); +extern int scsi_attempt_requeue_command(struct scsi_cmnd *cmd, int reason); extern void scsi_next_command(struct scsi_cmnd *cmd); extern void scsi_io_completion(struct scsi_cmnd *, unsigned int); extern void scsi_run_host_queues(struct Scsi_Host *shost); -- 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