On Tue, Aug 27, 2013 at 10:17 PM, Stephen Warren <swarren@xxxxxxxxxxxxx> wrote: > On 08/26/2013 08:07 AM, Lars Poeschel wrote: >> >> Currently the kernel is ambigously treating GPIOs and interrupts >> from a GPIO controller: GPIOs and interrupts are treated as >> orthogonal. This unfortunately makes it unclear how to actually >> retrieve and request a GPIO line or interrupt from a GPIO >> controller in the device tree probe path. > > I still think that this patch is the wrong approach. Instead, the logic > should be hooked into gpio_request() and request_irq(). This patch only > addresses DT, and ignores anything else, hence doesn't seem like the > right level of abstraction to plug in, since the issue is not related to DT. We tried to do it that way, and it exploded. See commit b4419e1a15905191661ffe75ba2f9e649f5d565e "gpio/omap: auto request GPIO as input if used as IRQ via DT" Here request_irq() augmented through its irqdomain to issue gpio_request_one(). Why was this patch reverted? It seems this is what has not managed to reach the audience here. It turns out some drivers were already doing this: request_gpio(gpio); gpio_direction_input(gpio); request_irq(gpio_to_irq(gpio)); Looks perfectly valid right? Not so: after the above change, we tried to request the GPIO a *second time* in the GPIO driver's irq map function, and of course it failed, as it was already taken. So saying that it should be done in the request_irq() function is imposing this other semantic on the kernel instead: you must *NOT* request the GPIO with request_gpio() if you're going to use it as an IRQ. (Also, it force us to implement the same code in each and every driver, but that is a lesser problem.) I don't quite understand what is so hard around this. We cannot get away from restricting the semantics in some way, if gpio-controllers shall also be interrupt-controllers, the current patch is the least intrusive I've seen so far. And I don't even think this is a Linux problem, handing out the same resource with two hands is ambigous and is going to cause problems with any operating system. It is better to restrict this and say in the binding doc that the gpio line cannot be <&gpio n> assigned when there is an interrupt on the same line. We can start out by printing warnings when we fail to request the corresponding GPIO for an interrupt line though, it will be annoying enough and a kind of compromise. Or it has to be the GPIO input hogs. Yours, Linus Walleij -- To unsubscribe from this list: send the line "unsubscribe devicetree" in the body of a message to majordomo@xxxxxxxxxxxxxxx More majordomo info at http://vger.kernel.org/majordomo-info.html