Re: [patch, -rc5-mm1] genirq MSI fixes

From: Benjamin Herrenschmidt
Date: Wed May 31 2006 - 02:39:57 EST


On Wed, 2006-05-31 at 08:15 +0200, Ingo Molnar wrote:
> this is a fixed up and cleaned up replacement for
> genirq-msi-fixes.patch, which should solve the i386 4KSTACKS problem. I
> also added Ben's idea of pushing the __do_IRQ() check into
> generic_handle_irq().
>
> i booted this with MSI enabled, but i only have MSI devices, not MSI-X
> devices. I'd still expect MSI-X to work now.

Looks good except the likely statement in generic_handle_irq() :) I'd
let the CPU speculate here and not try to influence the choice... but
heh... I understand why you want to "favor" the new scheme :)

Ben.

> --------------
> Subject: genirq-msi-fixes
> From: Ingo Molnar <mingo@xxxxxxx>
>
> irqchip migration helper: call __do_IRQ() if a descriptor is attached
> to an irqtype-style controller. This also fixes MSI-X IRQ handling on
> i386 and x86_64.
>
> Signed-off-by: Ingo Molnar <mingo@xxxxxxx>
> ---
>
> arch/i386/kernel/irq.c | 5 +++++
> include/linux/irq.h | 27 ++++++++++++++++-----------
> 2 files changed, 21 insertions(+), 11 deletions(-)
>
> Index: linux/arch/i386/kernel/irq.c
> ===================================================================
> --- linux.orig/arch/i386/kernel/irq.c
> +++ linux/arch/i386/kernel/irq.c
> @@ -77,6 +77,10 @@ fastcall unsigned int do_IRQ(struct pt_r
> }
> #endif
>
> + if (!irq_desc[irq].handle_irq) {
> + __do_IRQ(irq, regs);
> + goto out_exit;
> + }
> #ifdef CONFIG_4KSTACKS
>
> curctx = (union irq_ctx *) current_thread_info();
> @@ -109,6 +113,7 @@ fastcall unsigned int do_IRQ(struct pt_r
> #endif
> desc->handle_irq(irq, desc, regs);
>
> +out_exit:
> irq_exit();
>
> return 1;
> Index: linux/include/linux/irq.h
> ===================================================================
> --- linux.orig/include/linux/irq.h
> +++ linux/include/linux/irq.h
> @@ -176,17 +176,6 @@ typedef struct irq_desc irq_desc_t;
> */
> #include <asm/hw_irq.h>
>
> -/*
> - * Architectures call this to let the generic IRQ layer
> - * handle an interrupt:
> - */
> -static inline void generic_handle_irq(unsigned int irq, struct pt_regs *regs)
> -{
> - struct irq_desc *desc = irq_desc + irq;
> -
> - desc->handle_irq(irq, desc, regs);
> -}
> -
> extern int setup_irq(unsigned int irq, struct irqaction *new);
>
> #ifdef CONFIG_GENERIC_HARDIRQS
> @@ -324,6 +313,22 @@ handle_irq_name(void fastcall (*handle)(
> */
> extern fastcall unsigned int __do_IRQ(unsigned int irq, struct pt_regs *regs);
>
> +/*
> + * Architectures call this to let the generic IRQ layer
> + * handle an interrupt. If the descriptor is attached to an
> + * irqchip-style controller then we call the ->handle_irq() handler,
> + * and it calls __do_IRQ() if it's attached to an irqtype-style controller.
> + */
> +static inline void generic_handle_irq(unsigned int irq, struct pt_regs *regs)
> +{
> + struct irq_desc *desc = irq_desc + irq;
> +
> + if (likely(desc->handle_irq))
> + desc->handle_irq(irq, desc, regs);
> + else
> + __do_IRQ(irq, regs);
> +}
> +
> /* Handling of unhandled and spurious interrupts: */
> extern void note_interrupt(unsigned int irq, struct irq_desc *desc,
> int action_ret, struct pt_regs *regs);

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