diff options
author | Dan Williams <dan.j.williams@intel.com> | 2012-06-22 02:30:53 -0400 |
---|---|---|
committer | James Bottomley <JBottomley@Parallels.com> | 2012-07-20 03:58:50 -0400 |
commit | 9524c6821849bddad4bf592a47276cfb8a8a98c0 (patch) | |
tree | f49578198e8ab3388f529a7a39aefc69af535d82 /drivers/scsi/libsas | |
parent | 5db45bdc87ce4f503947adf7896586d60c63322c (diff) |
[SCSI] libsas: add sas_eh_abort_handler
When recovering failed eh-cmnds let the lldd attempt an abort via
scsi_abort_eh_cmnd before escalating.
Reviewed-by: Jacek Danecki <jacek.danecki@intel.com>
Signed-off-by: Dan Williams <dan.j.williams@intel.com>
Signed-off-by: James Bottomley <JBottomley@Parallels.com>
Diffstat (limited to 'drivers/scsi/libsas')
-rw-r--r-- | drivers/scsi/libsas/sas_scsi_host.c | 21 |
1 files changed, 21 insertions, 0 deletions
diff --git a/drivers/scsi/libsas/sas_scsi_host.c b/drivers/scsi/libsas/sas_scsi_host.c index 2e0e779fb3b2..875b87112c50 100644 --- a/drivers/scsi/libsas/sas_scsi_host.c +++ b/drivers/scsi/libsas/sas_scsi_host.c | |||
@@ -531,6 +531,27 @@ static int sas_queue_reset(struct domain_device *dev, int reset_type, int lun, i | |||
531 | return FAILED; | 531 | return FAILED; |
532 | } | 532 | } |
533 | 533 | ||
534 | int sas_eh_abort_handler(struct scsi_cmnd *cmd) | ||
535 | { | ||
536 | int res; | ||
537 | struct sas_task *task = TO_SAS_TASK(cmd); | ||
538 | struct Scsi_Host *host = cmd->device->host; | ||
539 | struct sas_internal *i = to_sas_internal(host->transportt); | ||
540 | |||
541 | if (current != host->ehandler) | ||
542 | return FAILED; | ||
543 | |||
544 | if (!i->dft->lldd_abort_task) | ||
545 | return FAILED; | ||
546 | |||
547 | res = i->dft->lldd_abort_task(task); | ||
548 | if (res == TMF_RESP_FUNC_SUCC || res == TMF_RESP_FUNC_COMPLETE) | ||
549 | return SUCCESS; | ||
550 | |||
551 | return FAILED; | ||
552 | } | ||
553 | EXPORT_SYMBOL_GPL(sas_eh_abort_handler); | ||
554 | |||
534 | /* Attempt to send a LUN reset message to a device */ | 555 | /* Attempt to send a LUN reset message to a device */ |
535 | int sas_eh_device_reset_handler(struct scsi_cmnd *cmd) | 556 | int sas_eh_device_reset_handler(struct scsi_cmnd *cmd) |
536 | { | 557 | { |