Don't call a NULL ack function in the generic IRQ code.

Some IRQ controllers don't need an ack function (e.g. OpenPIC on
PPC platforms) and for them we'd rather not have the overhead
of doing an indirect call to a function that does nothing.

Signed-off-by: Paul Mackerras <paulus@samba.org>
This commit is contained in:
Paul Mackerras 2005-09-28 20:29:44 +10:00
parent 20c8c21063
commit beeca08738

View File

@ -117,6 +117,7 @@ fastcall unsigned int __do_IRQ(unsigned int irq, struct pt_regs *regs)
/* /*
* No locking required for CPU-local interrupts: * No locking required for CPU-local interrupts:
*/ */
if (desc->handler->ack)
desc->handler->ack(irq); desc->handler->ack(irq);
action_ret = handle_IRQ_event(irq, regs, desc->action); action_ret = handle_IRQ_event(irq, regs, desc->action);
desc->handler->end(irq); desc->handler->end(irq);
@ -124,6 +125,7 @@ fastcall unsigned int __do_IRQ(unsigned int irq, struct pt_regs *regs)
} }
spin_lock(&desc->lock); spin_lock(&desc->lock);
if (desc->handler->ack)
desc->handler->ack(irq); desc->handler->ack(irq);
/* /*
* REPLAY is when Linux resends an IRQ that was dropped earlier * REPLAY is when Linux resends an IRQ that was dropped earlier