diff options
author | Darrick J. Wong <djwong@us.ibm.com> | 2007-01-30 10:18:35 +0100 |
---|---|---|
committer | James Bottomley <jejb@mulgrave.localdomain> | 2007-07-18 18:14:55 +0200 |
commit | 3eb7a51a3ae0ed0227e051ecf75199fccbb4cc73 (patch) | |
tree | 656ac071a158ad355b936999a30548a1f575d339 /drivers/scsi/libsas/sas_scsi_host.c | |
parent | [SCSI] aic94xx: Don't call pci_map_sg for already-mapped scatterlists (diff) | |
download | linux-3eb7a51a3ae0ed0227e051ecf75199fccbb4cc73.tar.xz linux-3eb7a51a3ae0ed0227e051ecf75199fccbb4cc73.zip |
[SCSI] sas_ata: Satisfy libata qc function locking requirements
ata_qc_complete and ata_sas_queuecmd require that the port lock be held
when they are called. sas_ata doesn't do this, leading to BUG messages
about qc tags newly allocated qc tags already being in use. This patch
fixes the locking, which should clean up the rest of those messages.
So far I've tested this against an IBM x206m with two SATA disks with no
BUG messages and no other signs of things going wrong, and the machine
finally passed the pounder stress test.
Signed-off-by: Darrick J. Wong <djwong@us.ibm.com>
Signed-off-by: James Bottomley <James.Bottomley@SteelEye.com>
Diffstat (limited to 'drivers/scsi/libsas/sas_scsi_host.c')
-rw-r--r-- | drivers/scsi/libsas/sas_scsi_host.c | 4 |
1 files changed, 4 insertions, 0 deletions
diff --git a/drivers/scsi/libsas/sas_scsi_host.c b/drivers/scsi/libsas/sas_scsi_host.c index dbc2a912114f..ba5c91b81312 100644 --- a/drivers/scsi/libsas/sas_scsi_host.c +++ b/drivers/scsi/libsas/sas_scsi_host.c @@ -216,8 +216,12 @@ int sas_queuecommand(struct scsi_cmnd *cmd, struct sas_task *task; if (dev_is_sata(dev)) { + unsigned long flags; + + spin_lock_irqsave(dev->sata_dev.ap->lock, flags); res = ata_sas_queuecmd(cmd, scsi_done, dev->sata_dev.ap); + spin_unlock_irqrestore(dev->sata_dev.ap->lock, flags); goto out; } |