On Fri, Sep 07, 2012 at 02:30:59PM +0000, AnilKumar, Chimata wrote: > On Fri, Sep 07, 2012 at 16:32:51, Domenico Andreoli wrote: > > On Fri, Sep 07, 2012 at 09:10:50AM +0000, AnilKumar, Chimata wrote: > > > On Fri, Sep 07, 2012 at 14:18:39, Domenico Andreoli wrote: > > > > On Sat, Sep 1, 2012 at 10:16 AM, AnilKumar Ch <anilkumar@xxxxxx> wrote: > > > > > Adopt pinctrl support to leds-gpio driver based on leds-gpio > > > > > device pointer, pinctrl driver configure SoC pins to GPIO > > > > > mode according to definitions provided in .dts file. > > > > > > > > Shouldn't be the interaction with the pinctrl layer left to gpiolib? > > > > > > > > > > No, these gpio's are configured specifically for user leds. > > > > So there are some special pad configs to make the leds work which are not > > only muxing and direction setting? Because I expect these to be managed > > privately between gpiolib and pinctrl but now I'm not sure any more, > > I'll look the code. > > How can gpio driver knows that leds-gpio driver require > these 4 pins? because leds-gpio requests each gpio (specified in the DT against a specific gpio controller) before assuming it is available? gpiolib then asks to pinctrl if those pins are available for gpio and possibly reserve them (configuring the mux, if necessary) for the device. But this idea does not correspond to the code, so I must have filled in the blanks of something I didn't fully understand. > > > So, leds-gpio driver should have this call, because these gpio > > > pins are used by leds-gpio driver. > > > > > > + am33xx_pinmux: pinmux@44e10800 { > > > + userled_pins: pinmux_userled_pins { > > > + pinctrl-single,pins = < > > > + 0x54 0x7 > > > + 0x58 0x17 > > > + 0x5c 0x7 > > > + 0x60 0x17 > > > + >; > > > + }; > > > + }; > > > + > > > > > > [...] > > > > > > + leds { > > > + compatible = "gpio-leds"; > > > + pinctrl-names = "default"; > > > + pinctrl-0 = <&userled_pins>; > > > ^^^^^^^^^^^^ > > > > I'm surprised to not see any gpio controller (ala irq) involved. > > GPIO controller data will be in GPIO node, should not be here. So is this the preferred way to attach gpio users to gpio provides in DT whenever gpios are muxed? I would well see these info hidden in the gpio controller so, at least for gpios, no magic numbers would be required in the DT (except the gpio number relative to the owning controller). > > > Lets take gpio-keypad driver, in that case we have to configure > > > pins as INPUT mode (generic gpio driver might not know what > > > the end usecase is) and this leds case we configure as OUTPUT > > > mode. > > > > gpio direction is modeled by gpiolib so, if no other out-of-gpiolib > > capabilities are required for that led gpio, there is no need to directly > > use pinctrl. > > > > Here leds-gpio driver requirement is to set mux configuration of > those 4 pins to GPIO mode (mode 7) as well direction OUTPUT/INPUT. Direction info is passed to gpiolib in the exact instant gpio_set_direction_*() is invoked. > Set mux mode to 7 (GPIO usage) should be from led driver, because > this driver have the requirement. This GPIO mode value is known to the pinctrl driver, actually it's _specific_ for that driver. So the only info pinctrl would really need to know is which pin is requested to be used as GPIO, something that gpiolib already manages. So I really don't see why the gpiolib could not be (I've understood it isn't) the one-stop for GPIO users. Of course direct pinctrl configuration would be required for all those specific gpio parameters not modeled by the gpiolib (like debounce times, etc). cheers, Domenico -- To unsubscribe from this list: send the line "unsubscribe linux-omap" in the body of a message to majordomo@xxxxxxxxxxxxxxx More majordomo info at http://vger.kernel.org/majordomo-info.html