]> git.ipfire.org Git - thirdparty/linux.git/commitdiff
pinctrl: spacemit: move over to generic pinmux dt_node_to_map implementation
authorConor Dooley <conor.dooley@microchip.com>
Tue, 19 May 2026 09:37:25 +0000 (10:37 +0100)
committerLinus Walleij <linusw@kernel.org>
Tue, 26 May 2026 11:32:52 +0000 (13:32 +0200)
Replace the custom implementation of dt_node_to_map with
pinctrl_generic_dt_node_to_map() to demonstrate its use.
spacemit_pin_mux_config didn't provide much value in the first place,
because the group contains the information required to look up the
spacemit_pin struct corresponding to a pin, so there's no loss in
functionality as a result of the generic function carrying only the mux
data in the group's data pointer rather than having an array of
spacemit_pin_mux_config structs.

Signed-off-by: Conor Dooley <conor.dooley@microchip.com>
Reviewed-by: Troy Mitchell <troy.mitchell@linux.spacemit.com>
Signed-off-by: Linus Walleij <linusw@kernel.org>
drivers/pinctrl/spacemit/Kconfig
drivers/pinctrl/spacemit/pinctrl-k1.c

index c021d51033d16a878c44273f1ef3e95d88c336d0..b2365deffe1be95beb6fed05662919330a83911a 100644 (file)
@@ -8,9 +8,7 @@ config PINCTRL_SPACEMIT_K1
        depends on ARCH_SPACEMIT || COMPILE_TEST
        depends on OF
        default ARCH_SPACEMIT
-       select GENERIC_PINCTRL_GROUPS
-       select GENERIC_PINMUX_FUNCTIONS
-       select GENERIC_PINCONF
+       select GENERIC_PINCTRL
        help
          Say Y to select the pinctrl driver for K1/K3 SoC.
          This pin controller allows selecting the mux function for
index ae8f9eb61a8c096ac98c7595a5237c949a617159..67de499349bb416c1ca7fb22fc03ee26118d018f 100644 (file)
@@ -114,11 +114,6 @@ struct spacemit_pinctrl_data {
        const struct spacemit_pinctrl_dconf     *dconf;
 };
 
-struct spacemit_pin_mux_config {
-       const struct spacemit_pin       *pin;
-       u32                             config;
-};
-
 /* map pin id to pinctrl register offset, refer MFPR definition */
 static unsigned int spacemit_k1_pin_to_offset(unsigned int pin)
 {
@@ -228,16 +223,6 @@ static inline void __iomem *spacemit_pin_to_reg(struct spacemit_pinctrl *pctrl,
        return pctrl->regs + pctrl->data->pin_to_offset(pin);
 }
 
-static u16 spacemit_dt_get_pin(u32 value)
-{
-       return value >> 16;
-}
-
-static u16 spacemit_dt_get_pin_mux(u32 value)
-{
-       return value & GENMASK(15, 0);
-}
-
 static const struct spacemit_pin *spacemit_get_pin(struct spacemit_pinctrl *pctrl,
                                                   unsigned long pin)
 {
@@ -445,121 +430,12 @@ static void spacemit_set_io_pwr_domain(struct spacemit_pinctrl *pctrl,
        writel_relaxed(val, pctrl->regs + IO_PWR_DOMAIN_OFFSET + offset);
 }
 
-static int spacemit_pctrl_dt_node_to_map(struct pinctrl_dev *pctldev,
-                                        struct device_node *np,
-                                        struct pinctrl_map **maps,
-                                        unsigned int *num_maps)
-{
-       struct spacemit_pinctrl *pctrl = pinctrl_dev_get_drvdata(pctldev);
-       struct device *dev = pctrl->dev;
-       struct device_node *child;
-       struct pinctrl_map *map;
-       const char **grpnames;
-       const char *grpname;
-       int ngroups = 0;
-       int nmaps = 0;
-       int ret;
-
-       for_each_available_child_of_node(np, child)
-               ngroups += 1;
-
-       grpnames = devm_kcalloc(dev, ngroups, sizeof(*grpnames), GFP_KERNEL);
-       if (!grpnames)
-               return -ENOMEM;
-
-       map = kzalloc_objs(*map, ngroups * 2);
-       if (!map)
-               return -ENOMEM;
-
-       ngroups = 0;
-       guard(mutex)(&pctrl->mutex);
-       for_each_available_child_of_node_scoped(np, child) {
-               struct spacemit_pin_mux_config *pinmuxs;
-               unsigned int config, *pins;
-               int i, npins;
-
-               npins = of_property_count_u32_elems(child, "pinmux");
-
-               if (npins < 1) {
-                       dev_err(dev, "invalid pinctrl group %pOFn.%pOFn\n",
-                               np, child);
-                       return -EINVAL;
-               }
-
-               grpname = devm_kasprintf(dev, GFP_KERNEL, "%pOFn.%pOFn",
-                                        np, child);
-               if (!grpname)
-                       return -ENOMEM;
-
-               grpnames[ngroups++] = grpname;
-
-               pins = devm_kcalloc(dev, npins, sizeof(*pins), GFP_KERNEL);
-               if (!pins)
-                       return -ENOMEM;
-
-               pinmuxs = devm_kcalloc(dev, npins, sizeof(*pinmuxs), GFP_KERNEL);
-               if (!pinmuxs)
-                       return -ENOMEM;
-
-               for (i = 0; i < npins; i++) {
-                       ret = of_property_read_u32_index(child, "pinmux",
-                                                        i, &config);
-
-                       if (ret)
-                               return -EINVAL;
-
-                       pins[i] = spacemit_dt_get_pin(config);
-                       pinmuxs[i].config = config;
-                       pinmuxs[i].pin = spacemit_get_pin(pctrl, pins[i]);
-
-                       if (!pinmuxs[i].pin)
-                               return dev_err_probe(dev, -ENODEV, "failed to get pin %d\n", pins[i]);
-               }
-
-               map[nmaps].type = PIN_MAP_TYPE_MUX_GROUP;
-               map[nmaps].data.mux.function = np->name;
-               map[nmaps].data.mux.group = grpname;
-               nmaps += 1;
-
-               ret = pinctrl_generic_add_group(pctldev, grpname,
-                                               pins, npins, pinmuxs);
-               if (ret < 0)
-                       return dev_err_probe(dev, ret, "failed to add group %s: %d\n", grpname, ret);
-
-               ret = pinconf_generic_parse_dt_config(child, pctldev,
-                                                     &map[nmaps].data.configs.configs,
-                                                     &map[nmaps].data.configs.num_configs);
-               if (ret)
-                       return dev_err_probe(dev, ret, "failed to parse pin config of group %s\n",
-                               grpname);
-
-               if (map[nmaps].data.configs.num_configs == 0)
-                       continue;
-
-               map[nmaps].type = PIN_MAP_TYPE_CONFIGS_GROUP;
-               map[nmaps].data.configs.group_or_pin = grpname;
-               nmaps += 1;
-       }
-
-       ret = pinmux_generic_add_function(pctldev, np->name,
-                                         grpnames, ngroups, NULL);
-       if (ret < 0) {
-               pinctrl_utils_free_map(pctldev, map, nmaps);
-               return dev_err_probe(dev, ret, "error adding function %s\n", np->name);
-       }
-
-       *maps = map;
-       *num_maps = nmaps;
-
-       return 0;
-}
-
 static const struct pinctrl_ops spacemit_pctrl_ops = {
        .get_groups_count       = pinctrl_generic_get_group_count,
        .get_group_name         = pinctrl_generic_get_group_name,
        .get_group_pins         = pinctrl_generic_get_group_pins,
        .pin_dbg_show           = spacemit_pctrl_dbg_show,
-       .dt_node_to_map         = spacemit_pctrl_dt_node_to_map,
+       .dt_node_to_map         = pinctrl_generic_pinmux_dt_node_to_map,
        .dt_free_map            = pinctrl_utils_free_map,
 };
 
@@ -568,8 +444,8 @@ static int spacemit_pmx_set_mux(struct pinctrl_dev *pctldev,
 {
        struct spacemit_pinctrl *pctrl = pinctrl_dev_get_drvdata(pctldev);
        const struct group_desc *group;
-       const struct spacemit_pin_mux_config *configs;
        unsigned int i, mux;
+       unsigned int *configs;
        void __iomem *reg;
 
        group = pinctrl_generic_get_group(pctldev, gsel);
@@ -579,11 +455,17 @@ static int spacemit_pmx_set_mux(struct pinctrl_dev *pctldev,
        configs = group->data;
 
        for (i = 0; i < group->grp.npins; i++) {
-               const struct spacemit_pin *spin = configs[i].pin;
-               u32 value = configs[i].config;
+               const struct spacemit_pin *spin;
+               u32 value = configs[i];
+
+               spin = spacemit_get_pin(pctrl, group->grp.pins[i]);
+               if (!spin) {
+                       dev_err(pctrl->dev, "Invalid pin %u\n", group->grp.pins[i]);
+                       return -EINVAL;
+               }
 
                reg = spacemit_pin_to_reg(pctrl, spin->pin);
-               mux = spacemit_dt_get_pin_mux(value);
+               mux = value;
 
                guard(raw_spinlock_irqsave)(&pctrl->lock);
                value = readl_relaxed(reg) & ~PAD_MUX;