Commit 61afafe8 authored by Miaoqian Lin's avatar Miaoqian Lin Committed by Mathieu Poirier

remoteproc: imx_rproc: Fix refcount leak in imx_rproc_addr_init

of_parse_phandle() returns a node pointer with refcount
incremented, we should use of_node_put() on it when not needed anymore.
This function has two paths missing of_node_put().

Fixes: 6e962bfe ("remoteproc: imx_rproc: add missing of_node_put")
Fixes: a0ff4aa6 ("remoteproc: imx_rproc: add a NXP/Freescale imx_rproc driver")
Signed-off-by: default avatarMiaoqian Lin <linmq006@gmail.com>
Link: https://lore.kernel.org/r/20220512045558.7142-1-linmq006@gmail.comSigned-off-by: default avatarMathieu Poirier <mathieu.poirier@linaro.org>
parent 2d1ea19f
...@@ -594,16 +594,17 @@ static int imx_rproc_addr_init(struct imx_rproc *priv, ...@@ -594,16 +594,17 @@ static int imx_rproc_addr_init(struct imx_rproc *priv,
node = of_parse_phandle(np, "memory-region", a); node = of_parse_phandle(np, "memory-region", a);
/* Not map vdevbuffer, vdevring region */ /* Not map vdevbuffer, vdevring region */
if (!strncmp(node->name, "vdev", strlen("vdev"))) if (!strncmp(node->name, "vdev", strlen("vdev"))) {
of_node_put(node);
continue; continue;
}
err = of_address_to_resource(node, 0, &res); err = of_address_to_resource(node, 0, &res);
of_node_put(node);
if (err) { if (err) {
dev_err(dev, "unable to resolve memory region\n"); dev_err(dev, "unable to resolve memory region\n");
return err; return err;
} }
of_node_put(node);
if (b >= IMX_RPROC_MEM_MAX) if (b >= IMX_RPROC_MEM_MAX)
break; break;
......
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