Commit 7cb69d03 authored by Akinobu Mita's avatar Akinobu Mita Committed by James Bottomley

[SCSI] scsi_debug: fix NULL pointer dereference with parameters dif=0 dix=1

The protection info dif_storep is allocated only when parameter dif is
not zero.  But it will be accessed when reading or writing to the storage
installed with parameter dix is not zero.

So kernel crashes if scsi_debug module is loaded with parameters dix=1 and
dif=0.

This fixes it by making dif_storep available if parameter dix is not zero
instead of checking if parameter dif is not zero.
Signed-off-by: default avatarAkinobu Mita <akinobu.mita@gmail.com>
Acked-by: default avatarDouglas Gilbert <dgilbert@interlog.com>
Acked-by: default avatar"Martin K. Petersen" <martin.petersen@oracle.com>
Signed-off-by: default avatarJames Bottomley <JBottomley@Parallels.com>
parent fc3fc352
...@@ -3372,7 +3372,7 @@ static int __init scsi_debug_init(void) ...@@ -3372,7 +3372,7 @@ static int __init scsi_debug_init(void)
if (scsi_debug_num_parts > 0) if (scsi_debug_num_parts > 0)
sdebug_build_parts(fake_storep, sz); sdebug_build_parts(fake_storep, sz);
if (scsi_debug_dif) { if (scsi_debug_dix) {
int dif_size; int dif_size;
dif_size = sdebug_store_sectors * sizeof(struct sd_dif_tuple); dif_size = sdebug_store_sectors * sizeof(struct sd_dif_tuple);
......
Markdown is supported
0%
or
You are about to add 0 people to the discussion. Proceed with caution.
Finish editing this message first!
Please register or to comment