pinctrl: tegra: Use correct offset for pin group
authorPrathamesh Shete <pshete@nvidia.com>
Mon, 25 Oct 2021 11:09:59 +0000 (16:39 +0530)
committerLinus Walleij <linus.walleij@linaro.org>
Mon, 25 Oct 2021 23:27:39 +0000 (01:27 +0200)
Function tegra_pinctrl_gpio_request_enable() and
tegra_pinctrl_gpio_disable_free() uses pin offset instead
of group offset, causing the driver to use wrong offset
to enable gpio.

Add a helper function tegra_pinctrl_get_group() to parse the
pin group and determine correct offset.

Signed-off-by: Kartik K <kkartik@nvidia.com>
Signed-off-by: Prathamesh Shete <pshete@nvidia.com>
Link: https://lore.kernel.org/r/20211025110959.27751-1-pshete@nvidia.com
Signed-off-by: Linus Walleij <linus.walleij@linaro.org>
drivers/pinctrl/tegra/pinctrl-tegra.c

index 195cfe557511bd5c0c2000335f429c8b240c2918..0471d9c7f0ba155a8b61481e1498553ebfbeca9f 100644 (file)
@@ -275,6 +275,29 @@ static int tegra_pinctrl_set_mux(struct pinctrl_dev *pctldev,
        return 0;
 }
 
+static struct tegra_pingroup *tegra_pinctrl_get_group(struct pinctrl_dev *pctldev,
+                                       unsigned int offset)
+{
+       struct tegra_pmx *pmx = pinctrl_dev_get_drvdata(pctldev);
+       struct tegra_pingroup *g;
+       unsigned int group, num_pins, j;
+       const unsigned int *pins;
+       int ret;
+
+       for (group = 0; group < pmx->soc->ngroups; ++group) {
+               ret = tegra_pinctrl_get_group_pins(pctldev, group, &pins, &num_pins);
+               if (ret < 0)
+                       continue;
+               for (j = 0; j < num_pins; j++) {
+                       if (offset == pins[j])
+                               return &pmx->soc->groups[group];
+               }
+       }
+
+       dev_err(pctldev->dev, "Pingroup not found for pin %u\n", offset);
+       return NULL;
+}
+
 static int tegra_pinctrl_gpio_request_enable(struct pinctrl_dev *pctldev,
                                             struct pinctrl_gpio_range *range,
                                             unsigned int offset)
@@ -286,7 +309,10 @@ static int tegra_pinctrl_gpio_request_enable(struct pinctrl_dev *pctldev,
        if (!pmx->soc->sfsel_in_mux)
                return 0;
 
-       group = &pmx->soc->groups[offset];
+       group = tegra_pinctrl_get_group(pctldev, offset);
+
+       if (!group)
+               return -EINVAL;
 
        if (group->mux_reg < 0 || group->sfsel_bit < 0)
                return -EINVAL;
@@ -309,7 +335,10 @@ static void tegra_pinctrl_gpio_disable_free(struct pinctrl_dev *pctldev,
        if (!pmx->soc->sfsel_in_mux)
                return;
 
-       group = &pmx->soc->groups[offset];
+       group = tegra_pinctrl_get_group(pctldev, offset);
+
+       if (!group)
+               return -EINVAL;
 
        if (group->mux_reg < 0 || group->sfsel_bit < 0)
                return;