diff options
author | Zeng Heng <zengheng4@huawei.com> | 2024-04-15 18:53:28 +0800 |
---|---|---|
committer | Linus Walleij <linus.walleij@linaro.org> | 2024-04-16 15:32:48 +0200 |
commit | a0cedbcc8852d6c77b00634b81e41f17f29d9404 (patch) | |
tree | c9d9f08034685bb809c28f743bab86fb363c3067 /drivers/pinctrl | |
parent | c5d3b64c568a344e998830e0e94a7c04e372f89b (diff) | |
download | linux-a0cedbcc8852d6c77b00634b81e41f17f29d9404.tar.gz linux-a0cedbcc8852d6c77b00634b81e41f17f29d9404.tar.bz2 linux-a0cedbcc8852d6c77b00634b81e41f17f29d9404.zip |
pinctrl: devicetree: fix refcount leak in pinctrl_dt_to_map()
If we fail to allocate propname buffer, we need to drop the reference
count we just took. Because the pinctrl_dt_free_maps() includes the
droping operation, here we call it directly.
Fixes: 91d5c5060ee2 ("pinctrl: devicetree: fix null pointer dereferencing in pinctrl_dt_to_map")
Suggested-by: Dan Carpenter <dan.carpenter@linaro.org>
Signed-off-by: Zeng Heng <zengheng4@huawei.com>
Reviewed-by: Dan Carpenter <dan.carpenter@linaro.org>
Message-ID: <20240415105328.3651441-1-zengheng4@huawei.com>
Signed-off-by: Linus Walleij <linus.walleij@linaro.org>
Diffstat (limited to 'drivers/pinctrl')
-rw-r--r-- | drivers/pinctrl/devicetree.c | 10 |
1 files changed, 6 insertions, 4 deletions
diff --git a/drivers/pinctrl/devicetree.c b/drivers/pinctrl/devicetree.c index df1efc2e5202..6a94ecd6a8de 100644 --- a/drivers/pinctrl/devicetree.c +++ b/drivers/pinctrl/devicetree.c @@ -220,14 +220,16 @@ int pinctrl_dt_to_map(struct pinctrl *p, struct pinctrl_dev *pctldev) for (state = 0; ; state++) { /* Retrieve the pinctrl-* property */ propname = kasprintf(GFP_KERNEL, "pinctrl-%d", state); - if (!propname) - return -ENOMEM; + if (!propname) { + ret = -ENOMEM; + goto err; + } prop = of_find_property(np, propname, &size); kfree(propname); if (!prop) { if (state == 0) { - of_node_put(np); - return -ENODEV; + ret = -ENODEV; + goto err; } break; } |