diff options
author | Viresh Kumar <viresh.kumar@linaro.org> | 2014-09-04 14:01:23 +0200 |
---|---|---|
committer | Sebastian Reichel <sre@kernel.org> | 2014-09-16 11:01:27 +0200 |
commit | f9c85486c4ae8fd56770340bd9c16a61127c96e1 (patch) | |
tree | afd50e87aa06851ed681f8adc498c52796b65cda | |
parent | power-supply: Don't over-allocate memory for "supplied-from" array (diff) | |
download | linux-f9c85486c4ae8fd56770340bd9c16a61127c96e1.tar.xz linux-f9c85486c4ae8fd56770340bd9c16a61127c96e1.zip |
power-supply: Return early if "power-supplies" property isn't valid
If power-supply's DT node doesn't have a valid "power-supplies" entry, then
power_supply_check_supplies() should return early instead of trying to allocate
memory for "supplied_from" array.
Signed-off-by: Viresh Kumar <viresh.kumar@linaro.org>
Signed-off-by: Sebastian Reichel <sre@kernel.org>
-rw-r--r-- | drivers/power/power_supply_core.c | 4 |
1 files changed, 4 insertions, 0 deletions
diff --git a/drivers/power/power_supply_core.c b/drivers/power/power_supply_core.c index 10f0b57f00d9..414384a4ab52 100644 --- a/drivers/power/power_supply_core.c +++ b/drivers/power/power_supply_core.c @@ -226,6 +226,10 @@ static int power_supply_check_supplies(struct power_supply *psy) of_node_put(np); } while (np); + /* Missing valid "power-supplies" entries */ + if (cnt == 1) + return 0; + /* All supplies found, allocate char ** array for filling */ psy->supplied_from = devm_kzalloc(psy->dev, sizeof(psy->supplied_from), GFP_KERNEL); |