Interrupt Management
During 2.1 development, some of the Linux internals were changed. New kernels offer good management of internal locks; race conditions are avoided using several fine-grained locks instead of global ones, thus obtaining better performance--especially with SMP configurations.
One of the outcomes of finer locking is that intr_count
no longer exists. Version 2.1.34 got rid of the global variable,
and the boolean function in_interrupt can be used instead (this
function has existed since 2.1.30). Currently, in_interrupt is a
macro declared in the header <asm/hardirq.h>
, which in turn is
included by <linux/interrupt.h>
. The header sysdep-2.1.h
conditionally defines in_interrupt in terms of intr_count
to achieve backward portability to 2.0.
Note that while in_interrupt is an integer, intr_count
was unsigned long
, so if you want to print the value and be
portable across 2.0 and 2.1, you should cast the value to an explicit type
and specify the suitable format in calling printk.
Another difference in interrupt management was introduced in
2.1.37: fast and slow interrupt handlers don’t exist any more. The
flag SA_INTERRUPT
isn’t used by the new version of
request_irq, but it still controls whether interrupts are enabled before the handler is executed. If several handlers share the interrupt line, each can be of a different ``type.'' Interrupts are enabled or not according to the type of the first handler being called. Bottom halves are always executed when the interrupt ...
Get Linux Device Drivers now with the O’Reilly learning platform.
O’Reilly members experience books, live events, courses curated by job role, and more from O’Reilly and nearly 200 top publishers.