diff --git a/[refs] b/[refs] index c953c917fe4f..f00fb24e0dd6 100644 --- a/[refs] +++ b/[refs] @@ -1,2 +1,2 @@ --- -refs/heads/master: af6061777131639d7d2687ce542b6052a6510c25 +refs/heads/master: 385d94246b05f7c06d7ecb5215087e5ebddbf1e6 diff --git a/trunk/drivers/pinctrl/core.c b/trunk/drivers/pinctrl/core.c index deb3d04323b0..8b832ce6a8e3 100644 --- a/trunk/drivers/pinctrl/core.c +++ b/trunk/drivers/pinctrl/core.c @@ -981,26 +981,10 @@ static int pinctrl_select_state_locked(struct pinctrl *p, pinmux_disable_setting(setting2); } - if (old_state) { - list_for_each_entry(setting, &old_state->settings, node) { - bool found = false; - if (setting->type != PIN_MAP_TYPE_MUX_GROUP) - continue; - list_for_each_entry(setting2, &state->settings, node) { - if (setting2->type != PIN_MAP_TYPE_MUX_GROUP) - continue; - if (setting2->data.mux.group == - setting->data.mux.group) { - found = true; - break; - } - } - if (!found) - pinmux_enable_setting(setting); - } - } + /* There's no infinite recursive loop here because p->state is NULL */ + if (old_state) + pinctrl_select_state_locked(p, old_state); - p->state = old_state; return ret; }