pinmux_map_to_settingi() uses setting->data.mux.func to store the return code of pinmux_func_name_to_selector(). However, struct pinctrl_setting_mux defines the func element as unsigned, resulting in all error codes getting lost. The conditional following the assignment will always evaluate to false thus breaking the error path.
This bug can be triggered by loading a pinmux group map from the devicetree with an invalid function string. Signed-off-by: John Crispin <[email protected]> Cc: Stephen Warren <[email protected]> Cc: Dong Aisheng <[email protected]> --- drivers/pinctrl/pinmux.c | 8 ++++---- 1 files changed, 4 insertions(+), 4 deletions(-) diff --git a/drivers/pinctrl/pinmux.c b/drivers/pinctrl/pinmux.c index c494c37..cd377a2 100644 --- a/drivers/pinctrl/pinmux.c +++ b/drivers/pinctrl/pinmux.c @@ -328,10 +328,10 @@ int pinmux_map_to_setting(struct pinctrl_map const *map, return -EINVAL; } - setting->data.mux.func = - pinmux_func_name_to_selector(pctldev, map->data.mux.function); - if (setting->data.mux.func < 0) - return setting->data.mux.func; + ret = pinmux_func_name_to_selector(pctldev, map->data.mux.function); + if (ret < 0) + return ret; + setting->data.mux.func = ret; ret = pmxops->get_function_groups(pctldev, setting->data.mux.func, &groups, &num_groups); -- 1.7.9.1 _______________________________________________ devicetree-discuss mailing list [email protected] https://lists.ozlabs.org/listinfo/devicetree-discuss
