]> Pileus Git - ~andy/linux/blobdiff - arch/ia64/kernel/irq.c
EFI: warn only for pre-1.00 system tables
[~andy/linux] / arch / ia64 / kernel / irq.c
index c4e1b3b60b48b95adf010ff67f804e7746bc23c4..ce49c85c928f5fe44f52501c86211b11926c89d8 100644 (file)
@@ -76,7 +76,7 @@ int show_interrupts(struct seq_file *p, void *v)
                        seq_printf(p, "%10u ", kstat_cpu(j).irqs[i]);
                }
 #endif
-               seq_printf(p, " %14s", irq_desc[i].chip->typename);
+               seq_printf(p, " %14s", irq_desc[i].chip->name);
                seq_printf(p, "  %s", action->name);
 
                for (action=action->next; action; action = action->next)
@@ -120,7 +120,10 @@ static void migrate_irqs(void)
        int             irq, new_cpu;
 
        for (irq=0; irq < NR_IRQS; irq++) {
-               desc = irq_descp(irq);
+               desc = irq_desc + irq;
+
+               if (desc->status == IRQ_DISABLED)
+                       continue;
 
                /*
                 * No handling for now.
@@ -194,8 +197,11 @@ void fixup_irqs(void)
         */
        for (irq=0; irq < NR_IRQS; irq++) {
                if (vectors_in_migration[irq]) {
+                       struct pt_regs *old_regs = set_irq_regs(NULL);
+
                        vectors_in_migration[irq]=0;
-                       __do_IRQ(irq, NULL);
+                       generic_handle_irq(irq);
+                       set_irq_regs(old_regs);
                }
        }