HID: input: Fix NULL pointer dereference when power_supply_register fails
authorKrzysztof Kozlowski <k.kozlowski@samsung.com>
Mon, 23 Mar 2015 15:34:51 +0000 (16:34 +0100)
committerSebastian Reichel <sre@kernel.org>
Tue, 24 Mar 2015 12:38:16 +0000 (13:38 +0100)
Do not call power_supply_powers() if power_supply_register() failed
earlier. This fixes possible NULL pointer dereference by
power_supply_powers() in such case.

Signed-off-by: Krzysztof Kozlowski <k.kozlowski@samsung.com>
Reported-by: Dan Carpenter <dan.carpenter@oracle.com>
Acked-by: Jiri Kosina <jkosina@suse.cz>
Signed-off-by: Sebastian Reichel <sre@kernel.org>
drivers/hid/hid-input.c

index 5d5a8c42645f77adb2191b9c44787ec1a10e7ff2..32c2da49bd5b3f270714e191ac47eaeaef9d3ddf 100644 (file)
@@ -452,10 +452,10 @@ static bool hidinput_setup_battery(struct hid_device *dev, unsigned report_type,
                kfree(psy_desc->name);
                kfree(psy_desc);
                dev->battery = NULL;
+       } else {
+               power_supply_powers(dev->battery, &dev->dev);
        }
 
-       power_supply_powers(dev->battery, &dev->dev);
-
 out:
        return true;
 }