]> pilppa.org Git - linux-2.6-omap-h63xx.git/blobdiff - arch/sh64/kernel/irq.c
Merge branch 'upstream-jeff' of git://git.kernel.org/pub/scm/linux/kernel/git/romieu...
[linux-2.6-omap-h63xx.git] / arch / sh64 / kernel / irq.c
index e7e07f8749c9907567ff8a83053b45f2577eea61..9412b7166700307343c4fbca7e3d895a37a6c7d6 100644 (file)
@@ -26,7 +26,6 @@
 #include <linux/slab.h>
 #include <linux/random.h>
 #include <linux/smp.h>
-#include <linux/smp_lock.h>
 #include <linux/init.h>
 #include <linux/seq_file.h>
 #include <linux/bitops.h>
@@ -95,6 +94,7 @@ asmlinkage void do_NMI(unsigned long vector_num, struct pt_regs * regs)
  */
 asmlinkage int do_IRQ(unsigned long vector_num, struct pt_regs * regs)
 {
+       struct pt_regs *old_regs = set_irq_regs(regs);
        int irq;
 
        irq_enter();
@@ -102,13 +102,14 @@ asmlinkage int do_IRQ(unsigned long vector_num, struct pt_regs * regs)
        irq = irq_demux(vector_num);
 
        if (irq >= 0) {
-               __do_IRQ(irq, regs);
+               __do_IRQ(irq);
        } else {
                printk("unexpected IRQ trap at vector %03lx\n", vector_num);
        }
 
        irq_exit();
 
+       set_irq_regs(old_regs);
        return 1;
 }