summaryrefslogtreecommitdiff
path: root/drivers
diff options
context:
space:
mode:
authorJörn Engel <joern@logfs.org>2012-02-15 16:52:11 -0500
committerGreg Kroah-Hartman <gregkh@linuxfoundation.org>2012-04-02 09:52:48 -0700
commitb794073eb1f5574b35c5de89ce81f108742a9879 (patch)
tree03153b7aff97a8810ca9334d88c34731aad95c72 /drivers
parentf18009c7acc4efa72c6bb36f8be1db8b08582dd9 (diff)
target: prevent NULL pointer dereference in target_report_luns
commit 47f1b8803e1e358ebbf4f82bfdb98971c912a2c3 upstream. transport_kmap_data_sg can return NULL. I never saw this trigger, but returning -ENOMEM seems better than a crash. Also removes a pointless case while at it. Signed-off-by: Joern Engel <joern@logfs.org> Signed-off-by: Nicholas Bellinger <nab@linux-iscsi.org> Signed-off-by: Greg Kroah-Hartman <gregkh@linuxfoundation.org>
Diffstat (limited to 'drivers')
-rw-r--r--drivers/target/target_core_device.c4
1 files changed, 3 insertions, 1 deletions
diff --git a/drivers/target/target_core_device.c b/drivers/target/target_core_device.c
index 097178b83b3a..f8773aec5965 100644
--- a/drivers/target/target_core_device.c
+++ b/drivers/target/target_core_device.c
@@ -658,7 +658,9 @@ int target_report_luns(struct se_task *se_task)
unsigned char *buf;
u32 cdb_offset = 0, lun_count = 0, offset = 8, i;
- buf = (unsigned char *) transport_kmap_data_sg(se_cmd);
+ buf = transport_kmap_data_sg(se_cmd);
+ if (!buf)
+ return -ENOMEM;
/*
* If no struct se_session pointer is present, this struct se_cmd is