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

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.com


Signed-off-by: default avatarLinus Walleij <linus.walleij@linaro.org>
parent 08b71a71
Loading
Loading
Loading
Loading
+33 −19
Original line number Diff line number Diff line
@@ -474,11 +474,38 @@ static int s32_get_slew_regval(int arg)
	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)
{
	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;

	param = pinconf_to_config_param(pincfg);
	arg = pinconf_to_config_argument(pincfg);

	switch (param) {
	/* All pins are persistent over suspend */
	case PIN_CONFIG_PERSIST_STATE:
@@ -508,26 +535,15 @@ static int s32_get_pin_conf(enum pin_config_param param, u32 arg,
		*config |= S32_MSCR_SRE((u32)ret);
		*mask |= S32_MSCR_SRE(~0);
		break;
	case PIN_CONFIG_BIAS_DISABLE:
	case PIN_CONFIG_BIAS_PULL_UP:
		if (arg)
			*config |= S32_MSCR_PUS;
		else
			*config &= ~S32_MSCR_PUS;
		fallthrough;
	case PIN_CONFIG_BIAS_PULL_DOWN:
		if (arg)
			*config |= S32_MSCR_PUE;
		else
			*config &= ~S32_MSCR_PUE;
		*mask |= S32_MSCR_PUE | S32_MSCR_PUS;
		s32_pin_set_pull(param, mask, config);
		break;
	case PIN_CONFIG_BIAS_HIGH_IMPEDANCE:
		*config &= ~(S32_MSCR_ODE | S32_MSCR_OBE | S32_MSCR_IBE);
		*mask |= S32_MSCR_ODE | S32_MSCR_OBE | S32_MSCR_IBE;
		fallthrough;
	case PIN_CONFIG_BIAS_DISABLE:
		*config &= ~(S32_MSCR_PUS | S32_MSCR_PUE);
		*mask |= S32_MSCR_PUS | S32_MSCR_PUE;
		s32_pin_set_pull(param, mask, config);
		break;
	default:
		return -EOPNOTSUPP;
@@ -553,9 +569,7 @@ static int s32_pinconf_mscr_update(struct pinctrl_dev *pctldev,
		pin_get_name(pctldev, pin_id), num_configs);

	for (i = 0; i < num_configs; i++) {
		ret = s32_get_pin_conf(pinconf_to_config_param(configs[i]),
				       pinconf_to_config_argument(configs[i]),
				       &mask, &config);
		ret = s32_parse_pincfg(configs[i], &mask, &config);
		if (ret)
			return ret;
	}