IRQ Level / Edge

Sven Luther sven.luther at wanadoo.fr
Sun Jul 4 02:42:16 EST 2004


On Fri, Jul 02, 2004 at 05:47:59PM -0500, Andy Fleming wrote:
>
> Level sensitive Interrupts will continue to fire until the interrupt is
> cleared.  Essentially, the hardware device causing the interrupt will
> bring the interrupt line up (or down, depending on the polarity), and
> keep it at that level until the condition disappears.  By setting the
> IRQ controller to consider that interrupt level-sensitive, the
> controller knows that the interrupt is still firing, and if you unmask
> the interrupt while the signal is high, it will fire again.
>
> Edge sensitive means that the interrupt only fires on a transition (low
> to high for positive, high to low for negative).  Thus you don't have
> to worry about clearing the interrupt before unmasking it.
>
> I'm not sure if that's clear, but to summarize: Level and edge are
> descriptions of how the interrupt is detected (by the "level" of the
> interrupt, or by a transition *to* that level).  As for where to find
> out which it is, the manual for the device should specify whether the
> interrupt signal is level or edge sensitive.

Err, i suppose the interesting bit is not how the board designer will
know wheter the interrupt is edge or level, but how the kernel running
on the board is able to detect it ?

Friendly,

Sven Luther

** Sent via the linuxppc-dev mail list. See http://lists.linuxppc.org/





More information about the Linuxppc-dev mailing list