Commit 15f70e1b authored by John Crispin's avatar John Crispin Committed by Linus Walleij

pinctrl: fix signed vs unsigned conditionals inside pinmux_map_to_setting

pinmux_map_to_setting() uses setting->data.mux.func/group to store the return
code of pinmux_func_name_to_selector/pinctrl_get_group_selector(). However,
struct pinctrl_setting_mux defines these elements as unsigned, resulting in all
error codes getting lost. The conditionals following the assignments will always
evaluate to false thus breaking the error paths.

This bug can be triggered by loading a pinmux group map from the devicetree
with an invalid function/group string.
Signed-off-by: default avatarJohn Crispin <blogic@openwrt.org>
Acked-by: default avatarStephen Warren <swarren@wwwdotorg.org>
Acked-by: default avatarDong Aisheng <dong.aisheng@linaro.org>
Signed-off-by: default avatarLinus Walleij <linus.walleij@linaro.org>
parent dcb5dbc3
...@@ -329,10 +329,10 @@ int pinmux_map_to_setting(struct pinctrl_map const *map, ...@@ -329,10 +329,10 @@ int pinmux_map_to_setting(struct pinctrl_map const *map,
return -EINVAL; return -EINVAL;
} }
setting->data.mux.func = ret = pinmux_func_name_to_selector(pctldev, map->data.mux.function);
pinmux_func_name_to_selector(pctldev, map->data.mux.function); if (ret < 0)
if (setting->data.mux.func < 0) return ret;
return setting->data.mux.func; setting->data.mux.func = ret;
ret = pmxops->get_function_groups(pctldev, setting->data.mux.func, ret = pmxops->get_function_groups(pctldev, setting->data.mux.func,
&groups, &num_groups); &groups, &num_groups);
...@@ -356,9 +356,10 @@ int pinmux_map_to_setting(struct pinctrl_map const *map, ...@@ -356,9 +356,10 @@ int pinmux_map_to_setting(struct pinctrl_map const *map,
group = groups[0]; group = groups[0];
} }
setting->data.mux.group = pinctrl_get_group_selector(pctldev, group); ret = pinctrl_get_group_selector(pctldev, group);
if (setting->data.mux.group < 0) if (ret < 0)
return setting->data.mux.group; return ret;
setting->data.mux.group = ret;
ret = pctlops->get_group_pins(pctldev, setting->data.mux.group, &pins, ret = pctlops->get_group_pins(pctldev, setting->data.mux.group, &pins,
&num_pins); &num_pins);
......
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