Commit 48b016cb authored by Chester Lin's avatar Chester Lin Committed by Linus Walleij

pinctrl: s32cc: refactor pin config parsing

Move common codes into smaller inline functions and remove argument checks
that are not actually used by pull up/down bits in the S32 MSCR register.
Signed-off-by: default avatarChester Lin <clin@suse.com>
Reviewed-by: default avatarAndy Shevchenko <andy.shevchenko@gmail.com>
Link: https://lore.kernel.org/r/20230327062754.3326-3-clin@suse.comSigned-off-by: default avatarLinus Walleij <linus.walleij@linaro.org>
parent 08b71a71
...@@ -474,11 +474,38 @@ static int s32_get_slew_regval(int arg) ...@@ -474,11 +474,38 @@ static int s32_get_slew_regval(int arg)
return -EINVAL; return -EINVAL;
} }
static int s32_get_pin_conf(enum pin_config_param param, u32 arg, static inline void s32_pin_set_pull(enum pin_config_param param,
unsigned int *mask, unsigned int *config) unsigned int *mask, unsigned int *config)
{ {
switch (param) {
case PIN_CONFIG_BIAS_DISABLE:
case PIN_CONFIG_BIAS_HIGH_IMPEDANCE:
*config &= ~(S32_MSCR_PUS | S32_MSCR_PUE);
break;
case PIN_CONFIG_BIAS_PULL_UP:
*config |= S32_MSCR_PUS | S32_MSCR_PUE;
break;
case PIN_CONFIG_BIAS_PULL_DOWN:
*config &= ~S32_MSCR_PUS;
*config |= S32_MSCR_PUE;
break;
default:
return;
}
*mask |= S32_MSCR_PUS | S32_MSCR_PUE;
}
static int s32_parse_pincfg(unsigned long pincfg, unsigned int *mask,
unsigned int *config)
{
enum pin_config_param param;
u32 arg;
int ret; int ret;
param = pinconf_to_config_param(pincfg);
arg = pinconf_to_config_argument(pincfg);
switch (param) { switch (param) {
/* All pins are persistent over suspend */ /* All pins are persistent over suspend */
case PIN_CONFIG_PERSIST_STATE: case PIN_CONFIG_PERSIST_STATE:
...@@ -508,26 +535,15 @@ static int s32_get_pin_conf(enum pin_config_param param, u32 arg, ...@@ -508,26 +535,15 @@ static int s32_get_pin_conf(enum pin_config_param param, u32 arg,
*config |= S32_MSCR_SRE((u32)ret); *config |= S32_MSCR_SRE((u32)ret);
*mask |= S32_MSCR_SRE(~0); *mask |= S32_MSCR_SRE(~0);
break; break;
case PIN_CONFIG_BIAS_DISABLE:
case PIN_CONFIG_BIAS_PULL_UP: case PIN_CONFIG_BIAS_PULL_UP:
if (arg)
*config |= S32_MSCR_PUS;
else
*config &= ~S32_MSCR_PUS;
fallthrough;
case PIN_CONFIG_BIAS_PULL_DOWN: case PIN_CONFIG_BIAS_PULL_DOWN:
if (arg) s32_pin_set_pull(param, mask, config);
*config |= S32_MSCR_PUE;
else
*config &= ~S32_MSCR_PUE;
*mask |= S32_MSCR_PUE | S32_MSCR_PUS;
break; break;
case PIN_CONFIG_BIAS_HIGH_IMPEDANCE: case PIN_CONFIG_BIAS_HIGH_IMPEDANCE:
*config &= ~(S32_MSCR_ODE | S32_MSCR_OBE | S32_MSCR_IBE); *config &= ~(S32_MSCR_ODE | S32_MSCR_OBE | S32_MSCR_IBE);
*mask |= S32_MSCR_ODE | S32_MSCR_OBE | S32_MSCR_IBE; *mask |= S32_MSCR_ODE | S32_MSCR_OBE | S32_MSCR_IBE;
fallthrough; s32_pin_set_pull(param, mask, config);
case PIN_CONFIG_BIAS_DISABLE:
*config &= ~(S32_MSCR_PUS | S32_MSCR_PUE);
*mask |= S32_MSCR_PUS | S32_MSCR_PUE;
break; break;
default: default:
return -EOPNOTSUPP; return -EOPNOTSUPP;
...@@ -553,9 +569,7 @@ static int s32_pinconf_mscr_update(struct pinctrl_dev *pctldev, ...@@ -553,9 +569,7 @@ static int s32_pinconf_mscr_update(struct pinctrl_dev *pctldev,
pin_get_name(pctldev, pin_id), num_configs); pin_get_name(pctldev, pin_id), num_configs);
for (i = 0; i < num_configs; i++) { for (i = 0; i < num_configs; i++) {
ret = s32_get_pin_conf(pinconf_to_config_param(configs[i]), ret = s32_parse_pincfg(configs[i], &mask, &config);
pinconf_to_config_argument(configs[i]),
&mask, &config);
if (ret) if (ret)
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