]> git.ipfire.org Git - thirdparty/kernel/stable.git/commitdiff
pinctrl: stm32: Rework stm32_pconf_parse_conf()
authorAntonio Borneo <antonio.borneo@foss.st.com>
Thu, 23 Oct 2025 13:26:53 +0000 (15:26 +0200)
committerLinus Walleij <linus.walleij@linaro.org>
Tue, 28 Oct 2025 09:43:01 +0000 (10:43 +0100)
Reduce the number of parameters of the function by moving inside
the function the decoding of the field 'config'.

While there:
- change the type of 'param' to 'unsigned int' to handle the extra
  values not in 'enum pin_config_param';
- change the type of 'arg' to 'u32' to avoid additional conversions
  and align to 'u32' the corresponding param of __stm32_gpio_set().

Signed-off-by: Antonio Borneo <antonio.borneo@foss.st.com>
Signed-off-by: Linus Walleij <linus.walleij@linaro.org>
drivers/pinctrl/stm32/pinctrl-stm32.c

index 3ebb468de830db89a226e751fab48fad670c89b4..6c5f9e015e8e1b49f3050f4c986c39fa3ba3f140 100644 (file)
@@ -287,7 +287,7 @@ static void stm32_gpio_rif_release_semaphore(struct stm32_gpio_bank *bank, unsig
 /* GPIO functions */
 
 static inline void __stm32_gpio_set(struct stm32_gpio_bank *bank,
-       unsigned offset, int value)
+       unsigned int offset, u32 value)
 {
        stm32_gpio_backup_value(bank, offset, value);
 
@@ -1195,10 +1195,11 @@ static bool stm32_pconf_get(struct stm32_gpio_bank *bank,
 }
 
 static int stm32_pconf_parse_conf(struct pinctrl_dev *pctldev,
-               unsigned int pin, enum pin_config_param param,
-               enum pin_config_param arg)
+               unsigned int pin, unsigned long config)
 {
        struct stm32_pinctrl *pctl = pinctrl_dev_get_drvdata(pctldev);
+       unsigned int param = pinconf_to_config_param(config);
+       u32 arg = pinconf_to_config_argument(config);
        struct pinctrl_gpio_range *range;
        struct stm32_gpio_bank *bank;
        int offset, ret = 0;
@@ -1267,9 +1268,7 @@ static int stm32_pconf_group_set(struct pinctrl_dev *pctldev, unsigned group,
 
        for (i = 0; i < num_configs; i++) {
                mutex_lock(&pctldev->mutex);
-               ret = stm32_pconf_parse_conf(pctldev, g->pin,
-                       pinconf_to_config_param(configs[i]),
-                       pinconf_to_config_argument(configs[i]));
+               ret = stm32_pconf_parse_conf(pctldev, g->pin, configs[i]);
                mutex_unlock(&pctldev->mutex);
                if (ret < 0)
                        return ret;
@@ -1286,9 +1285,7 @@ static int stm32_pconf_set(struct pinctrl_dev *pctldev, unsigned int pin,
        int i, ret;
 
        for (i = 0; i < num_configs; i++) {
-               ret = stm32_pconf_parse_conf(pctldev, pin,
-                               pinconf_to_config_param(configs[i]),
-                               pinconf_to_config_argument(configs[i]));
+               ret = stm32_pconf_parse_conf(pctldev, pin, configs[i]);
                if (ret < 0)
                        return ret;
        }