pinctrl: pinconf-generic: add missing of_node_put()
authorZhangPeng <zhangpeng362@huawei.com>
Fri, 25 Nov 2022 07:01:56 +0000 (07:01 +0000)
committerLinus Walleij <linus.walleij@linaro.org>
Fri, 25 Nov 2022 09:49:28 +0000 (10:49 +0100)
of_node_put() needs to be called when jumping out of the loop, since
for_each_available_child_of_node() will increase the refcount of node.

Fixes: c7289500e29d ("pinctrl: pinconf-generic: scan also referenced phandle node")
Signed-off-by: ZhangPeng <zhangpeng362@huawei.com>
Link: https://lore.kernel.org/r/20221125070156.3535855-1-zhangpeng362@huawei.com
Signed-off-by: Linus Walleij <linus.walleij@linaro.org>
drivers/pinctrl/pinconf-generic.c

index 415d1df8f46a5c01d6b585ca30aaea97b463b36d..365c4b0ca465489208963341cc47d8baf0ade302 100644 (file)
@@ -395,8 +395,10 @@ int pinconf_generic_dt_node_to_map(struct pinctrl_dev *pctldev,
        for_each_available_child_of_node(np_config, np) {
                ret = pinconf_generic_dt_subnode_to_map(pctldev, np, map,
                                        &reserved_maps, num_maps, type);
-               if (ret < 0)
+               if (ret < 0) {
+                       of_node_put(np);
                        goto exit;
+               }
        }
        return 0;