]> git.ipfire.org Git - thirdparty/kernel/stable.git/commitdiff
pinctrl: make struct pinfunction a pointer in struct function_desc
authorBartosz Golaszewski <bartosz.golaszewski@linaro.org>
Tue, 2 Sep 2025 11:59:20 +0000 (13:59 +0200)
committerLinus Walleij <linus.walleij@linaro.org>
Mon, 8 Sep 2025 12:22:41 +0000 (14:22 +0200)
We currently duplicate the entire struct pinfunction object in
pinmux_generic_add_pinfunction(). While this is inevitable when the
arguments come in split through pinmux_generic_add_function(), users of
pinmux_generic_add_pinfunction() will typically pass addresses of
structures in .rodata, meaning we can try to avoid the duplication with
the help from kmemdup_const(). To that end: don't wrap the entire struct
pinfunction in struct function_desc but rather just store the address.

Tested-by: Neil Armstrong <neil.armstrong@linaro.org>
Signed-off-by: Bartosz Golaszewski <bartosz.golaszewski@linaro.org>
Signed-off-by: Linus Walleij <linus.walleij@linaro.org>
drivers/pinctrl/freescale/pinctrl-imx.c
drivers/pinctrl/mediatek/pinctrl-airoha.c
drivers/pinctrl/mediatek/pinctrl-moore.c
drivers/pinctrl/pinctrl-ingenic.c
drivers/pinctrl/pinmux.c
drivers/pinctrl/pinmux.h

index 39c582a25d8fe9ff24cc2b7d8b5a4d4e9fe982cb..731c58ad43eea98ba65de5d05755f9d33dd51951 100644 (file)
@@ -266,7 +266,7 @@ static int imx_pmx_set(struct pinctrl_dev *pctldev, unsigned selector,
        npins = grp->grp.npins;
 
        dev_dbg(ipctl->dev, "enable function %s group %s\n",
-               func->func.name, grp->grp.name);
+               func->func->name, grp->grp.name);
 
        for (i = 0; i < npins; i++) {
                /*
index 2eed83f9f209cad79580082c274d4056231bd421..8fb3b65a1b775cf078d3c926af59480e9e09ab30 100644 (file)
@@ -2456,7 +2456,7 @@ static int airoha_pinmux_set_mux(struct pinctrl_dev *pctrl_dev,
                return -EINVAL;
 
        dev_dbg(pctrl_dev->dev, "enable function %s group %s\n",
-               desc->func.name, grp->grp.name);
+               desc->func->name, grp->grp.name);
 
        func = desc->data;
        for (i = 0; i < func->group_size; i++) {
index 17a08c73423fd089066e4894d2307c852bbbb661..11dc525eb3a2dc8ceabf2278ee1a2abaa425eec1 100644 (file)
@@ -56,7 +56,7 @@ static int mtk_pinmux_set_mux(struct pinctrl_dev *pctldev,
                return -EINVAL;
 
        dev_dbg(pctldev->dev, "enable function %s group %s\n",
-               func->func.name, grp->grp.name);
+               func->func->name, grp->grp.name);
 
        for (i = 0; i < grp->grp.npins; i++) {
                const struct mtk_pin_desc *desc;
index e13ef07850386e70cffc83011589ceaf70a70a41..e5b24fab12e11e443df25ffeb7b70d7c1a03c6bc 100644 (file)
@@ -4015,7 +4015,7 @@ static int ingenic_pinmux_set_mux(struct pinctrl_dev *pctldev,
                return -EINVAL;
 
        dev_dbg(pctldev->dev, "enable function %s group %s\n",
-               func->func.name, grp->grp.name);
+               func->func->name, grp->grp.name);
 
        mode = (uintptr_t)grp->data;
        if (mode <= 3) {
index 1529d7b6c6657eed23dd1f3daac1fd7444efd1f7..07ec93f09334f8ba8f8cbde4c54fd6a894025ae6 100644 (file)
@@ -810,7 +810,7 @@ pinmux_generic_get_function_name(struct pinctrl_dev *pctldev,
        if (!function)
                return NULL;
 
-       return function->func.name;
+       return function->func->name;
 }
 EXPORT_SYMBOL_GPL(pinmux_generic_get_function_name);
 
@@ -835,8 +835,8 @@ int pinmux_generic_get_function_groups(struct pinctrl_dev *pctldev,
                        __func__, selector);
                return -EINVAL;
        }
-       *groups = function->func.groups;
-       *ngroups = function->func.ngroups;
+       *groups = function->func->groups;
+       *ngroups = function->func->ngroups;
 
        return 0;
 }
@@ -903,7 +903,17 @@ int pinmux_generic_add_pinfunction(struct pinctrl_dev *pctldev,
        if (!function)
                return -ENOMEM;
 
-       function->func = *func;
+       /*
+        * FIXME: It's generally a bad idea to use devres in subsystem core
+        * code - managed interfaces are aimed at drivers - but pinctrl already
+        * uses it all over the place so it's a larger piece of technical debt
+        * to fix.
+        */
+       function->func = devm_kmemdup_const(pctldev->dev, func,
+                                           sizeof(*func), GFP_KERNEL);
+       if (!function->func)
+               return -ENOMEM;
+
        function->data = data;
 
        error = radix_tree_insert(&pctldev->pin_function_tree, selector, function);
index 549ab10f7afbda32fadf4ad151401180bed2064f..653684290666d78fd725febb5f8bc987b66a1afb 100644 (file)
@@ -137,7 +137,7 @@ static inline void pinmux_init_device_debugfs(struct dentry *devroot,
  * @data: pin controller driver specific data
  */
 struct function_desc {
-       struct pinfunction func;
+       const struct pinfunction *func;
        void *data;
 };