[PATCH 3/6 v9] gpio: Add userland device interface to block GPIO
Roland Stigge
stigge at antcom.de
Wed Dec 5 17:20:57 EST 2012
Hi Wolfgang,
On 05/12/12 20:01, Wolfgang Grandegger wrote:
>> + for (i = 0; i < block->ngpio; i++) {
>> + status = gpio_request(block->gpio[i], "gpioblock dev");
>
> You could use the name of the GPIO block.
OK.
>> + if (status)
>> + goto err1;
>> +
>> + irq = gpio_to_irq(block->gpio[i]);
>> + if (irq >= 0 &&
>> + !test_bit(FLAG_IS_OUT, &gpio_desc[block->gpio[i]].flags) &&
>> + !gpio_block_is_irq_duplicate(block, i)) {
>> + status = request_irq(irq, gpio_block_irq_handler,
>> + IRQF_TRIGGER_FALLING,
>> + block->name, block);
>> + if (status)
>> + goto err2;
>> +
>> + block->irq_controlled = true;
>> + }
>> + }
>
> There is no need to request IRQs if "O_NONBLOCK" is specified.
Sure? Regarding this, I found: "The poll() function shall not be
affected by the O_NONBLOCK flag." [1]
> I observed that the read returns once immediately (without blocking)
> after reboot. I did not look into that yet.
Didn't happen to me. Can you tell how this can be reproduced?
Thanks,
Roland
[1] http://pubs.opengroup.org/onlinepubs/009695399/functions/poll.html
More information about the linux-arm-kernel
mailing list