Skip to content

Commit

Permalink
[MIPS] Misc fixes for plat_irq_dispatch functions
Browse files Browse the repository at this point in the history
 o adds missing ST0_IM masks, which caused the logging of valid interrupts
   as spurious
 o stops pnx8550 to log every interrupt as spurious
 o adds cause register masks for ip22/ip32, which caused handling of masked
   interrupts
 o removes some superfluous parentheses in the SNI interrupt code

Signed-Off-By: Thiemo Seufer <ths@networkno.de>
Signed-off-by: Ralf Baechle <ralf@linux-mips.org>
  • Loading branch information
Thiemo Seufer authored and Ralf Baechle committed Mar 19, 2007
1 parent 72ede9b commit 119537c
Show file tree
Hide file tree
Showing 13 changed files with 16 additions and 17 deletions.
2 changes: 1 addition & 1 deletion arch/mips/ddb5xxx/ddb5477/irq.c
Original file line number Diff line number Diff line change
Expand Up @@ -194,7 +194,7 @@ static void vrc5477_irq_dispatch(void)

asmlinkage void plat_irq_dispatch(void)
{
unsigned int pending = read_c0_cause() & read_c0_status();
unsigned int pending = read_c0_cause() & read_c0_status() & ST0_IM;

if (pending & STATUSF_IP7)
do_IRQ(CPU_IRQ_BASE + 7);
Expand Down
2 changes: 1 addition & 1 deletion arch/mips/emma2rh/markeins/irq.c
Original file line number Diff line number Diff line change
Expand Up @@ -115,7 +115,7 @@ void __init arch_init_irq(void)

asmlinkage void plat_irq_dispatch(void)
{
unsigned int pending = read_c0_status() & read_c0_cause();
unsigned int pending = read_c0_status() & read_c0_cause() & ST0_IM;

if (pending & STATUSF_IP7)
do_IRQ(CPU_IRQ_BASE + 7);
Expand Down
2 changes: 1 addition & 1 deletion arch/mips/gt64120/ev64120/irq.c
Original file line number Diff line number Diff line change
Expand Up @@ -48,7 +48,7 @@

asmlinkage void plat_irq_dispatch(void)
{
unsigned int pending = read_c0_status() & read_c0_cause();
unsigned int pending = read_c0_status() & read_c0_cause() & ST0_IM;

if (pending & STATUSF_IP4) /* int2 hardware line (timer) */
do_IRQ(4);
Expand Down
2 changes: 1 addition & 1 deletion arch/mips/gt64120/wrppmc/irq.c
Original file line number Diff line number Diff line change
Expand Up @@ -32,7 +32,7 @@

asmlinkage void plat_irq_dispatch(void)
{
unsigned int pending = read_c0_status() & read_c0_cause();
unsigned int pending = read_c0_status() & read_c0_cause() & ST0_IM;

if (pending & STATUSF_IP7)
do_IRQ(WRPPMC_MIPS_TIMER_IRQ); /* CPU Compare/Count internal timer */
Expand Down
2 changes: 1 addition & 1 deletion arch/mips/jazz/irq.c
Original file line number Diff line number Diff line change
Expand Up @@ -122,7 +122,7 @@ static void ll_local_dev(void)

asmlinkage void plat_irq_dispatch(void)
{
unsigned int pending = read_c0_cause() & read_c0_status() & ST0_IM;
unsigned int pending = read_c0_cause() & read_c0_status();

if (pending & IE_IRQ5)
write_c0_compare(0);
Expand Down
2 changes: 1 addition & 1 deletion arch/mips/momentum/ocelot_c/irq.c
Original file line number Diff line number Diff line change
Expand Up @@ -64,7 +64,7 @@ extern void ll_cpci_irq(void);

asmlinkage void plat_irq_dispatch(void)
{
unsigned int pending = read_c0_cause() & read_c0_status();
unsigned int pending = read_c0_cause() & read_c0_status() & ST0_IM;

if (pending & STATUSF_IP0)
do_IRQ(0);
Expand Down
7 changes: 3 additions & 4 deletions arch/mips/philips/pnx8550/common/int.c
Original file line number Diff line number Diff line change
Expand Up @@ -83,16 +83,15 @@ static void timer_irqdispatch(int irq)

asmlinkage void plat_irq_dispatch(void)
{
unsigned int pending = read_c0_status() & read_c0_cause();
unsigned int pending = read_c0_status() & read_c0_cause() & ST0_IM;

if (pending & STATUSF_IP2)
hw0_irqdispatch(2);
else if (pending & STATUSF_IP7) {
if (read_c0_config7() & 0x01c0)
timer_irqdispatch(7);
}

spurious_interrupt();
} else
spurious_interrupt();
}

static inline void modify_cp0_intmask(unsigned clr_mask, unsigned set_mask)
Expand Down
2 changes: 1 addition & 1 deletion arch/mips/sgi-ip22/ip22-int.c
Original file line number Diff line number Diff line change
Expand Up @@ -237,7 +237,7 @@ extern void indy_8254timer_irq(void);

asmlinkage void plat_irq_dispatch(void)
{
unsigned int pending = read_c0_cause();
unsigned int pending = read_c0_status() & read_c0_cause();

/*
* First we check for r4k counter/timer IRQ.
Expand Down
2 changes: 1 addition & 1 deletion arch/mips/sgi-ip32/ip32-irq.c
Original file line number Diff line number Diff line change
Expand Up @@ -454,7 +454,7 @@ static void ip32_irq5(void)

asmlinkage void plat_irq_dispatch(void)
{
unsigned int pending = read_c0_cause();
unsigned int pending = read_c0_status() & read_c0_cause();

if (likely(pending & IE_IRQ0))
ip32_irq0();
Expand Down
2 changes: 1 addition & 1 deletion arch/mips/sibyte/sb1250/irq.c
Original file line number Diff line number Diff line change
Expand Up @@ -421,7 +421,7 @@ asmlinkage void plat_irq_dispatch(void)
* blasting the high 32 bits.
*/

pending = read_c0_cause() & read_c0_status();
pending = read_c0_cause() & read_c0_status() & ST0_IM;

#ifdef CONFIG_SIBYTE_SB1250_PROF
if (pending & CAUSEF_IP7) /* Cpu performance counter interrupt */
Expand Down
2 changes: 1 addition & 1 deletion arch/mips/sni/pcimt.c
Original file line number Diff line number Diff line change
Expand Up @@ -333,7 +333,7 @@ static void pcimt_hwint3(void)

static void sni_pcimt_hwint(void)
{
u32 pending = (read_c0_cause() & read_c0_status());
u32 pending = read_c0_cause() & read_c0_status();

if (pending & C_IRQ5)
do_IRQ (MIPS_CPU_IRQ_BASE + 7);
Expand Down
4 changes: 2 additions & 2 deletions arch/mips/sni/pcit.c
Original file line number Diff line number Diff line change
Expand Up @@ -271,7 +271,7 @@ static void pcit_hwint0(void)

static void sni_pcit_hwint(void)
{
u32 pending = (read_c0_cause() & read_c0_status());
u32 pending = read_c0_cause() & read_c0_status();

if (pending & C_IRQ1)
pcit_hwint1();
Expand All @@ -285,7 +285,7 @@ static void sni_pcit_hwint(void)

static void sni_pcit_hwint_cplus(void)
{
u32 pending = (read_c0_cause() & read_c0_status());
u32 pending = read_c0_cause() & read_c0_status();

if (pending & C_IRQ0)
pcit_hwint0();
Expand Down
2 changes: 1 addition & 1 deletion arch/mips/tx4927/common/tx4927_irq.c
Original file line number Diff line number Diff line change
Expand Up @@ -416,7 +416,7 @@ static int tx4927_irq_nested(void)

asmlinkage void plat_irq_dispatch(void)
{
unsigned int pending = read_c0_status() & read_c0_cause();
unsigned int pending = read_c0_status() & read_c0_cause() & ST0_IM;

if (pending & STATUSF_IP7) /* cpu timer */
do_IRQ(TX4927_IRQ_CPU_TIMER);
Expand Down

0 comments on commit 119537c

Please sign in to comment.