summaryrefslogtreecommitdiffstats
path: root/drivers/thermal/cpuidle_cooling.c
diff options
context:
space:
mode:
authorDaniel Lezcano <daniel.lezcano@linaro.org>2021-03-19 21:25:22 +0100
committerDaniel Lezcano <daniel.lezcano@linaro.org>2021-04-15 13:21:26 +0200
commit6cc7b38c0ca3187abd07af849ec179b42337bcf6 (patch)
tree4bbf662d300f5e73549426095013affc538bdf78 /drivers/thermal/cpuidle_cooling.c
parent9aa80ab2c0ba67ce3281aee604b543293f71390d (diff)
downloadlinux-6cc7b38c0ca3187abd07af849ec179b42337bcf6.tar.gz
linux-6cc7b38c0ca3187abd07af849ec179b42337bcf6.tar.bz2
linux-6cc7b38c0ca3187abd07af849ec179b42337bcf6.zip
thermal/drivers/cpuidle_cooling: Fix use after error
When the function successfully finishes it logs an information about the registration of the cooling device and use its name to build the message. Unfortunately it was freed right before: drivers/thermal/cpuidle_cooling.c:218 __cpuidle_cooling_register() warn: 'name' was already freed. Fix this by freeing after the message happened. Fixes: 6fd1b186d900 ("thermal/drivers/cpuidle_cooling: Use device name instead of auto-numbering") Reported-by: Dan Carpenter <dan.carpenter@oracle.com> Signed-off-by: Daniel Lezcano <daniel.lezcano@linaro.org> Acked-by: Viresh Kumar <viresh.kumar@linaro.org> Link: https://lore.kernel.org/r/20210319202522.891061-1-daniel.lezcano@linaro.org
Diffstat (limited to 'drivers/thermal/cpuidle_cooling.c')
-rw-r--r--drivers/thermal/cpuidle_cooling.c8
1 files changed, 5 insertions, 3 deletions
diff --git a/drivers/thermal/cpuidle_cooling.c b/drivers/thermal/cpuidle_cooling.c
index f32976163bad..4f41102e8b16 100644
--- a/drivers/thermal/cpuidle_cooling.c
+++ b/drivers/thermal/cpuidle_cooling.c
@@ -208,18 +208,20 @@ static int __cpuidle_cooling_register(struct device_node *np,
cdev = thermal_of_cooling_device_register(np, name, idle_cdev,
&cpuidle_cooling_ops);
- kfree(name);
-
if (IS_ERR(cdev)) {
ret = PTR_ERR(cdev);
- goto out_unregister;
+ goto out_kfree_name;
}
pr_debug("%s: Idle injection set with idle duration=%u, latency=%u\n",
name, idle_duration_us, latency_us);
+ kfree(name);
+
return 0;
+out_kfree_name:
+ kfree(name);
out_unregister:
idle_inject_unregister(ii_dev);
out_kfree: