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-gpio" in the body of a message to majordomo@xxxxxxxxxxxxxxx More majordomo info at http://vger.kernel.org/majordomo-info.html