Skip to content

Commit

Permalink
thermal: cpu_cooling: do error handling at the bottom in __cpufreq_co…
Browse files Browse the repository at this point in the history
…oling_register()

This makes life easy and bug free. And is scalable for future resource
allocations.

Acked-by: Javi Merino <javi.merino@arm.com>
Signed-off-by: Viresh Kumar <viresh.kumar@linaro.org>
Signed-off-by: Eduardo Valentin <edubezval@gmail.com>
  • Loading branch information
Viresh Kumar authored and Eduardo Valentin committed Dec 8, 2014
1 parent c9ca319 commit 730abe0
Showing 1 changed file with 12 additions and 7 deletions.
19 changes: 12 additions & 7 deletions drivers/thermal/cpu_cooling.c
Original file line number Diff line number Diff line change
Expand Up @@ -448,20 +448,18 @@ __cpufreq_cooling_register(struct device_node *np,

ret = get_idr(&cpufreq_idr, &cpufreq_dev->id);
if (ret) {
kfree(cpufreq_dev);
return ERR_PTR(ret);
cool_dev = ERR_PTR(ret);
goto free_cdev;
}

snprintf(dev_name, sizeof(dev_name), "thermal-cpufreq-%d",
cpufreq_dev->id);

cool_dev = thermal_of_cooling_device_register(np, dev_name, cpufreq_dev,
&cpufreq_cooling_ops);
if (IS_ERR(cool_dev)) {
release_idr(&cpufreq_idr, cpufreq_dev->id);
kfree(cpufreq_dev);
return cool_dev;
}
if (IS_ERR(cool_dev))
goto remove_idr;

cpufreq_dev->cool_dev = cool_dev;

mutex_lock(&cooling_cpufreq_lock);
Expand All @@ -475,6 +473,13 @@ __cpufreq_cooling_register(struct device_node *np,

mutex_unlock(&cooling_cpufreq_lock);

return cool_dev;

remove_idr:
release_idr(&cpufreq_idr, cpufreq_dev->id);
free_cdev:
kfree(cpufreq_dev);

return cool_dev;
}

Expand Down

0 comments on commit 730abe0

Please sign in to comment.