Some HBAs will always send a command completion on the original command after a ABORT TASK TMF has been send. For those it's pointless to wait for the TMF itself to finish, but we can as well reset the timer for the failed command and wait for the command completion to finish up the command. Signed-off-by: Hannes Reinecke <hare@xxxxxxxx> --- drivers/scsi/scsi_error.c | 7 +++++-- include/scsi/scsi_host.h | 6 ++++++ 2 files changed, 11 insertions(+), 2 deletions(-) diff --git a/drivers/scsi/scsi_error.c b/drivers/scsi/scsi_error.c index a8b610e..e4a1592 100644 --- a/drivers/scsi/scsi_error.c +++ b/drivers/scsi/scsi_error.c @@ -285,8 +285,11 @@ enum blk_eh_timer_return scsi_times_out(struct request *req) rtn = host->hostt->eh_timed_out(scmd); if (rtn == BLK_EH_NOT_HANDLED) { - if (!host->hostt->no_async_abort && - scsi_abort_command(scmd) == SUCCESS) + if (host->hostt->abort_completions && + scsi_try_to_abort_cmd(host->hostt, scmd) == SUCCESS) + return BLK_EH_RESET_TIMER; + else if (!host->hostt->no_async_abort && + scsi_abort_command(scmd) == SUCCESS) return BLK_EH_NOT_HANDLED; set_host_byte(scmd, DID_TIME_OUT); diff --git a/include/scsi/scsi_host.h b/include/scsi/scsi_host.h index 76e9d27..2af2397 100644 --- a/include/scsi/scsi_host.h +++ b/include/scsi/scsi_host.h @@ -449,6 +449,12 @@ struct scsi_host_template { unsigned no_async_abort:1; /* + * True if aborts will trigger a command completion + * of the failed command + */ + unsigned abort_completions:1; + + /* * Countdown for host blocking with no commands outstanding. */ unsigned int max_host_blocked; -- 1.8.5.6 -- 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