forked from Minki/linux
power: supply: ab8500: Avoid NULL pointers
Sometimes the code will crash because we haven't enabled AC or USB charging and thus not created the corresponding psy device. Fix it by checking that it is there before notifying. Signed-off-by: Linus Walleij <linus.walleij@linaro.org> Signed-off-by: Sebastian Reichel <sebastian.reichel@collabora.com>
This commit is contained in:
parent
7e2bb83c61
commit
5bcb5087c9
@ -415,6 +415,14 @@ disable_otp:
|
||||
static void ab8500_power_supply_changed(struct ab8500_charger *di,
|
||||
struct power_supply *psy)
|
||||
{
|
||||
/*
|
||||
* This happens if we get notifications or interrupts and
|
||||
* the platform has been configured not to support one or
|
||||
* other type of charging.
|
||||
*/
|
||||
if (!psy)
|
||||
return;
|
||||
|
||||
if (di->autopower_cfg) {
|
||||
if (!di->usb.charger_connected &&
|
||||
!di->ac.charger_connected &&
|
||||
@ -441,7 +449,15 @@ static void ab8500_charger_set_usb_connected(struct ab8500_charger *di,
|
||||
if (!connected)
|
||||
di->flags.vbus_drop_end = false;
|
||||
|
||||
sysfs_notify(&di->usb_chg.psy->dev.kobj, NULL, "present");
|
||||
/*
|
||||
* Sometimes the platform is configured not to support
|
||||
* USB charging and no psy has been created, but we still
|
||||
* will get these notifications.
|
||||
*/
|
||||
if (di->usb_chg.psy) {
|
||||
sysfs_notify(&di->usb_chg.psy->dev.kobj, NULL,
|
||||
"present");
|
||||
}
|
||||
|
||||
if (connected) {
|
||||
mutex_lock(&di->charger_attached_mutex);
|
||||
|
Loading…
Reference in New Issue
Block a user