[SCSI] storvsc: NULL pointer dereference fix

If the initialization of storvsc fails, the storvsc_device_destroy()
causes NULL pointer dereference.

storvsc_bus_scan()
scsi_scan_target()
__scsi_scan_target()
scsi_probe_and_add_lun(hostdata=NULL)
scsi_alloc_sdev(hostdata=NULL)

sdev->hostdata = hostdata

now the host allocation fails

__scsi_remove_device(sdev)

calls sdev->host->hostt->slave_destroy() ==
storvsc_device_destroy(sdev)
access of sdev->hostdata->request_mempool

Signed-off-by: Ales Novak <alnovak@suse.cz>
Signed-off-by: Thomas Abraham <tabraham@suse.com>
Reviewed-by: Jiri Kosina <jkosina@suse.cz>
Acked-by: K. Y. Srinivasan <kys@microsoft.com>
Cc: stable@vger.kernel.org
Signed-off-by: James Bottomley <JBottomley@Parallels.com>

authored by

Ales Novak and committed by
James Bottomley
b12bb60d b77ed25c

+3
+3
drivers/scsi/storvsc_drv.c
··· 1419 { 1420 struct stor_mem_pools *memp = sdevice->hostdata; 1421 1422 mempool_destroy(memp->request_mempool); 1423 kmem_cache_destroy(memp->request_pool); 1424 kfree(memp);
··· 1419 { 1420 struct stor_mem_pools *memp = sdevice->hostdata; 1421 1422 + if (!memp) 1423 + return; 1424 + 1425 mempool_destroy(memp->request_mempool); 1426 kmem_cache_destroy(memp->request_pool); 1427 kfree(memp);