diff options
author | Linus Torvalds <torvalds@linux-foundation.org> | 2010-05-21 10:19:18 -0400 |
---|---|---|
committer | Linus Torvalds <torvalds@linux-foundation.org> | 2010-05-21 10:19:18 -0400 |
commit | 33cf23b0a535475aead57707cb9f4fe135a93544 (patch) | |
tree | 67e14f77f0eeab847a26a6cbfcb44eecb5fa2fda /drivers/scsi/libsas | |
parent | 7a9b149212f3716c598afe973b6261fd58453b7a (diff) | |
parent | 95bb335c0ebe96afe926387a1ef3a096bd884a82 (diff) |
Merge git://git.kernel.org/pub/scm/linux/kernel/git/jejb/scsi-misc-2.6
* git://git.kernel.org/pub/scm/linux/kernel/git/jejb/scsi-misc-2.6: (182 commits)
[SCSI] aacraid: add an ifdef'd device delete case instead of taking the device offline
[SCSI] aacraid: prohibit access to array container space
[SCSI] aacraid: add support for handling ATA pass-through commands.
[SCSI] aacraid: expose physical devices for models with newer firmware
[SCSI] aacraid: respond automatically to volumes added by config tool
[SCSI] fcoe: fix fcoe module ref counting
[SCSI] libfcoe: FIP Keep-Alive messages for VPorts are sent with incorrect port_id and wwn
[SCSI] libfcoe: Fix incorrect MAC address clearing
[SCSI] fcoe: fix a circular locking issue with rtnl and sysfs mutex
[SCSI] libfc: Move the port_id into lport
[SCSI] fcoe: move link speed checking into its own routine
[SCSI] libfc: Remove extra pointer check
[SCSI] libfc: Remove unused fc_get_host_port_type
[SCSI] fcoe: fixes wrong error exit in fcoe_create
[SCSI] libfc: set seq_id for incoming sequence
[SCSI] qla2xxx: Updates to ISP82xx support.
[SCSI] qla2xxx: Optionally disable target reset.
[SCSI] qla2xxx: ensure flash operation and host reset via sg_reset are mutually exclusive
[SCSI] qla2xxx: Silence bogus warning by gcc for wrap and did.
[SCSI] qla2xxx: T10 DIF support added.
...
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 | 16 |
2 files changed, 11 insertions, 10 deletions
diff --git a/drivers/scsi/libsas/sas_ata.c b/drivers/scsi/libsas/sas_ata.c index 88f744672576..8c496b56556c 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, | |||
395 | void sas_ata_task_abort(struct sas_task *task) | 395 | void sas_ata_task_abort(struct sas_task *task) |
396 | { | 396 | { |
397 | struct ata_queued_cmd *qc = task->uldd_task; | 397 | struct ata_queued_cmd *qc = task->uldd_task; |
398 | struct request_queue *q = qc->scsicmd->device->request_queue; | ||
399 | struct completion *waiting; | 398 | struct completion *waiting; |
400 | unsigned long flags; | ||
401 | 399 | ||
402 | /* Bounce SCSI-initiated commands to the SCSI EH */ | 400 | /* Bounce SCSI-initiated commands to the SCSI EH */ |
403 | if (qc->scsicmd) { | 401 | if (qc->scsicmd) { |
402 | struct request_queue *q = qc->scsicmd->device->request_queue; | ||
403 | unsigned long flags; | ||
404 | |||
404 | spin_lock_irqsave(q->queue_lock, flags); | 405 | spin_lock_irqsave(q->queue_lock, flags); |
405 | blk_abort_request(qc->scsicmd->request); | 406 | blk_abort_request(qc->scsicmd->request); |
406 | spin_unlock_irqrestore(q->queue_lock, flags); | 407 | 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 b71b6d41baa1..a7890c6d878e 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) |