Re: better leve triggered IRQ management needed

[Date Prev][Date Next][Thread Prev][Thread Next][Date Index][Thread Index]

 




On Mon, 24 Apr 2006, Stephen Hemminger wrote:
>
> We should fail request_irq() if the SA_SHIRQ but the irq is edge-triggered.

That would be HORRIBLE.

Edge-triggered works perfectly fine for SA_SHIRQ, as long as there is just 
one user and the driver is properly written. Making request_irq() fail 
would break existing and working setups.

If you have a driver that requires level-triggered interrupts, then your 
driver is arguably buggy. NAPI or no NAPI, doesn't matter. Edge-triggered 
interrupts is a fact of life, and deciding that you don't like them is not 
an excuse for saying "they should not work".

You can get an edge by having your driver make sure that it clears the 
interrupt source at some point where it requires an edge.

And yes, that may mean that when you're ready to start taking interrupts 
again, you are required to first read all pending packets, instead of just 
assuming that a level-triggered interrupt will "just happen", but that's 
the harsh reality for writing a driver that actually WORKS.

For a driver writer, there is one rule above _all_ other rules:

	"Reality sucks, deal with it"

That rule is inviolate, and no amount of "I wish", and "it _should_ work 
this way" or "..but the documentation says" matters at all.

If you can't take that rule, don't write drivers, and don't design 
infrastructure for them.

		Linus
-
To unsubscribe from this list: send the line "unsubscribe linux-kernel" in
the body of a message to [email protected]
More majordomo info at  http://vger.kernel.org/majordomo-info.html
Please read the FAQ at  http://www.tux.org/lkml/

[Index of Archives]     [Kernel Newbies]     [Netfilter]     [Bugtraq]     [Photo]     [Stuff]     [Gimp]     [Yosemite News]     [MIPS Linux]     [ARM Linux]     [Linux Security]     [Linux RAID]     [Video 4 Linux]     [Linux for the blind]     [Linux Resources]
  Powered by Linux