diff options
author | Paul Mackerras <paulus@samba.org> | 2012-06-15 14:51:39 +1000 |
---|---|---|
committer | Paul Mackerras <paulus@samba.org> | 2012-06-15 15:27:41 +1000 |
commit | f948501b36c6b3d9352ce212a197098a7e958971 (patch) | |
tree | 2b0d0448fc0f5dd52658caacbf6fcad02e7e784c | |
parent | cfaf025112d3856637ff34a767ef785ef5cf2ca9 (diff) | |
download | blackbird-op-linux-f948501b36c6b3d9352ce212a197098a7e958971.tar.gz blackbird-op-linux-f948501b36c6b3d9352ce212a197098a7e958971.zip |
Make hard_irq_disable() actually hard-disable interrupts
At present, hard_irq_disable() does nothing on powerpc because of
this code in include/linux/interrupt.h:
#ifndef hard_irq_disable
#define hard_irq_disable() do { } while(0)
#endif
So we need to make our hard_irq_disable be a macro. It was previously
a macro until commit 7230c56441 ("powerpc: Rework lazy-interrupt
handling") changed it to a static inline function.
Cc: stable@vger.kernel.org
Acked-by: Benjamin Herrenschmidt <benh@kernel.crashing.org>
Signed-off-by: Paul Mackerras <paulus@samba.org>
--
arch/powerpc/include/asm/hw_irq.h | 3 +++
1 file changed, 3 insertions(+)
-rw-r--r-- | arch/powerpc/include/asm/hw_irq.h | 3 |
1 files changed, 3 insertions, 0 deletions
diff --git a/arch/powerpc/include/asm/hw_irq.h b/arch/powerpc/include/asm/hw_irq.h index c9aac24b02e2..32b394f3b854 100644 --- a/arch/powerpc/include/asm/hw_irq.h +++ b/arch/powerpc/include/asm/hw_irq.h @@ -100,6 +100,9 @@ static inline void hard_irq_disable(void) get_paca()->irq_happened |= PACA_IRQ_HARD_DIS; } +/* include/linux/interrupt.h needs hard_irq_disable to be a macro */ +#define hard_irq_disable hard_irq_disable + /* * This is called by asynchronous interrupts to conditionally * re-enable hard interrupts when soft-disabled after having |