pinctrl: spear: Make get_gpio_pingroup return NULL when no gpio_pingroup found
authorAxel Lin <axel.lin@ingics.com>
Tue, 13 Nov 2012 12:20:50 +0000 (20:20 +0800)
committerLinus Walleij <linus.walleij@linaro.org>
Thu, 15 Nov 2012 11:31:23 +0000 (12:31 +0100)
Currently get_gpio_pingroup() may return NULL or ERR_PTR(-EINVAL) when
no gpio_pingroup found. The caller in gpio_request_endisable() only
checks if the return value is NULL. Return ERR_PTR(-EINVAL) for
get_gpio_pingroup() causes problem and seems not necessary.

Signed-off-by: Axel Lin <axel.lin@ingics.com>
Acked-by: Viresh Kumar <viresh.kumar@linaro.org>
Signed-off-by: Linus Walleij <linus.walleij@linaro.org>
drivers/pinctrl/spear/pinctrl-spear.c

index add933286e94f43951521e8c04a80584a5d66e5e..bf78eb7f85c4ebb58e2964562b57a102bb06bf0f 100644 (file)
@@ -286,12 +286,12 @@ static struct spear_gpio_pingroup *get_gpio_pingroup(struct spear_pmx *pmx,
                unsigned pin)
 {
        struct spear_gpio_pingroup *gpio_pingroup;
-       int i = 0, j;
+       int i, j;
 
        if (!pmx->machdata->gpio_pingroups)
                return NULL;
 
-       for (; i < pmx->machdata->ngpio_pingroups; i++) {
+       for (i = 0; i < pmx->machdata->ngpio_pingroups; i++) {
                gpio_pingroup = &pmx->machdata->gpio_pingroups[i];
 
                for (j = 0; j < gpio_pingroup->npins; j++) {
@@ -300,7 +300,7 @@ static struct spear_gpio_pingroup *get_gpio_pingroup(struct spear_pmx *pmx,
                }
        }
 
-       return ERR_PTR(-EINVAL);
+       return NULL;
 }
 
 static int gpio_request_endisable(struct pinctrl_dev *pctldev,