Commit 6ebcc00e authored by Jan Beulich's avatar Jan Beulich Committed by Linus Torvalds

[PATCH] i386/x86-64: simplify ioapic_register_intr()

Simplify (remove duplication of) code in ioapic_register_intr().
Signed-off-by: default avatarJan Beulich <jbeulich@novell.com>
Signed-off-by: default avatarAndi Kleen <ak@suse.de>
Signed-off-by: default avatarLinus Torvalds <torvalds@osdl.org>
parent 0a1ad60d
...@@ -1205,21 +1205,14 @@ static struct hw_interrupt_type ioapic_edge_type; ...@@ -1205,21 +1205,14 @@ static struct hw_interrupt_type ioapic_edge_type;
static inline void ioapic_register_intr(int irq, int vector, unsigned long trigger) static inline void ioapic_register_intr(int irq, int vector, unsigned long trigger)
{ {
if (use_pci_vector() && !platform_legacy_irq(irq)) { unsigned idx = use_pci_vector() && !platform_legacy_irq(irq) ? vector : irq;
if ((trigger == IOAPIC_AUTO && IO_APIC_irq_trigger(irq)) ||
trigger == IOAPIC_LEVEL)
irq_desc[vector].handler = &ioapic_level_type;
else
irq_desc[vector].handler = &ioapic_edge_type;
set_intr_gate(vector, interrupt[vector]);
} else {
if ((trigger == IOAPIC_AUTO && IO_APIC_irq_trigger(irq)) || if ((trigger == IOAPIC_AUTO && IO_APIC_irq_trigger(irq)) ||
trigger == IOAPIC_LEVEL) trigger == IOAPIC_LEVEL)
irq_desc[irq].handler = &ioapic_level_type; irq_desc[idx].handler = &ioapic_level_type;
else else
irq_desc[irq].handler = &ioapic_edge_type; irq_desc[idx].handler = &ioapic_edge_type;
set_intr_gate(vector, interrupt[irq]); set_intr_gate(vector, interrupt[idx]);
}
} }
static void __init setup_IO_APIC_irqs(void) static void __init setup_IO_APIC_irqs(void)
......
...@@ -876,21 +876,14 @@ static struct hw_interrupt_type ioapic_edge_type; ...@@ -876,21 +876,14 @@ static struct hw_interrupt_type ioapic_edge_type;
static inline void ioapic_register_intr(int irq, int vector, unsigned long trigger) static inline void ioapic_register_intr(int irq, int vector, unsigned long trigger)
{ {
if (use_pci_vector() && !platform_legacy_irq(irq)) { unsigned idx = use_pci_vector() && !platform_legacy_irq(irq) ? vector : irq;
if ((trigger == IOAPIC_AUTO && IO_APIC_irq_trigger(irq)) ||
trigger == IOAPIC_LEVEL)
irq_desc[vector].handler = &ioapic_level_type;
else
irq_desc[vector].handler = &ioapic_edge_type;
set_intr_gate(vector, interrupt[vector]);
} else {
if ((trigger == IOAPIC_AUTO && IO_APIC_irq_trigger(irq)) || if ((trigger == IOAPIC_AUTO && IO_APIC_irq_trigger(irq)) ||
trigger == IOAPIC_LEVEL) trigger == IOAPIC_LEVEL)
irq_desc[irq].handler = &ioapic_level_type; irq_desc[idx].handler = &ioapic_level_type;
else else
irq_desc[irq].handler = &ioapic_edge_type; irq_desc[idx].handler = &ioapic_edge_type;
set_intr_gate(vector, interrupt[irq]); set_intr_gate(vector, interrupt[idx]);
}
} }
static void __init setup_IO_APIC_irqs(void) static void __init setup_IO_APIC_irqs(void)
......
Markdown is supported
0%
or
You are about to add 0 people to the discussion. Proceed with caution.
Finish editing this message first!
Please register or to comment