From 4d249b9fed4deb45a70c6494f2c8905c237c49c4 Mon Sep 17 00:00:00 2001 From: Daniel Hellstrom Date: Mon, 19 Nov 2012 17:41:15 +0100 Subject: GPTIMER: support separate & shared irq by clearing pending bit after ISR --- c/src/lib/libbsp/sparc/shared/timer/gptimer.c | 8 +++++--- 1 file changed, 5 insertions(+), 3 deletions(-) diff --git a/c/src/lib/libbsp/sparc/shared/timer/gptimer.c b/c/src/lib/libbsp/sparc/shared/timer/gptimer.c index 2314a3b236..6a7e835f74 100644 --- a/c/src/lib/libbsp/sparc/shared/timer/gptimer.c +++ b/c/src/lib/libbsp/sparc/shared/timer/gptimer.c @@ -400,14 +400,16 @@ void gptimer_isr(void *data) /* Check all timers for IRQ */ for (i=0;itimer_cnt; i++) { - if (gptimer_tlib_int_pend((void *)&priv->timers[i], 1)) { - /* IRQ Was generated by Timer and Pending flag has been - * cleared. Call ISR registered + if (gptimer_tlib_int_pend((void *)&priv->timers[i], 0)) { + /* IRQ Was generated by Timer and Pending flag has *not* + * yet been cleared, this is to allow ISR to look at + * pending bit. Call ISR registered. Clear pending bit. */ if (priv->timers[i].tdev.isr_func) { priv->timers[i].tdev.isr_func( priv->timers[i].tdev.isr_data); } + gptimer_tlib_int_pend((void *)&priv->timers[i], 1); } } } -- cgit v1.2.3