diff options
Diffstat (limited to 'drivers/scsi/libsas/sas_scsi_host.c')
| -rw-r--r-- | drivers/scsi/libsas/sas_scsi_host.c | 18 | 
1 files changed, 9 insertions, 9 deletions
| 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) | 
