Commit e6e09514 authored by Miaoqian Lin's avatar Miaoqian Lin Committed by Bjorn Andersson

soc: qcom: aoss: Fix refcount leak in qmp_cooling_devices_register

Every iteration of for_each_available_child_of_node() decrements
the reference count of the previous node.
When breaking early from a for_each_available_child_of_node() loop,
we need to explicitly call of_node_put() on the child node.
Add missing of_node_put() to avoid refcount leak.

Fixes: 05589b30 ("soc: qcom: Extend AOSS QMP driver to support resources that are used to wake up the SoC.")
Signed-off-by: default avatarMiaoqian Lin <linmq006@gmail.com>
Signed-off-by: default avatarBjorn Andersson <bjorn.andersson@linaro.org>
Link: https://lore.kernel.org/r/20220606064252.42595-1-linmq006@gmail.com
parent a3e7259f
...@@ -399,8 +399,10 @@ static int qmp_cooling_devices_register(struct qmp *qmp) ...@@ -399,8 +399,10 @@ static int qmp_cooling_devices_register(struct qmp *qmp)
continue; continue;
ret = qmp_cooling_device_add(qmp, &qmp->cooling_devs[count++], ret = qmp_cooling_device_add(qmp, &qmp->cooling_devs[count++],
child); child);
if (ret) if (ret) {
of_node_put(child);
goto unroll; goto unroll;
}
} }
if (!count) if (!count)
......
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