Print out the affected group name on activation of pin mux
settings, and warn if you cannot free a pin that should have
been part of a certain setting.

Cc: Sonic Zhang <sonic.zh...@analog.com>
Signed-off-by: Linus Walleij <linus.wall...@linaro.org>
---
 drivers/pinctrl/pinmux.c | 35 +++++++++++++++++++++++++++++------
 1 file changed, 29 insertions(+), 6 deletions(-)

diff --git a/drivers/pinctrl/pinmux.c b/drivers/pinctrl/pinmux.c
index 5f51588..008f965 100644
--- a/drivers/pinctrl/pinmux.c
+++ b/drivers/pinctrl/pinmux.c
@@ -400,10 +400,14 @@ int pinmux_enable_setting(struct pinctrl_setting const 
*setting)
        ret = pctlops->get_group_pins(pctldev, setting->data.mux.group,
                                      &pins, &num_pins);
        if (ret) {
+               const char *gname;
+
                /* errors only affect debug data, so just warn */
+               gname = pctlops->get_group_name(pctldev,
+                                               setting->data.mux.group);
                dev_warn(pctldev->dev,
-                        "could not get pins for group selector %d\n",
-                        setting->data.mux.group);
+                        "could not get pins for group %s\n",
+                        gname);
                num_pins = 0;
        }
 
@@ -411,9 +415,14 @@ int pinmux_enable_setting(struct pinctrl_setting const 
*setting)
        for (i = 0; i < num_pins; i++) {
                ret = pin_request(pctldev, pins[i], setting->dev_name, NULL);
                if (ret) {
+                       const char *gname;
+
+                       gname = pctlops->get_group_name(pctldev,
+                                               setting->data.mux.group);
                        dev_err(pctldev->dev,
-                               "could not request pin %d on device %s\n",
-                               pins[i], pinctrl_dev_get_name(pctldev));
+                               "could not request pin %d from group %s on "
+                               "device %s\n",
+                               pins[i], gname, pinctrl_dev_get_name(pctldev));
                        goto err_pin_request;
                }
        }
@@ -466,10 +475,14 @@ void pinmux_disable_setting(struct pinctrl_setting const 
*setting)
        ret = pctlops->get_group_pins(pctldev, setting->data.mux.group,
                                      &pins, &num_pins);
        if (ret) {
+               const char *gname;
+
                /* errors only affect debug data, so just warn */
+               gname = pctlops->get_group_name(pctldev,
+                                               setting->data.mux.group);
                dev_warn(pctldev->dev,
-                        "could not get pins for group selector %d\n",
-                        setting->data.mux.group);
+                        "could not get pins for group %s\n",
+                        gname);
                num_pins = 0;
        }
 
@@ -486,6 +499,16 @@ void pinmux_disable_setting(struct pinctrl_setting const 
*setting)
                        desc->mux_setting = NULL;
                        /* And release the pin */
                        pin_free(pctldev, pins[i], NULL);
+               } else {
+                       const char *gname;
+
+                       gname = pctlops->get_group_name(pctldev,
+                                               setting->data.mux.group);
+                       dev_warn(pctldev->dev,
+                                "not freeing pin %d as part of deactivating "
+                                "group %s - it is already used for some other "
+                                "setting",
+                                pins[i], gname);
                }
        }
 
-- 
1.8.1.4

--
To unsubscribe from this list: send the line "unsubscribe linux-kernel" in
the body of a message to majord...@vger.kernel.org
More majordomo info at  http://vger.kernel.org/majordomo-info.html
Please read the FAQ at  http://www.tux.org/lkml/

Reply via email to