diff options
Diffstat (limited to 'drivers/scsi/libsas')
| -rw-r--r-- | drivers/scsi/libsas/sas_ata.c | 5 | ||||
| -rw-r--r-- | drivers/scsi/libsas/sas_scsi_host.c | 18 | 
2 files changed, 12 insertions, 11 deletions
| diff --git a/drivers/scsi/libsas/sas_ata.c b/drivers/scsi/libsas/sas_ata.c index 88f74467257..8c496b56556 100644 --- a/drivers/scsi/libsas/sas_ata.c +++ b/drivers/scsi/libsas/sas_ata.c @@ -395,12 +395,13 @@ int sas_ata_init_host_and_port(struct domain_device *found_dev,  void sas_ata_task_abort(struct sas_task *task)  {  	struct ata_queued_cmd *qc = task->uldd_task; -	struct request_queue *q = qc->scsicmd->device->request_queue;  	struct completion *waiting; -	unsigned long flags;  	/* Bounce SCSI-initiated commands to the SCSI EH */  	if (qc->scsicmd) { +		struct request_queue *q = qc->scsicmd->device->request_queue; +		unsigned long flags; +  		spin_lock_irqsave(q->queue_lock, flags);  		blk_abort_request(qc->scsicmd->request);  		spin_unlock_irqrestore(q->queue_lock, flags); diff --git a/drivers/scsi/libsas/sas_scsi_host.c b/drivers/scsi/libsas/sas_scsi_host.c index 822835055ce..a7890c6d878 100644 --- a/drivers/scsi/libsas/sas_scsi_host.c +++ b/drivers/scsi/libsas/sas_scsi_host.c @@ -818,7 +818,7 @@ void sas_slave_destroy(struct scsi_device *scsi_dev)  	struct domain_device *dev = sdev_to_domain_dev(scsi_dev);  	if (dev_is_sata(dev)) -		ata_port_disable(dev->sata_dev.ap); +		dev->sata_dev.ap->link.device[0].class = ATA_DEV_NONE;  }  int sas_change_queue_depth(struct scsi_device *scsi_dev, int new_depth, @@ -1030,8 +1030,6 @@ int __sas_task_abort(struct sas_task *task)  void sas_task_abort(struct sas_task *task)  {  	struct scsi_cmnd *sc = task->uldd_task; -	struct request_queue *q = sc->device->request_queue; -	unsigned long flags;  	/* Escape for libsas internal commands */  	if (!sc) { @@ -1043,13 +1041,15 @@ void sas_task_abort(struct sas_task *task)  	if (dev_is_sata(task->dev)) {  		sas_ata_task_abort(task); -		return; -	} +	} else { +		struct request_queue *q = sc->device->request_queue; +		unsigned long flags; -	spin_lock_irqsave(q->queue_lock, flags); -	blk_abort_request(sc->request); -	spin_unlock_irqrestore(q->queue_lock, flags); -	scsi_schedule_eh(sc->device->host); +		spin_lock_irqsave(q->queue_lock, flags); +		blk_abort_request(sc->request); +		spin_unlock_irqrestore(q->queue_lock, flags); +		scsi_schedule_eh(sc->device->host); +	}  }  int sas_slave_alloc(struct scsi_device *scsi_dev) | 
