Commit c61c2d70 authored by Thierry Reding's avatar Thierry Reding Committed by Linus Walleij

pinctrl: tegra-xusb: Don't leak configurations

The pinctrl config helpers make a separate copy of the configuration, so
callers must make sure to free any dynamically allocated memory that was
used to store it.
Signed-off-by: default avatarThierry Reding <treding@nvidia.com>
Signed-off-by: default avatarLinus Walleij <linus.walleij@linaro.org>
parent 9067bbe5
...@@ -20,6 +20,7 @@ ...@@ -20,6 +20,7 @@
#include <linux/pinctrl/pinmux.h> #include <linux/pinctrl/pinmux.h>
#include <linux/platform_device.h> #include <linux/platform_device.h>
#include <linux/reset.h> #include <linux/reset.h>
#include <linux/slab.h>
#include <dt-bindings/pinctrl/pinctrl-tegra-xusb.h> #include <dt-bindings/pinctrl/pinctrl-tegra-xusb.h>
...@@ -171,7 +172,7 @@ static int tegra_xusb_padctl_parse_subnode(struct tegra_xusb_padctl *padctl, ...@@ -171,7 +172,7 @@ static int tegra_xusb_padctl_parse_subnode(struct tegra_xusb_padctl *padctl,
if (err == -EINVAL) if (err == -EINVAL)
continue; continue;
return err; goto out;
} }
config = TEGRA_XUSB_PADCTL_PACK(properties[i].param, value); config = TEGRA_XUSB_PADCTL_PACK(properties[i].param, value);
...@@ -179,7 +180,7 @@ static int tegra_xusb_padctl_parse_subnode(struct tegra_xusb_padctl *padctl, ...@@ -179,7 +180,7 @@ static int tegra_xusb_padctl_parse_subnode(struct tegra_xusb_padctl *padctl,
err = pinctrl_utils_add_config(padctl->pinctrl, &configs, err = pinctrl_utils_add_config(padctl->pinctrl, &configs,
&num_configs, config); &num_configs, config);
if (err < 0) if (err < 0)
return err; goto out;
} }
if (function) if (function)
...@@ -190,14 +191,14 @@ static int tegra_xusb_padctl_parse_subnode(struct tegra_xusb_padctl *padctl, ...@@ -190,14 +191,14 @@ static int tegra_xusb_padctl_parse_subnode(struct tegra_xusb_padctl *padctl,
err = of_property_count_strings(np, "nvidia,lanes"); err = of_property_count_strings(np, "nvidia,lanes");
if (err < 0) if (err < 0)
return err; goto out;
reserve *= err; reserve *= err;
err = pinctrl_utils_reserve_map(padctl->pinctrl, maps, reserved_maps, err = pinctrl_utils_reserve_map(padctl->pinctrl, maps, reserved_maps,
num_maps, reserve); num_maps, reserve);
if (err < 0) if (err < 0)
return err; goto out;
of_property_for_each_string(np, "nvidia,lanes", prop, group) { of_property_for_each_string(np, "nvidia,lanes", prop, group) {
if (function) { if (function) {
...@@ -205,7 +206,7 @@ static int tegra_xusb_padctl_parse_subnode(struct tegra_xusb_padctl *padctl, ...@@ -205,7 +206,7 @@ static int tegra_xusb_padctl_parse_subnode(struct tegra_xusb_padctl *padctl,
reserved_maps, num_maps, group, reserved_maps, num_maps, group,
function); function);
if (err < 0) if (err < 0)
return err; goto out;
} }
if (num_configs) { if (num_configs) {
...@@ -214,11 +215,15 @@ static int tegra_xusb_padctl_parse_subnode(struct tegra_xusb_padctl *padctl, ...@@ -214,11 +215,15 @@ static int tegra_xusb_padctl_parse_subnode(struct tegra_xusb_padctl *padctl,
configs, num_configs, configs, num_configs,
PIN_MAP_TYPE_CONFIGS_GROUP); PIN_MAP_TYPE_CONFIGS_GROUP);
if (err < 0) if (err < 0)
return err; goto out;
} }
} }
return 0; err = 0;
out:
kfree(configs);
return err;
} }
static int tegra_xusb_padctl_dt_node_to_map(struct pinctrl_dev *pinctrl, static int tegra_xusb_padctl_dt_node_to_map(struct pinctrl_dev *pinctrl,
......
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