pinctrl: s32cc: refactor pin config parsing
authorChester Lin <clin@suse.com>
Mon, 27 Mar 2023 06:27:51 +0000 (14:27 +0800)
committerLinus Walleij <linus.walleij@linaro.org>
Mon, 27 Mar 2023 21:35:00 +0000 (23:35 +0200)
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: Chester Lin <clin@suse.com>
Reviewed-by: Andy Shevchenko <andy.shevchenko@gmail.com>
Link: https://lore.kernel.org/r/20230327062754.3326-3-clin@suse.com
Signed-off-by: Linus Walleij <linus.walleij@linaro.org>
drivers/pinctrl/nxp/pinctrl-s32cc.c

index f698e1a..36f323f 100644 (file)
@@ -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,
-                           unsigned int *mask, unsigned int *config)
+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;
        }