]> asedeno.scripts.mit.edu Git - linux.git/commitdiff
powerpc: Add new kconfig CONFIG_PPC_IRQ_SOFT_MASK_DEBUG
authorMadhavan Srinivasan <maddy@linux.vnet.ibm.com>
Wed, 20 Dec 2017 03:55:54 +0000 (09:25 +0530)
committerMichael Ellerman <mpe@ellerman.id.au>
Fri, 19 Jan 2018 11:37:03 +0000 (22:37 +1100)
New Kconfig is added "CONFIG_PPC_IRQ_SOFT_MASK_DEBUG" to add WARN_ON
to alert the invalid transitions. Also moved the code under the
CONFIG_TRACE_IRQFLAGS in arch_local_irq_restore() to new Kconfig.

Reviewed-by: Nicholas Piggin <npiggin@gmail.com>
Signed-off-by: Madhavan Srinivasan <maddy@linux.vnet.ibm.com>
[mpe: Fix name of CONFIG option in change log]
Signed-off-by: Michael Ellerman <mpe@ellerman.id.au>
arch/powerpc/Kconfig.debug
arch/powerpc/include/asm/hw_irq.h
arch/powerpc/kernel/entry_64.S
arch/powerpc/kernel/irq.c

index 5d18169fff58cc1060511270606ff4b7830752f6..c45424c64e1963c3017981a601fb558be6686269 100644 (file)
@@ -90,6 +90,10 @@ config MSI_BITMAP_SELFTEST
        depends on DEBUG_KERNEL
        default n
 
+config PPC_IRQ_SOFT_MASK_DEBUG
+       bool "Include extra checks for powerpc irq soft masking"
+       default n
+
 config XMON
        bool "Include xmon kernel debugger"
        depends on DEBUG_KERNEL
index 552a2c6e428fea7b5699f96058aacf84bbeffdc5..f40da3bd079bd161f46659875a08f223e838b274 100644 (file)
@@ -71,7 +71,7 @@ static inline notrace unsigned long irq_soft_mask_return(void)
  */
 static inline notrace void irq_soft_mask_set(unsigned long mask)
 {
-#ifdef CONFIG_TRACE_IRQFLAGS
+#ifdef CONFIG_PPC_IRQ_SOFT_MASK_DEBUG
        /*
         * The irq mask must always include the STD bit if any are set.
         *
@@ -101,7 +101,7 @@ static inline notrace unsigned long irq_soft_mask_set_return(unsigned long mask)
 {
        unsigned long flags;
 
-#ifdef CONFIG_TRACE_IRQFLAGS
+#ifdef CONFIG_PPC_IRQ_SOFT_MASK_DEBUG
        WARN_ON(mask && !(mask & IRQS_DISABLED));
 #endif
 
index 3b90a2f1018e2eb6e3baee05fcc909e201e8a753..b2995509b01dca0b88be7fb3c30a9447330ca709 100644 (file)
@@ -128,7 +128,7 @@ END_FW_FTR_SECTION_IFSET(FW_FEATURE_SPLPAR)
         * of irq tracing is used, we additionally check that condition
         * is correct
         */
-#if defined(CONFIG_TRACE_IRQFLAGS) && defined(CONFIG_BUG)
+#if defined(CONFIG_PPC_IRQ_SOFT_MASK_DEBUG) && defined(CONFIG_BUG)
        lbz     r10,PACAIRQSOFTMASK(r13)
 1:     tdnei   r10,IRQS_ENABLED
        EMIT_BUG_ENTRY 1b,__FILE__,__LINE__,BUGFLAG_WARNING
@@ -911,7 +911,7 @@ END_FTR_SECTION_IFSET(CPU_FTR_HAS_PPR)
        rlwinm  r7,r7,0,~PACA_IRQ_HARD_DIS
        stb     r7,PACAIRQHAPPENED(r13)
 1:
-#if defined(CONFIG_TRACE_IRQFLAGS) && defined(CONFIG_BUG)
+#if defined(CONFIG_PPC_IRQ_SOFT_MASK_DEBUG) && defined(CONFIG_BUG)
        /* The interrupt should not have soft enabled. */
        lbz     r7,PACAIRQSOFTMASK(r13)
 1:     tdeqi   r7,IRQS_ENABLED
index 1a41cceddfe23ad9156cf16f36bde3eea1507460..f880388477908d60bf314318cc090e12157729c8 100644 (file)
@@ -264,7 +264,7 @@ notrace void arch_local_irq_restore(unsigned long mask)
         */
        if (unlikely(irq_happened != PACA_IRQ_HARD_DIS))
                __hard_irq_disable();
-#ifdef CONFIG_TRACE_IRQFLAGS
+#ifdef CONFIG_PPC_IRQ_SOFT_MASK_DEBUG
        else {
                /*
                 * We should already be hard disabled here. We had bugs
@@ -275,7 +275,7 @@ notrace void arch_local_irq_restore(unsigned long mask)
                if (WARN_ON(mfmsr() & MSR_EE))
                        __hard_irq_disable();
        }
-#endif /* CONFIG_TRACE_IRQFLAGS */
+#endif
 
        irq_soft_mask_set(IRQS_ALL_DISABLED);
        trace_hardirqs_off();