summaryrefslogtreecommitdiffstats
path: root/drivers/scsi/sd.c
diff options
context:
space:
mode:
authorMartin K. Petersen <martin.petersen@oracle.com>2012-08-28 20:29:33 +0200
committerJames Bottomley <JBottomley@Parallels.com>2012-09-24 10:10:59 +0200
commit8c579ab69d50a416887390ba4b89598a7b2fa0b6 (patch)
tree11a552e7ebcc13c1a15ca764da04bece358d26a1 /drivers/scsi/sd.c
parent[SCSI] mpt2sas: fix double mutex lock in NON_BLOCKING state (diff)
downloadlinux-8c579ab69d50a416887390ba4b89598a7b2fa0b6.tar.xz
linux-8c579ab69d50a416887390ba4b89598a7b2fa0b6.zip
[SCSI] sd: Avoid remapping bad reference tags
It does not make sense to translate ref tags with unexpected values. Instead we simply ignore them and let the upper layers catch the problem. Ref tags that contain the expected value are still remapped. Signed-off-by: Martin K. Petersen <martin.petersen@oracle.com> Signed-off-by: James Bottomley <JBottomley@Parallels.com>
Diffstat (limited to 'drivers/scsi/sd.c')
-rw-r--r--drivers/scsi/sd.c5
1 files changed, 2 insertions, 3 deletions
diff --git a/drivers/scsi/sd.c b/drivers/scsi/sd.c
index 4df73e52a4f9..9f7fc39891b8 100644
--- a/drivers/scsi/sd.c
+++ b/drivers/scsi/sd.c
@@ -804,9 +804,8 @@ static int sd_prep_fn(struct request_queue *q, struct request *rq)
SCpnt->cmnd[0] = WRITE_6;
SCpnt->sc_data_direction = DMA_TO_DEVICE;
- if (blk_integrity_rq(rq) &&
- sd_dif_prepare(rq, block, sdp->sector_size) == -EIO)
- goto out;
+ if (blk_integrity_rq(rq))
+ sd_dif_prepare(rq, block, sdp->sector_size);
} else if (rq_data_dir(rq) == READ) {
SCpnt->cmnd[0] = READ_6;