power: supply: core: fix memory leak in HWMON error path
authorQiushi Wu <wu000273@umn.edu>
Sat, 2 May 2020 23:33:38 +0000 (18:33 -0500)
committerSebastian Reichel <sre@kernel.org>
Sun, 3 May 2020 00:17:13 +0000 (02:17 +0200)
In function power_supply_add_hwmon_sysfs(), psyhw->props is
allocated by bitmap_zalloc(). But this pointer is not deallocated
when devm_add_action fail,  which lead to a memory leak bug. To fix
this, we replace devm_add_action with devm_add_action_or_reset.

Cc: stable@kernel.org
Fixes: e67d4dfc9ff19 ("power: supply: Add HWMON compatibility layer")
Signed-off-by: Qiushi Wu <wu000273@umn.edu>
Signed-off-by: Sebastian Reichel <sebastian.reichel@collabora.com>
drivers/power/supply/power_supply_hwmon.c

index f5d5384..7fe4b6b 100644 (file)
@@ -358,7 +358,7 @@ int power_supply_add_hwmon_sysfs(struct power_supply *psy)
                goto error;
        }
 
-       ret = devm_add_action(dev, power_supply_hwmon_bitmap_free,
+       ret = devm_add_action_or_reset(dev, power_supply_hwmon_bitmap_free,
                              psyhw->props);
        if (ret)
                goto error;