diff options
author | Akinobu Mita <akinobu.mita@gmail.com> | 2013-06-29 10:59:17 +0200 |
---|---|---|
committer | James Bottomley <JBottomley@Parallels.com> | 2013-07-09 10:24:25 +0200 |
commit | e9926b4376544d5a2dc4d310d4d0006c634b1a93 (patch) | |
tree | 2d1fbe3341b66fe39e57c49d5c562cadaddc3f4c | |
parent | [SCSI] scsi_debug: fix NULL pointer dereference with parameters dif=0 dix=1 (diff) | |
download | linux-e9926b4376544d5a2dc4d310d4d0006c634b1a93.tar.xz 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>
-rw-r--r-- | drivers/scsi/scsi_debug.c | 5 |
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); } |