diff options
Diffstat (limited to 'drivers/scsi/libsas/sas_scsi_host.c')
-rw-r--r-- | drivers/scsi/libsas/sas_scsi_host.c | 16 |
1 files changed, 8 insertions, 8 deletions
diff --git a/drivers/scsi/libsas/sas_scsi_host.c b/drivers/scsi/libsas/sas_scsi_host.c index 822835055cef..53849f21ad42 100644 --- a/drivers/scsi/libsas/sas_scsi_host.c +++ b/drivers/scsi/libsas/sas_scsi_host.c | |||
@@ -1030,8 +1030,6 @@ int __sas_task_abort(struct sas_task *task) | |||
1030 | void sas_task_abort(struct sas_task *task) | 1030 | void sas_task_abort(struct sas_task *task) |
1031 | { | 1031 | { |
1032 | struct scsi_cmnd *sc = task->uldd_task; | 1032 | struct scsi_cmnd *sc = task->uldd_task; |
1033 | struct request_queue *q = sc->device->request_queue; | ||
1034 | unsigned long flags; | ||
1035 | 1033 | ||
1036 | /* Escape for libsas internal commands */ | 1034 | /* Escape for libsas internal commands */ |
1037 | if (!sc) { | 1035 | if (!sc) { |
@@ -1043,13 +1041,15 @@ void sas_task_abort(struct sas_task *task) | |||
1043 | 1041 | ||
1044 | if (dev_is_sata(task->dev)) { | 1042 | if (dev_is_sata(task->dev)) { |
1045 | sas_ata_task_abort(task); | 1043 | sas_ata_task_abort(task); |
1046 | return; | 1044 | } else { |
1047 | } | 1045 | struct request_queue *q = sc->device->request_queue; |
1046 | unsigned long flags; | ||
1048 | 1047 | ||
1049 | spin_lock_irqsave(q->queue_lock, flags); | 1048 | spin_lock_irqsave(q->queue_lock, flags); |
1050 | blk_abort_request(sc->request); | 1049 | blk_abort_request(sc->request); |
1051 | spin_unlock_irqrestore(q->queue_lock, flags); | 1050 | spin_unlock_irqrestore(q->queue_lock, flags); |
1052 | scsi_schedule_eh(sc->device->host); | 1051 | scsi_schedule_eh(sc->device->host); |
1052 | } | ||
1053 | } | 1053 | } |
1054 | 1054 | ||
1055 | int sas_slave_alloc(struct scsi_device *scsi_dev) | 1055 | int sas_slave_alloc(struct scsi_device *scsi_dev) |