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 | { |
