summaryrefslogtreecommitdiffstats
path: root/arch/blackfin/mach-common
diff options
context:
space:
mode:
Diffstat (limited to 'arch/blackfin/mach-common')
-rw-r--r--arch/blackfin/mach-common/ints-priority.c25
1 files changed, 8 insertions, 17 deletions
diff --git a/arch/blackfin/mach-common/ints-priority.c b/arch/blackfin/mach-common/ints-priority.c
index 43d9fb195c1e..59e0efc98e23 100644
--- a/arch/blackfin/mach-common/ints-priority.c
+++ b/arch/blackfin/mach-common/ints-priority.c
@@ -63,22 +63,19 @@ unsigned long bfin_irq_flags = 0x1f;
EXPORT_SYMBOL(bfin_irq_flags);
#endif
-/* The number of spurious interrupts */
-atomic_t num_spurious;
-
#ifdef CONFIG_PM
unsigned long bfin_sic_iwr[3]; /* Up to 3 SIC_IWRx registers */
unsigned vr_wakeup;
#endif
-struct ivgx {
+static struct ivgx {
/* irq number for request_irq, available in mach-bf5xx/irq.h */
unsigned int irqno;
/* corresponding bit in the SIC_ISR register */
unsigned int isrflag;
} ivg_table[NR_PERI_INTS];
-struct ivg_slice {
+static struct ivg_slice {
/* position of first irq in ivg_table for given ivg */
struct ivgx *ifirst;
struct ivgx *istop;
@@ -1331,10 +1328,8 @@ void do_irq(int vec, struct pt_regs *fp)
sic_status[2] = bfin_read_SIC_ISR2() & bfin_read_SIC_IMASK2();
# endif
for (;; ivg++) {
- if (ivg >= ivg_stop) {
- atomic_inc(&num_spurious);
+ if (ivg >= ivg_stop)
return;
- }
if (sic_status[(ivg->irqno - IVG7) / 32] & ivg->isrflag)
break;
}
@@ -1344,10 +1339,9 @@ void do_irq(int vec, struct pt_regs *fp)
sic_status = bfin_read_SIC_IMASK() & bfin_read_SIC_ISR();
for (;; ivg++) {
- if (ivg >= ivg_stop) {
- atomic_inc(&num_spurious);
+ if (ivg >= ivg_stop)
return;
- } else if (sic_status & ivg->isrflag)
+ if (sic_status & ivg->isrflag)
break;
}
#endif
@@ -1403,10 +1397,8 @@ asmlinkage int __ipipe_grab_irq(int vec, struct pt_regs *regs)
sic_status[2] = bfin_read_SIC_ISR2() & bfin_read_SIC_IMASK2();
# endif
for (;; ivg++) {
- if (ivg >= ivg_stop) {
- atomic_inc(&num_spurious);
+ if (ivg >= ivg_stop)
return 0;
- }
if (sic_status[(ivg->irqno - IVG7) / 32] & ivg->isrflag)
break;
}
@@ -1416,10 +1408,9 @@ asmlinkage int __ipipe_grab_irq(int vec, struct pt_regs *regs)
sic_status = bfin_read_SIC_IMASK() & bfin_read_SIC_ISR();
for (;; ivg++) {
- if (ivg >= ivg_stop) {
- atomic_inc(&num_spurious);
+ if (ivg >= ivg_stop)
return 0;
- } else if (sic_status & ivg->isrflag)
+ if (sic_status & ivg->isrflag)
break;
}
#endif
OpenPOWER on IntegriCloud