power: supply: isp1704: Fix unchecked return value of devm_kzalloc
authorPan Bian <bianpan2016@163.com>
Mon, 24 Apr 2017 08:22:08 +0000 (16:22 +0800)
committerSebastian Reichel <sre@kernel.org>
Mon, 1 May 2017 09:52:25 +0000 (11:52 +0200)
Function devm_kzalloc() will return a NULL pointer. However, in function
isp1704_charger_probe(), the return value of devm_kzalloc() is directly
used without validation. This may result in a bad memory access bug.

Fixes: 34a109610e2a ("isp1704_charger: Add DT support")
Signed-off-by: Pan Bian <bianpan2016@163.com>
Reviewed-by: Pali Rohár <pali.rohar@gmail.com>
Signed-off-by: Sebastian Reichel <sebastian.reichel@collabora.co.uk>
drivers/power/supply/isp1704_charger.c

index 4cd6899..95af5f3 100644 (file)
@@ -418,6 +418,10 @@ static int isp1704_charger_probe(struct platform_device *pdev)
 
                pdata = devm_kzalloc(&pdev->dev,
                        sizeof(struct isp1704_charger_data), GFP_KERNEL);
+               if (!pdata) {
+                       ret = -ENOMEM;
+                       goto fail0;
+               }
                pdata->enable_gpio = gpio;
 
                dev_info(&pdev->dev, "init gpio %d\n", pdata->enable_gpio);