Commit 9867999f authored by Sudeep Holla's avatar Sudeep Holla Committed by Rafael J. Wysocki

PM / OPP: add missing of_node_put() for of_get_cpu_node()

Commit 76279291 (PM / OPP: Fix get sharing CPUs when hotplug
is used) moved away from using cpu_dev->of_node because of some
limitations.

However, commit 7467c9d9 (of: return of_get_cpu_node from
of_cpu_device_node_get if CPUs are not registered) added support to
fall back to of_get_cpu_node() if called if CPUs are not registered
yet.

Add the missing of_node_put() for the CPU device nodes. Also go back
to using of_cpu_device_node_get() in dev_pm_opp_of_get_sharing_cpus()
to avoid scanning the device tree again.
Acked-by: default avatarViresh Kumar <vireshk@kernel.org>
Fixes: 76279291 (PM / OPP: Fix get sharing CPUs when hotplug is used)
Signed-off-by: default avatarSudeep Holla <sudeep.holla@arm.com>
Reviewed-by: default avatarStephen Boyd <sboyd@codeaurora.org>
Signed-off-by: default avatarRafael J. Wysocki <rafael.j.wysocki@intel.com>
parent 604a7aeb
...@@ -16,7 +16,7 @@ ...@@ -16,7 +16,7 @@
#include <linux/cpu.h> #include <linux/cpu.h>
#include <linux/errno.h> #include <linux/errno.h>
#include <linux/device.h> #include <linux/device.h>
#include <linux/of.h> #include <linux/of_device.h>
#include <linux/slab.h> #include <linux/slab.h>
#include <linux/export.h> #include <linux/export.h>
...@@ -604,7 +604,7 @@ int dev_pm_opp_of_get_sharing_cpus(struct device *cpu_dev, ...@@ -604,7 +604,7 @@ int dev_pm_opp_of_get_sharing_cpus(struct device *cpu_dev,
if (cpu == cpu_dev->id) if (cpu == cpu_dev->id)
continue; continue;
cpu_np = of_get_cpu_node(cpu, NULL); cpu_np = of_cpu_device_node_get(cpu);
if (!cpu_np) { if (!cpu_np) {
dev_err(cpu_dev, "%s: failed to get cpu%d node\n", dev_err(cpu_dev, "%s: failed to get cpu%d node\n",
__func__, cpu); __func__, cpu);
...@@ -614,6 +614,7 @@ int dev_pm_opp_of_get_sharing_cpus(struct device *cpu_dev, ...@@ -614,6 +614,7 @@ int dev_pm_opp_of_get_sharing_cpus(struct device *cpu_dev,
/* Get OPP descriptor node */ /* Get OPP descriptor node */
tmp_np = _opp_of_get_opp_desc_node(cpu_np); tmp_np = _opp_of_get_opp_desc_node(cpu_np);
of_node_put(cpu_np);
if (!tmp_np) { if (!tmp_np) {
pr_err("%pOF: Couldn't find opp node\n", cpu_np); pr_err("%pOF: Couldn't find opp node\n", cpu_np);
ret = -ENOENT; ret = -ENOENT;
......
Markdown is supported
0%
or
You are about to add 0 people to the discussion. Proceed with caution.
Finish editing this message first!
Please register or to comment