summaryrefslogtreecommitdiffstats
path: root/drivers/scsi
diff options
context:
space:
mode:
authorAkinobu Mita <akinobu.mita@gmail.com>2013-06-29 17:59:17 +0900
committerJames Bottomley <JBottomley@Parallels.com>2013-07-09 09:24:25 +0100
commite9926b4376544d5a2dc4d310d4d0006c634b1a93 (patch)
tree2d1fbe3341b66fe39e57c49d5c562cadaddc3f4c /drivers/scsi
parent7cb69d0397233546d82191e524235fdb9d1d91aa (diff)
downloadlinux-e9926b4376544d5a2dc4d310d4d0006c634b1a93.tar.gz
linux-e9926b4376544d5a2dc4d310d4d0006c634b1a93.tar.bz2
linux-e9926b4376544d5a2dc4d310d4d0006c634b1a93.zip
[SCSI] scsi_debug: invalidate protection info for unmapped region
When UNMAP command is issued with the data integrity support enabled, the protection info for the unmapped region is remain unchanged. So READ command for the region later on causes data integrity failure. This fixes it by invalidating protection info for the unmapped region by filling with 0xff pattern. Signed-off-by: Akinobu Mita <akinobu.mita@gmail.com> Acked-by: Douglas Gilbert <dgilbert@interlog.com> Acked-by: "Martin K. Petersen" <martin.petersen@oracle.com> Signed-off-by: James Bottomley <JBottomley@Parallels.com>
Diffstat (limited to 'drivers/scsi')
-rw-r--r--drivers/scsi/scsi_debug.c5
1 files changed, 5 insertions, 0 deletions
diff --git a/drivers/scsi/scsi_debug.c b/drivers/scsi/scsi_debug.c
index e83e661b0257..83efec2919b1 100644
--- a/drivers/scsi/scsi_debug.c
+++ b/drivers/scsi/scsi_debug.c
@@ -2064,6 +2064,11 @@ static void unmap_region(sector_t lba, unsigned int len)
scsi_debug_sector_size *
scsi_debug_unmap_granularity);
}
+ if (dif_storep) {
+ memset(dif_storep + lba, 0xff,
+ sizeof(*dif_storep) *
+ scsi_debug_unmap_granularity);
+ }
}
lba = map_index_to_lba(index + 1);
}