diff options
Diffstat (limited to 'drivers')
-rw-r--r-- | drivers/scsi/scsi.c | 18 |
1 files changed, 18 insertions, 0 deletions
diff --git a/drivers/scsi/scsi.c b/drivers/scsi/scsi.c index 73994e2ac2cb..dae4f08adde0 100644 --- a/drivers/scsi/scsi.c +++ b/drivers/scsi/scsi.c | |||
@@ -720,6 +720,24 @@ void scsi_init_cmd_from_req(struct scsi_cmnd *cmd, struct scsi_request *sreq) | |||
720 | static DEFINE_PER_CPU(struct list_head, scsi_done_q); | 720 | static DEFINE_PER_CPU(struct list_head, scsi_done_q); |
721 | 721 | ||
722 | /** | 722 | /** |
723 | * scsi_req_abort_cmd -- Request command recovery for the specified command | ||
724 | * cmd: pointer to the SCSI command of interest | ||
725 | * | ||
726 | * This function requests that SCSI Core start recovery for the | ||
727 | * command by deleting the timer and adding the command to the eh | ||
728 | * queue. It can be called by either LLDDs or SCSI Core. LLDDs who | ||
729 | * implement their own error recovery MAY ignore the timeout event if | ||
730 | * they generated scsi_req_abort_cmd. | ||
731 | */ | ||
732 | void scsi_req_abort_cmd(struct scsi_cmnd *cmd) | ||
733 | { | ||
734 | if (!scsi_delete_timer(cmd)) | ||
735 | return; | ||
736 | scsi_times_out(cmd); | ||
737 | } | ||
738 | EXPORT_SYMBOL(scsi_req_abort_cmd); | ||
739 | |||
740 | /** | ||
723 | * scsi_done - Enqueue the finished SCSI command into the done queue. | 741 | * scsi_done - Enqueue the finished SCSI command into the done queue. |
724 | * @cmd: The SCSI Command for which a low-level device driver (LLDD) gives | 742 | * @cmd: The SCSI Command for which a low-level device driver (LLDD) gives |
725 | * ownership back to SCSI Core -- i.e. the LLDD has finished with it. | 743 | * ownership back to SCSI Core -- i.e. the LLDD has finished with it. |