]> git.karo-electronics.de Git - karo-tx-linux.git/blobdiff - arch/x86/kernel/irqinit_64.c
x86: unify init_ISA_irqs() in irqinit_{32,64}.c
[karo-tx-linux.git] / arch / x86 / kernel / irqinit_64.c
index 8cd10537fd46f7480b6db9807db276ada5b390af..61c9a922e80cfb7512bcc69a3e84d4ba1bdeeaf6 100644 (file)
@@ -84,9 +84,14 @@ static void __init init_ISA_irqs(void)
 {
        int i;
 
+#if defined(CONFIG_X86_64) || defined(CONFIG_X86_LOCAL_APIC)
        init_bsp_APIC();
+#endif
        init_8259A(0);
 
+       /*
+        * 16 old-style INTA-cycle interrupts:
+        */
        for (i = 0; i < NR_IRQS_LEGACY; i++) {
                struct irq_desc *desc = irq_to_desc(i);
 
@@ -94,11 +99,8 @@ static void __init init_ISA_irqs(void)
                desc->action = NULL;
                desc->depth = 1;
 
-               /*
-                * 16 old-style INTA-cycle interrupts:
-                */
                set_irq_chip_and_handler_name(i, &i8259A_chip,
-                                                     handle_level_irq, "XT");
+                                             handle_level_irq, "XT");
        }
 }
 
@@ -107,6 +109,7 @@ void init_IRQ(void) __attribute__((weak, alias("native_init_IRQ")));
 static void __init smp_intr_init(void)
 {
 #ifdef CONFIG_SMP
+#if defined(CONFIG_X86_64) || defined(CONFIG_X86_LOCAL_APIC)
        /*
         * The reschedule interrupt is a CPU-to-CPU reschedule-helper
         * IPI, driven by wakeup.
@@ -134,6 +137,7 @@ static void __init smp_intr_init(void)
        set_intr_gate(IRQ_MOVE_CLEANUP_VECTOR, irq_move_cleanup_interrupt);
        set_bit(IRQ_MOVE_CLEANUP_VECTOR, used_vectors);
 #endif
+#endif /* CONFIG_SMP */
 }
 
 static void __init apic_intr_init(void)
@@ -159,15 +163,16 @@ void __init native_init_IRQ(void)
        int i;
 
        init_ISA_irqs();
+
        /*
         * Cover the whole vector space, no vector can escape
         * us. (some of these will be overridden and become
         * 'special' SMP interrupts)
         */
-       for (i = 0; i < (NR_VECTORS - FIRST_EXTERNAL_VECTOR); i++) {
-               int vector = FIRST_EXTERNAL_VECTOR + i;
-               if (vector != IA32_SYSCALL_VECTOR)
-                       set_intr_gate(vector, interrupt[i]);
+       for (i = FIRST_EXTERNAL_VECTOR; i < NR_VECTORS; i++) {
+               /* IA32_SYSCALL_VECTOR was reserved in trap_init. */
+               if (i != IA32_SYSCALL_VECTOR)
+                       set_intr_gate(i, interrupt[i-FIRST_EXTERNAL_VECTOR]);
        }
 
        apic_intr_init();