summaryrefslogtreecommitdiffstats
diff options
context:
space:
mode:
authorFUJITA Tomonori <tomof@acm.org>2008-02-19 09:02:27 +0100
committerJames Bottomley <James.Bottomley@HansenPartnership.com>2008-02-19 17:49:27 +0100
commit2b28a4721e068ac89bd5435472723a1bc44442fe (patch)
tree3d84bdc38c41557fdd70f6283a7e4a60d038e6f7
parent[SCSI] gdth: don't call pci_free_consistent under spinlock (diff)
downloadlinux-2b28a4721e068ac89bd5435472723a1bc44442fe.tar.xz
linux-2b28a4721e068ac89bd5435472723a1bc44442fe.zip
[SCSI] ips: fix data buffer accessors conversion bug
This fixes a bug that can't handle a passthru command with more than two sg entries. Big thanks to Tim Pepper for debugging the problem. Signed-off-by: FUJITA Tomonori <fujita.tomonori@lab.ntt.co.jp> Acked-by: Mark Salyzyn <Mark_Salyzyn@adaptec.com> Cc: Stable Tree <stable@kernel.org> Signed-off-by: James Bottomley <James.Bottomley@HansenPartnership.com>
-rw-r--r--drivers/scsi/ips.c2
1 files changed, 1 insertions, 1 deletions
diff --git a/drivers/scsi/ips.c b/drivers/scsi/ips.c
index bb152fb9fec7..7ed568f180ae 100644
--- a/drivers/scsi/ips.c
+++ b/drivers/scsi/ips.c
@@ -1576,7 +1576,7 @@ ips_make_passthru(ips_ha_t *ha, struct scsi_cmnd *SC, ips_scb_t *scb, int intr)
METHOD_TRACE("ips_make_passthru", 1);
scsi_for_each_sg(SC, sg, scsi_sg_count(SC), i)
- length += sg[i].length;
+ length += sg->length;
if (length < sizeof (ips_passthru_t)) {
/* wrong size */