[PATCH] pinctrl: pinconf-generic: fix of_node reference count leak in dt_node_to_map_pinmux

Wentao Liang posted 1 patch 1 day, 10 hours ago
drivers/pinctrl/pinconf-generic.c | 2 ++
1 file changed, 2 insertions(+)
[PATCH] pinctrl: pinconf-generic: fix of_node reference count leak in dt_node_to_map_pinmux
Posted by Wentao Liang 1 day, 10 hours ago
of_get_parent() acquires a reference on pnode, but the reference is never
released on any return path.  Add of_node_put(pnode) in the exit label and
before the early return path.

Cc: stable@vger.kernel.org
Fixes: 7112c05fff83 ("pinctrl: pinconf-generic: Add API for pinmux propertity in DTS file")
Signed-off-by: Wentao Liang <vulab@iscas.ac.cn>
---
 drivers/pinctrl/pinconf-generic.c | 2 ++
 1 file changed, 2 insertions(+)

diff --git a/drivers/pinctrl/pinconf-generic.c b/drivers/pinctrl/pinconf-generic.c
index d67838afb085..a5016f522889 100644
--- a/drivers/pinctrl/pinconf-generic.c
+++ b/drivers/pinctrl/pinconf-generic.c
@@ -390,6 +390,7 @@ int pinconf_generic_dt_node_to_map_pinmux(struct pinctrl_dev *pctldev,
 					      &num_configs);
 	if (ret < 0) {
 		dev_err(dev, "%pOF: could not parse node property\n", np);
+		of_node_put(pnode);
 		return ret;
 	}
 
@@ -420,6 +421,7 @@ int pinconf_generic_dt_node_to_map_pinmux(struct pinctrl_dev *pctldev,
 	kfree(configs);
 	if (ret)
 		pinctrl_utils_free_map(pctldev, *map, *num_maps);
+	of_node_put(pnode);
 
 	return ret;
 }
-- 
2.34.1
Re: [PATCH] pinctrl: pinconf-generic: fix of_node reference count leak in dt_node_to_map_pinmux
Posted by Markus Elfring 1 day, 8 hours ago
> of_get_parent() acquires a reference on pnode, but the reference is never
> released on any return path.  Add of_node_put(pnode) in the exit label and

                                                       call?


> before the early return path.

Please avoid a bit of duplicate source code in the mentioned function implementation.

How do you think about to reconsider involved identifiers once more?
https://elixir.bootlin.com/linux/v7.1-rc4/source/drivers/pinctrl/pinconf-generic.c

Regards,
Markus