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
--
To unsubscribe from this list: send the line "unsubscribe linux-kernel" in
the body of a message to majord...@vger.kernel.org
More majordomo info at  http://vger.kernel.org/majordomo-info.html
Please read the FAQ at  http://www.tux.org/lkml/

Reply via email to