From 2501814ee91a30ab6f12a02356707db3b9cc67f4 Mon Sep 17 00:00:00 2001 From: Jiri Gaisler Date: Sun, 23 Nov 2014 22:53:00 +0100 Subject: sparc/leon2: LEON_Is_interrupt_masked for Leon2 in leon.h wrongly defined Condition needs to be inverted, as a 1 in the mask register means that the interrupt is enabled. Solves ticket #1959 in trac. --- c/src/lib/libbsp/sparc/leon2/include/leon.h | 2 +- 1 file changed, 1 insertion(+), 1 deletion(-) diff --git a/c/src/lib/libbsp/sparc/leon2/include/leon.h b/c/src/lib/libbsp/sparc/leon2/include/leon.h index 8d2f0c5c55..7ec6b1dcf9 100644 --- a/c/src/lib/libbsp/sparc/leon2/include/leon.h +++ b/c/src/lib/libbsp/sparc/leon2/include/leon.h @@ -307,7 +307,7 @@ static __inline__ int bsp_irq_fixup(int irq) (LEON_REG.Interrupt_Pending & (1 << (_source))) #define LEON_Is_interrupt_masked( _source ) \ - (LEON_REG.Interrupt_Masked & (1 << (_source))) + (!(LEON_REG.Interrupt_Mask & (1 << (_source)))) #define LEON_Mask_interrupt( _source ) \ do { \ -- cgit v1.2.3