On Wednesday 14 October 2009, Arve Hjønnevåg wrote: > 2009/10/14 Ferenc Wagner <wferi@xxxxxxx>: > > Dmitry Torokhov <dmitry.torokhov@xxxxxxxxx> writes: > > > >> On Mon, Oct 12, 2009 at 07:09:50PM +0200, Ferenc Wagner wrote: > >> > >>> The gpio_get_value function may sleep, so it should not be > >>> called in a timer function. > >>> > >>> So is drivers/staging/dream/gpio_input.c in error, too? > >> > >> I guess so. Initially gpio method did not sleep but that has > >> changed. > > > > Let's make Arve aware of this then (even though it may not affect > > Android in practice). > > If gpio_get_value may sleep, then what is gpio_get_value_cansleep for? To tell if this is one of the GPIOs for which it may sleep. Whether the GPIO is atomic vs cansleep is an attribute of the GPIO itself, not the routine it's called with. > The gpio documentation claims gpio_get_value and gpio_set_value are > safe to use from interrupt context, but a call to gpio_cansleep is > probably needed in probe. They're safe to use there ... if that GPIO is safe. Yes, make sure you know the answer before you call gpio_get_value() instead of the always-safe gpio_get_value_cansleep(). > The matrix driver also need to change the direction of the gpio from > the timer, so it would be useful to have a standard way to check if > this is allowed as well. If gpio_{set,get}_value() can sleep, so can gpio_direction_*(). - Dave -- To unsubscribe from this list: send the line "unsubscribe linux-input" in the body of a message to majordomo@xxxxxxxxxxxxxxx More majordomo info at http://vger.kernel.org/majordomo-info.html