Re: [PATCH 2/2] RFT: pinctrl: sirf: move sgpio lock into state container

From: Linus Walleij
Date: Fri May 09 2014 - 07:57:21 EST


On Thu, May 1, 2014 at 2:40 PM, Barry Song <baohua@xxxxxxxxxx> wrote:
> 2014-04-24 5:16 GMT+08:00 Linus Walleij <linus.walleij@xxxxxxxxxx>:

>> Instead of referring to a global static variable for the sgpio
>> locking, use the state container to contain the lock.
>>
>> Signed-off-by: Linus Walleij <linus.walleij@xxxxxxxxxx>
>
> hi Linus, thanks! this looks very good only if we fix the
> gpiochip_add_pin_range() failure in patch 1:
>
> [ 0.231658] pinmux-sirf b0120000.pinctrl: initialized SIRFSOC pinmux driver
> [ 0.261200] bio: create slab <bio-0> at 0
> [ 0.268264] GPIO chip /axi/peri-iobg/pinctrl@b0120000: could not
> create pin range
> [ 0.276142] pinmux-sirf b0120000.pinctrl: could not add gpiochip pin range

Hm! This may mean that the pin controller is not there at this point,
so the pin controller needs to be probed first, before the gpiochip
and its range is probed.

What happens if you do this:

diff --git a/drivers/pinctrl/sirf/pinctrl-sirf.c
b/drivers/pinctrl/sirf/pinctrl-sirf.c
index 76502aab2cb1..ce7c3552398f 100644
--- a/drivers/pinctrl/sirf/pinctrl-sirf.c
+++ b/drivers/pinctrl/sirf/pinctrl-sirf.c
@@ -950,7 +950,7 @@ static int __init sirfsoc_gpio_init(void)

return sirfsoc_gpio_probe(np);
}
-subsys_initcall(sirfsoc_gpio_init);
+device_initcall(sirfsoc_gpio_init);

MODULE_AUTHOR("Rongjun Ying <rongjun.ying@xxxxxxx>, "
"Yuping Luo <yuping.luo@xxxxxxx>, "


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