Commit c2f6d059 authored by Linus Walleij's avatar Linus Walleij

pinctrl: nomadik: refactor DT parser to take two paths

We refactor the DT parser to look for either a config or a
function and then look for further nodes and reserve maps,
not the two things mixed up like prior to this patch.
Signed-off-by: default avatarLinus Walleij <linus.walleij@linaro.org>
parent 6e9b1c35
...@@ -1505,51 +1505,55 @@ static int nmk_pinctrl_dt_subnode_to_map(struct pinctrl_dev *pctldev, ...@@ -1505,51 +1505,55 @@ static int nmk_pinctrl_dt_subnode_to_map(struct pinctrl_dev *pctldev,
const char *function = NULL; const char *function = NULL;
unsigned long configs = 0; unsigned long configs = 0;
bool has_config = 0; bool has_config = 0;
unsigned reserve = 0;
struct property *prop; struct property *prop;
const char *group, *gpio_name; const char *group, *gpio_name;
struct device_node *np_config; struct device_node *np_config;
ret = of_property_read_string(np, "ste,function", &function); ret = of_property_read_string(np, "ste,function", &function);
if (ret >= 0) if (ret >= 0) {
reserve = 1; ret = of_property_count_strings(np, "ste,pins");
if (ret < 0)
has_config = nmk_pinctrl_dt_get_config(np, &configs); goto exit;
np_config = of_parse_phandle(np, "ste,config", 0); ret = pinctrl_utils_reserve_map(pctldev, map,
if (np_config) reserved_maps,
has_config |= nmk_pinctrl_dt_get_config(np_config, &configs); num_maps, ret);
if (ret < 0)
ret = of_property_count_strings(np, "ste,pins"); goto exit;
if (ret < 0)
goto exit; of_property_for_each_string(np, "ste,pins", prop, group) {
if (has_config)
reserve++;
reserve *= ret;
ret = pinctrl_utils_reserve_map(pctldev, map, reserved_maps, num_maps, reserve);
if (ret < 0)
goto exit;
of_property_for_each_string(np, "ste,pins", prop, group) {
if (function) {
ret = nmk_dt_add_map_mux(map, reserved_maps, num_maps, ret = nmk_dt_add_map_mux(map, reserved_maps, num_maps,
group, function); group, function);
if (ret < 0) if (ret < 0)
goto exit; goto exit;
} }
if (has_config) { }
has_config = nmk_pinctrl_dt_get_config(np, &configs);
np_config = of_parse_phandle(np, "ste,config", 0);
if (np_config)
has_config |= nmk_pinctrl_dt_get_config(np_config, &configs);
if (has_config) {
ret = of_property_count_strings(np, "ste,pins");
if (ret < 0)
goto exit;
ret = pinctrl_utils_reserve_map(pctldev, map,
reserved_maps,
num_maps, ret);
if (ret < 0)
goto exit;
of_property_for_each_string(np, "ste,pins", prop, group) {
gpio_name = nmk_find_pin_name(pctldev, group); gpio_name = nmk_find_pin_name(pctldev, group);
ret = nmk_dt_add_map_configs(map, reserved_maps, num_maps, ret = nmk_dt_add_map_configs(map, reserved_maps,
gpio_name, &configs, 1); num_maps,
gpio_name, &configs, 1);
if (ret < 0) if (ret < 0)
goto exit; goto exit;
} }
} }
exit: exit:
return ret; return ret;
} }
......
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