[MIPS] Fix the build error of Wind River PPMC board, rewrite irq code to C
authorMark.Zhan <rongkai.zhan@windriver.com>
Tue, 20 Jun 2006 10:15:02 +0000 (18:15 +0800)
committerRalf Baechle <ralf@linux-mips.org>
Thu, 29 Jun 2006 20:10:34 +0000 (21:10 +0100)
 o Fix the build error Wind River PPMC board caused by the change of
   plat_setup hook interface.
 o Rewrite first level interrupt dispatch code to C.

Signed-off-by: Rongkai.Zhan <rongkai.zhan@windriver.com>
Signed-off-by: Ralf Baechle <ralf@linux-mips.org>
arch/mips/Kconfig
arch/mips/gt64120/wrppmc/Makefile
arch/mips/gt64120/wrppmc/int-handler.S [deleted file]
arch/mips/gt64120/wrppmc/irq.c
arch/mips/gt64120/wrppmc/setup.c

index 35e038a974c6227940cc4ebe7c5ead85d52e4a65..3fa67af8725d95e5f530389f86cc7bb26a65193a 100644 (file)
@@ -358,7 +358,7 @@ config MIPS_SEAD
          board.
 
 config WR_PPMC
-       bool "Support for Wind River PPMC board"
+       bool "Wind River PPMC board"
        select IRQ_CPU
        select BOOT_ELF32
        select DMA_NONCOHERENT
index 72606b9af12a929f892acb7ebff4884c46b3a555..7cf52205511ccad299507a650188fb223fbef919 100644 (file)
@@ -9,6 +9,6 @@
 # Makefile for the Wind River MIPS 4KC PPMC Eval Board
 #
 
-obj-y  += int-handler.o irq.o reset.o setup.o time.o pci.o
+obj-y += irq.o reset.o setup.o time.o pci.o
 
 EXTRA_AFLAGS := $(CFLAGS)
diff --git a/arch/mips/gt64120/wrppmc/int-handler.S b/arch/mips/gt64120/wrppmc/int-handler.S
deleted file mode 100644 (file)
index edee7b3..0000000
+++ /dev/null
@@ -1,59 +0,0 @@
-/*
- * This file is subject to the terms and conditions of the GNU General Public
- * License.  See the file "COPYING" in the main directory of this archive
- * for more details.
- *
- * Copyright (C) 1995, 1996, 1997, 2003 by Ralf Baechle
- * Copyright (C) Wind River System Inc. Rongkai.Zhan <rongkai.zhan@windriver.com>
- */
-#include <asm/asm.h>
-#include <asm/mipsregs.h>
-#include <asm/addrspace.h>
-#include <asm/regdef.h>
-#include <asm/stackframe.h>
-#include <asm/mach-wrppmc/mach-gt64120.h>
-
-       .align  5
-       .set    noat
-NESTED(handle_IRQ, PT_SIZE, sp)
-       SAVE_ALL
-       CLI                             # Important: mark KERNEL mode !
-       .set    at
-
-       mfc0    t0, CP0_CAUSE           # get pending interrupts
-       mfc0    t1, CP0_STATUS          # get enabled interrupts
-       and     t0, t0, t1              # get allowed interrupts
-       andi    t0, t0, 0xFF00
-       beqz    t0, 1f
-       move    a1, sp                  # Prepare 'struct pt_regs *regs' pointer
-
-       andi    t1, t0, CAUSEF_IP7      # CPU Compare/Count internal timer
-       bnez    t1, handle_cputimer_irq
-       andi    t1, t0, CAUSEF_IP6      # UART 16550 port
-       bnez    t1, handle_uart_irq
-       andi    t1, t0, CAUSEF_IP3      # PCI INT_A
-       bnez    t1, handle_pci_intA_irq
-
-       /* wrong alarm or masked ... */
-1:     j       spurious_interrupt
-       nop
-END(handle_IRQ)
-
-       .align  5
-handle_cputimer_irq:
-       li      a0, WRPPMC_MIPS_TIMER_IRQ
-       jal     do_IRQ
-       j       ret_from_irq
-
-       .align  5
-handle_uart_irq:
-       li      a0, WRPPMC_UART16550_IRQ
-       jal     do_IRQ
-       j       ret_from_irq
-
-       .align  5
-handle_pci_intA_irq:
-       li      a0, WRPPMC_PCI_INTA_IRQ
-       jal     do_IRQ
-       j       ret_from_irq
-
index 8605687e24eda75160c5ee1f329d230fdd00b13f..26cf360f16942faf505c5a26ff86518cd106db9e 100644 (file)
 #include <asm/irq_cpu.h>
 #include <asm/gt64120.h>
 
-extern asmlinkage void handle_IRQ(void);
+asmlinkage void plat_irq_dispatch(struct pt_regs *regs)
+{
+       unsigned int pending = read_c0_status() & read_c0_cause();
+
+       if (pending & STATUSF_IP7)
+               do_IRQ(WRPPMC_MIPS_TIMER_IRQ, regs);    /* CPU Compare/Count internal timer */
+       else if (pending & STATUSF_IP6)
+               do_IRQ(WRPPMC_UART16550_IRQ, regs);     /* UART 16550 port */
+       else if (pending & STATUSF_IP3)
+               do_IRQ(WRPPMC_PCI_INTA_IRQ, regs);      /* PCI INT_A */
+       else
+               spurious_interrupt(regs);
+}
 
 /**
  * Initialize GT64120 Interrupt Controller
@@ -53,9 +65,6 @@ void __init arch_init_irq(void)
        /* enable all CPU interrupt bits. */
        set_c0_status(ST0_IM);  /* IE bit is still 0 */
 
-       /* Install MIPS Interrupt Trap Vector */
-       set_except_vector(0, handle_IRQ);
-
        /* IRQ 0 - 7 are for MIPS common irq_cpu controller */
        mips_cpu_irq_init(0);
 
index 20c591e49dae38a6ab7bf2d5889a6e159725d321..2db6375ef29e5bd518d1338eee1b14363be609e3 100644 (file)
@@ -125,7 +125,7 @@ static void wrppmc_setup_serial(void)
 }
 #endif
 
-void __init plat_setup(void)
+void __init plat_mem_setup(void)
 {
        extern void wrppmc_time_init(void);
        extern void wrppmc_timer_setup(struct irqaction *);