]> www.infradead.org Git - users/hch/dma-mapping.git/commitdiff
powerpc/64: Rename soft_enabled to irq_soft_mask
authorMadhavan Srinivasan <maddy@linux.vnet.ibm.com>
Wed, 20 Dec 2017 03:55:50 +0000 (09:25 +0530)
committerMichael Ellerman <mpe@ellerman.id.au>
Fri, 19 Jan 2018 11:37:01 +0000 (22:37 +1100)
Rename the paca->soft_enabled to paca->irq_soft_mask as it is no
longer used as a flag for interrupt state, but a mask.

Signed-off-by: Madhavan Srinivasan <maddy@linux.vnet.ibm.com>
Signed-off-by: Michael Ellerman <mpe@ellerman.id.au>
19 files changed:
arch/powerpc/include/asm/exception-64s.h
arch/powerpc/include/asm/hw_irq.h
arch/powerpc/include/asm/irqflags.h
arch/powerpc/include/asm/kvm_ppc.h
arch/powerpc/include/asm/paca.h
arch/powerpc/kernel/asm-offsets.c
arch/powerpc/kernel/entry_64.S
arch/powerpc/kernel/exceptions-64e.S
arch/powerpc/kernel/head_64.S
arch/powerpc/kernel/idle_book3e.S
arch/powerpc/kernel/idle_power4.S
arch/powerpc/kernel/irq.c
arch/powerpc/kernel/optprobes_head.S
arch/powerpc/kernel/ptrace.c
arch/powerpc/kernel/setup_64.c
arch/powerpc/kernel/time.c
arch/powerpc/kvm/book3s_hv_rmhandlers.S
arch/powerpc/mm/hugetlbpage.c
arch/powerpc/xmon/xmon.c

index a21adcb75fc6a16ac0de37e676d0dbe96016143b..b090db4ca37e044f3b74a8b3a098fc7d0e9d2c8e 100644 (file)
@@ -432,7 +432,7 @@ END_FTR_SECTION_NESTED(ftr,ftr,943)
        mflr    r9;                     /* Get LR, later save to stack  */ \
        ld      r2,PACATOC(r13);        /* get kernel TOC into r2       */ \
        std     r9,_LINK(r1);                                              \
-       lbz     r10,PACASOFTIRQEN(r13);                            \
+       lbz     r10,PACAIRQSOFTMASK(r13);                                  \
        mfspr   r11,SPRN_XER;           /* save XER in stackframe       */ \
        std     r10,SOFTE(r1);                                             \
        std     r11,_XER(r1);                                              \
@@ -498,7 +498,7 @@ END_FTR_SECTION_NESTED(ftr,ftr,943)
 #define SOFTEN_VALUE_0xea0     PACA_IRQ_EE
 
 #define __SOFTEN_TEST(h, vec)                                          \
-       lbz     r10,PACASOFTIRQEN(r13);                                 \
+       lbz     r10,PACAIRQSOFTMASK(r13);                               \
        andi.   r10,r10,IRQS_DISABLED;                          \
        li      r10,SOFTEN_VALUE_##vec;                                 \
        bne     masked_##h##interrupt
index f96280ee95402554345dc6bedd44b8f6eaae6783..5c82bb116832c601635b4f232a3c3f3e5d1120ff 100644 (file)
@@ -29,7 +29,7 @@
 #define PACA_IRQ_HMI           0x20
 
 /*
- * flags for paca->soft_enabled
+ * flags for paca->irq_soft_mask
  */
 #define IRQS_ENABLED           0
 #define IRQS_DISABLED          1
@@ -49,14 +49,14 @@ extern void unknown_exception(struct pt_regs *regs);
 #ifdef CONFIG_PPC64
 #include <asm/paca.h>
 
-static inline notrace unsigned long soft_enabled_return(void)
+static inline notrace unsigned long irq_soft_mask_return(void)
 {
        unsigned long flags;
 
        asm volatile(
                "lbz %0,%1(13)"
                : "=r" (flags)
-               : "i" (offsetof(struct paca_struct, soft_enabled)));
+               : "i" (offsetof(struct paca_struct, irq_soft_mask)));
 
        return flags;
 }
@@ -64,18 +64,24 @@ static inline notrace unsigned long soft_enabled_return(void)
 /*
  * The "memory" clobber acts as both a compiler barrier
  * for the critical section and as a clobber because
- * we changed paca->soft_enabled
+ * we changed paca->irq_soft_mask
  */
-static inline notrace void soft_enabled_set(unsigned long enable)
+static inline notrace void irq_soft_mask_set(unsigned long mask)
 {
 #ifdef CONFIG_TRACE_IRQFLAGS
        /*
-        * mask must always include LINUX bit if any are set, and
-        * interrupts don't get replayed until the Linux interrupt is
-        * unmasked. This could be changed to replay partial unmasks
-        * in future, which would allow Linux masks to nest inside
-        * other masks, among other things. For now, be very dumb and
-        * simple.
+        * The irq mask must always include the STD bit if any are set.
+        *
+        * and interrupts don't get replayed until the standard
+        * interrupt (local_irq_disable()) is unmasked.
+        *
+        * Other masks must only provide additional masking beyond
+        * the standard, and they are also not replayed until the
+        * standard interrupt becomes unmasked.
+        *
+        * This could be changed, but it will require partial
+        * unmasks to be replayed, among other things. For now, take
+        * the simple approach.
         */
        WARN_ON(mask && !(mask & IRQS_DISABLED));
 #endif
@@ -83,12 +89,12 @@ static inline notrace void soft_enabled_set(unsigned long enable)
        asm volatile(
                "stb %0,%1(13)"
                :
-               : "r" (enable),
-                 "i" (offsetof(struct paca_struct, soft_enabled))
+               : "r" (mask),
+                 "i" (offsetof(struct paca_struct, irq_soft_mask))
                : "memory");
 }
 
-static inline notrace unsigned long soft_enabled_set_return(unsigned long mask)
+static inline notrace unsigned long irq_soft_mask_set_return(unsigned long mask)
 {
        unsigned long flags;
 
@@ -99,7 +105,7 @@ static inline notrace unsigned long soft_enabled_set_return(unsigned long mask)
        asm volatile(
                "lbz %0,%1(13); stb %2,%1(13)"
                : "=&r" (flags)
-               : "i" (offsetof(struct paca_struct, soft_enabled)),
+               : "i" (offsetof(struct paca_struct, irq_soft_mask)),
                  "r" (mask)
                : "memory");
 
@@ -108,12 +114,12 @@ static inline notrace unsigned long soft_enabled_set_return(unsigned long mask)
 
 static inline unsigned long arch_local_save_flags(void)
 {
-       return soft_enabled_return();
+       return irq_soft_mask_return();
 }
 
 static inline void arch_local_irq_disable(void)
 {
-       soft_enabled_set(IRQS_DISABLED);
+       irq_soft_mask_set(IRQS_DISABLED);
 }
 
 extern void arch_local_irq_restore(unsigned long);
@@ -125,7 +131,7 @@ static inline void arch_local_irq_enable(void)
 
 static inline unsigned long arch_local_irq_save(void)
 {
-       return soft_enabled_set_return(IRQS_DISABLED);
+       return irq_soft_mask_set_return(IRQS_DISABLED);
 }
 
 static inline bool arch_irqs_disabled_flags(unsigned long flags)
@@ -146,13 +152,13 @@ static inline bool arch_irqs_disabled(void)
 #define __hard_irq_disable()   __mtmsrd(local_paca->kernel_msr, 1)
 #endif
 
-#define hard_irq_disable()     do {                    \
-       unsigned long flags;                            \
-       __hard_irq_disable();                           \
-       flags = soft_enabled_set_return(IRQS_DISABLED);\
-       local_paca->irq_happened |= PACA_IRQ_HARD_DIS;  \
-       if (!arch_irqs_disabled_flags(flags))           \
-               trace_hardirqs_off();                   \
+#define hard_irq_disable()     do {                            \
+       unsigned long flags;                                    \
+       __hard_irq_disable();                                   \
+       flags = irq_soft_mask_set_return(IRQS_DISABLED);        \
+       local_paca->irq_happened |= PACA_IRQ_HARD_DIS;          \
+       if (!arch_irqs_disabled_flags(flags))                   \
+               trace_hardirqs_off();                           \
 } while(0)
 
 static inline bool lazy_irq_pending(void)
index f1ec012232d9412a678969b55a8f8b319652b1b7..1a6c1ce17735a5f3a80b6f3254e9f082d72f14c4 100644 (file)
  * be clobbered.
  */
 #define RECONCILE_IRQ_STATE(__rA, __rB)                \
-       lbz     __rA,PACASOFTIRQEN(r13);        \
+       lbz     __rA,PACAIRQSOFTMASK(r13);      \
        lbz     __rB,PACAIRQHAPPENED(r13);      \
-       andi.   __rA,__rA,IRQS_DISABLED;\
-       li      __rA,IRQS_DISABLED;     \
+       andi.   __rA,__rA,IRQS_DISABLED;        \
+       li      __rA,IRQS_DISABLED;             \
        ori     __rB,__rB,PACA_IRQ_HARD_DIS;    \
        stb     __rB,PACAIRQHAPPENED(r13);      \
        bne     44f;                            \
-       stb     __rA,PACASOFTIRQEN(r13);        \
+       stb     __rA,PACAIRQSOFTMASK(r13);      \
        TRACE_DISABLE_INTS;                     \
 44:
 
@@ -64,9 +64,9 @@
 
 #define RECONCILE_IRQ_STATE(__rA, __rB)                \
        lbz     __rA,PACAIRQHAPPENED(r13);      \
-       li      __rB,IRQS_DISABLED;     \
+       li      __rB,IRQS_DISABLED;             \
        ori     __rA,__rA,PACA_IRQ_HARD_DIS;    \
-       stb     __rB,PACASOFTIRQEN(r13);        \
+       stb     __rB,PACAIRQSOFTMASK(r13);      \
        stb     __rA,PACAIRQHAPPENED(r13)
 #endif
 #endif
index 369f0640826c363e350cec7e7d08ced10b8ce78f..9db18287b5f447503eb3a8453e32fe652b5e467d 100644 (file)
@@ -873,7 +873,7 @@ static inline void kvmppc_fix_ee_before_entry(void)
 
        /* Only need to enable IRQs by hard enabling them after this */
        local_paca->irq_happened = 0;
-       soft_enabled_set(IRQS_ENABLED);
+       irq_soft_mask_set(IRQS_ENABLED);
 #endif
 }
 
index 3892db93b8374e1f1256a6b497d384f3faedc06e..e2ee193eb24d28ef2b55d7821df2de483fd216ab 100644 (file)
@@ -159,7 +159,7 @@ struct paca_struct {
        u64 saved_r1;                   /* r1 save for RTAS calls or PM */
        u64 saved_msr;                  /* MSR saved here by enter_rtas */
        u16 trap_save;                  /* Used when bad stack is encountered */
-       u8 soft_enabled;                /* irq soft-enable flag */
+       u8 irq_soft_mask;               /* mask for irq soft masking */
        u8 irq_happened;                /* irq happened while soft-disabled */
        u8 io_sync;                     /* writel() needs spin_unlock sync */
        u8 irq_work_pending;            /* IRQ_WORK interrupt while soft-disable */
index 3f6316bcde4ee9c309c91536285fbd1567d4ded3..43a6967d48ad2a1e627a36e67e2f73b8e468450a 100644 (file)
@@ -178,7 +178,7 @@ int main(void)
        OFFSET(PACATOC, paca_struct, kernel_toc);
        OFFSET(PACAKBASE, paca_struct, kernelbase);
        OFFSET(PACAKMSR, paca_struct, kernel_msr);
-       OFFSET(PACASOFTIRQEN, paca_struct, soft_enabled);
+       OFFSET(PACAIRQSOFTMASK, paca_struct, irq_soft_mask);
        OFFSET(PACAIRQHAPPENED, paca_struct, irq_happened);
 #ifdef CONFIG_PPC_BOOK3S
        OFFSET(PACACONTEXTID, paca_struct, mm_ctx_id);
index 51e4cc4dba4af3a7059078d11f7593b8e761c9ce..7c51f022d0defff27e14127234fd445fcd5100c7 100644 (file)
@@ -129,7 +129,7 @@ END_FW_FTR_SECTION_IFSET(FW_FEATURE_SPLPAR)
         * is correct
         */
 #if defined(CONFIG_TRACE_IRQFLAGS) && defined(CONFIG_BUG)
-       lbz     r10,PACASOFTIRQEN(r13)
+       lbz     r10,PACAIRQSOFTMASK(r13)
 1:     tdnei   r10,IRQS_ENABLED
        EMIT_BUG_ENTRY 1b,__FILE__,__LINE__,BUGFLAG_WARNING
 #endif
@@ -781,7 +781,7 @@ restore:
         * are about to re-enable interrupts
         */
        ld      r5,SOFTE(r1)
-       lbz     r6,PACASOFTIRQEN(r13)
+       lbz     r6,PACAIRQSOFTMASK(r13)
        andi.   r5,r5,IRQS_DISABLED
        bne     .Lrestore_irq_off
 
@@ -806,7 +806,7 @@ restore:
 .Lrestore_no_replay:
        TRACE_ENABLE_INTS
        li      r0,IRQS_ENABLED
-       stb     r0,PACASOFTIRQEN(r13);
+       stb     r0,PACAIRQSOFTMASK(r13);
 
        /*
         * Final return path. BookE is handled in a different file
@@ -913,8 +913,8 @@ END_FTR_SECTION_IFSET(CPU_FTR_HAS_PPR)
 1:
 #if defined(CONFIG_TRACE_IRQFLAGS) && defined(CONFIG_BUG)
        /* The interrupt should not have soft enabled. */
-       lbz     r7,PACASOFTIRQEN(r13)
-1:     tdnei   r7,IRQS_DISABLED
+       lbz     r7,PACAIRQSOFTMASK(r13)
+1:     tdeqi   r7,IRQS_ENABLED
        EMIT_BUG_ENTRY 1b,__FILE__,__LINE__,BUGFLAG_WARNING
 #endif
        b       .Ldo_restore
@@ -1034,7 +1034,7 @@ _GLOBAL(enter_rtas)
        /* There is no way it is acceptable to get here with interrupts enabled,
         * check it with the asm equivalent of WARN_ON
         */
-       lbz     r0,PACASOFTIRQEN(r13)
+       lbz     r0,PACAIRQSOFTMASK(r13)
 1:     tdeqi   r0,IRQS_ENABLED
        EMIT_BUG_ENTRY 1b,__FILE__,__LINE__,BUGFLAG_WARNING
 #endif
index 9216ece7672ce41aa7c9db2543922ea65929e891..ee832d344a5a265018d8fa98f0c38c0a94549db5 100644 (file)
@@ -139,7 +139,7 @@ END_FTR_SECTION_IFSET(CPU_FTR_EMB_HV)
        mfspr   r10,SPRN_ESR
        SPECIAL_EXC_STORE(r10,ESR)
 
-       lbz     r10,PACASOFTIRQEN(r13)
+       lbz     r10,PACAIRQSOFTMASK(r13)
        SPECIAL_EXC_STORE(r10,SOFTE)
        ld      r10,_NIP(r1)
        SPECIAL_EXC_STORE(r10,CSRR0)
@@ -206,7 +206,7 @@ BEGIN_FTR_SECTION
        mtspr   SPRN_MAS8,r10
 END_FTR_SECTION_IFSET(CPU_FTR_EMB_HV)
 
-       lbz     r6,PACASOFTIRQEN(r13)
+       lbz     r6,PACAIRQSOFTMASK(r13)
        ld      r5,SOFTE(r1)
 
        /* Interrupts had better not already be enabled... */
@@ -216,7 +216,7 @@ END_FTR_SECTION_IFSET(CPU_FTR_EMB_HV)
        bne     1f
 
        TRACE_ENABLE_INTS
-       stb     r5,PACASOFTIRQEN(r13)
+       stb     r5,PACAIRQSOFTMASK(r13)
 1:
        /*
         * Restore PACAIRQHAPPENED rather than setting it based on
@@ -351,7 +351,7 @@ ret_from_mc_except:
 #define PROLOG_ADDITION_NONE_MC(n)
 
 #define PROLOG_ADDITION_MASKABLE_GEN(n)                                            \
-       lbz     r10,PACASOFTIRQEN(r13); /* are irqs soft-disabled ? */      \
+       lbz     r10,PACAIRQSOFTMASK(r13);       /* are irqs soft-masked? */ \
        andi.   r10,r10,IRQS_DISABLED;  /* yes -> go out of line */ \
        bne     masked_interrupt_book3e_##n
 
@@ -397,7 +397,7 @@ exc_##n##_common:                                                       \
        mfspr   r8,SPRN_XER;            /* save XER in stackframe */        \
        ld      r9,excf+EX_R1(r13);     /* load orig r1 back from PACA */   \
        lwz     r10,excf+EX_CR(r13);    /* load orig CR back from PACA  */  \
-       lbz     r11,PACASOFTIRQEN(r13); /* get current IRQ softe */         \
+       lbz     r11,PACAIRQSOFTMASK(r13); /* get current IRQ softe */       \
        ld      r12,exception_marker@toc(r2);                               \
        li      r0,0;                                                       \
        std     r3,GPR10(r1);           /* save r10 to stackframe */        \
index 0deef350004f1b148f5a6b8a7db1e1e7a95a55f3..a61151a6ea5e82f8edc5828d923d80b07863182a 100644 (file)
@@ -766,7 +766,7 @@ _GLOBAL(pmac_secondary_start)
         * in the PACA when doing hotplug)
         */
        li      r0,IRQS_DISABLED
-       stb     r0,PACASOFTIRQEN(r13)
+       stb     r0,PACAIRQSOFTMASK(r13)
        li      r0,PACA_IRQ_HARD_DIS
        stb     r0,PACAIRQHAPPENED(r13)
 
@@ -823,7 +823,7 @@ __secondary_start:
         * in the PACA when doing hotplug)
         */
        li      r7,IRQS_DISABLED
-       stb     r7,PACASOFTIRQEN(r13)
+       stb     r7,PACAIRQSOFTMASK(r13)
        li      r0,PACA_IRQ_HARD_DIS
        stb     r0,PACAIRQHAPPENED(r13)
 
@@ -990,7 +990,7 @@ start_here_common:
         * in the PACA when doing hotplug)
         */
        li      r0,IRQS_DISABLED
-       stb     r0,PACASOFTIRQEN(r13)
+       stb     r0,PACAIRQSOFTMASK(r13)
        li      r0,PACA_IRQ_HARD_DIS
        stb     r0,PACAIRQHAPPENED(r13)
 
index 1bb1d152aa46c281f738c46681779cba5c467bfe..2b269315d37701a3cf3c11e654da681c5ec3c0a5 100644 (file)
@@ -48,7 +48,7 @@ _GLOBAL(\name)
        addi    r1,r1,128
 #endif
        li      r0,IRQS_ENABLED
-       stb     r0,PACASOFTIRQEN(r13)
+       stb     r0,PACAIRQSOFTMASK(r13)
        
        /* Interrupts will make use return to LR, so get something we want
         * in there
index 8b4702d9370152fa0236d5dd38aa7eb31c29642a..08faa93755f9f912bd9673be5bfa9ea363880aa4 100644 (file)
@@ -55,7 +55,7 @@ END_FTR_SECTION_IFCLR(CPU_FTR_CAN_NAP)
 #endif /* CONFIG_TRACE_IRQFLAGS */
 
        li      r0,IRQS_ENABLED
-       stb     r0,PACASOFTIRQEN(r13)   /* we'll hard-enable shortly */
+       stb     r0,PACAIRQSOFTMASK(r13) /* we'll hard-enable shortly */
 BEGIN_FTR_SECTION
        DSSALL
        sync
index 406c4329b535ec37b839dc4b12f1715210a8f885..e137b98dc5f898c7be4f3609fc51d5843775ef31 100644 (file)
@@ -225,22 +225,9 @@ notrace void arch_local_irq_restore(unsigned long mask)
        unsigned int replay;
 
        /* Write the new soft-enabled value */
-       soft_enabled_set(mask);
-       if (mask) {
-#ifdef CONFIG_TRACE_IRQFLAGS
-               /*
-                * mask must always include LINUX bit if any
-                * are set, and interrupts don't get replayed until
-                * the Linux interrupt is unmasked. This could be
-                * changed to replay partial unmasks in future,
-                * which would allow Linux masks to nest inside
-                * other masks, among other things. For now, be very
-                * dumb and simple.
-                */
-               WARN_ON(!(mask & IRQS_DISABLED));
-#endif
+       irq_soft_mask_set(mask);
+       if (mask)
                return;
-       }
 
        /*
         * From this point onward, we can take interrupts, preempt,
@@ -285,7 +272,7 @@ notrace void arch_local_irq_restore(unsigned long mask)
        }
 #endif /* CONFIG_TRACE_IRQFLAGS */
 
-       soft_enabled_set(IRQS_DISABLED);
+       irq_soft_mask_set(IRQS_DISABLED);
        trace_hardirqs_off();
 
        /*
@@ -297,7 +284,7 @@ notrace void arch_local_irq_restore(unsigned long mask)
 
        /* We can soft-enable now */
        trace_hardirqs_on();
-       soft_enabled_set(IRQS_ENABLED);
+       irq_soft_mask_set(IRQS_ENABLED);
 
        /*
         * And replay if we have to. This will return with interrupts
@@ -372,7 +359,7 @@ bool prep_irq_for_idle(void)
         * of entering the low power state.
         */
        local_paca->irq_happened &= ~PACA_IRQ_HARD_DIS;
-       soft_enabled_set(IRQS_ENABLED);
+       irq_soft_mask_set(IRQS_ENABLED);
 
        /* Tell the caller to enter the low power state */
        return true;
index 52fc864cdec4e9f3950fc5da1a48de74a34380d7..98a3aeeb3c8cddf705c5054142b98b7ef4d6090c 100644 (file)
@@ -58,7 +58,7 @@ optprobe_template_entry:
        std     r5,_XER(r1)
        mfcr    r5
        std     r5,_CCR(r1)
-       lbz     r5,PACASOFTIRQEN(r13)
+       lbz     r5,PACAIRQSOFTMASK(r13)
        std     r5,SOFTE(r1)
 
        /*
index bd2c49475473d0438d487f69cda7ce6cd1fcf6e3..aef08e57994672c213a83b3694f923391a2d8842 100644 (file)
@@ -285,7 +285,7 @@ int ptrace_get_reg(struct task_struct *task, int regno, unsigned long *data)
 
 #ifdef CONFIG_PPC64
        /*
-        * softe copies paca->soft_enabled variable state. Since soft_enabled is
+        * softe copies paca->irq_soft_mask variable state. Since irq_soft_mask is
         * no more used as a flag, lets force usr to alway see the softe value as 1
         * which means interrupts are not soft disabled.
         */
index f6bedebda90a6203f06ca0d47fa0925938f235c9..896dacef2f2dcfef871c805504d5b19cb38877a5 100644 (file)
@@ -189,7 +189,7 @@ static void __init fixup_boot_paca(void)
        /* Allow percpu accesses to work until we setup percpu data */
        get_paca()->data_offset = 0;
        /* Mark interrupts disabled in PACA */
-       soft_enabled_set(IRQS_DISABLED);
+       irq_soft_mask_set(IRQS_DISABLED);
 }
 
 static void __init configure_exceptions(void)
@@ -352,7 +352,7 @@ void __init early_setup(unsigned long dt_ptr)
 void early_setup_secondary(void)
 {
        /* Mark interrupts disabled in PACA */
-       soft_enabled_set(IRQS_DISABLED);
+       irq_soft_mask_set(IRQS_DISABLED);
 
        /* Initialize the hash table or TLB handling */
        early_init_mmu_secondary();
index daa6e9e35ab94c27f820d6373e60a8256a31dbf9..a32823dcd9a4d24444cb5291f17ec79bc7fe23ef 100644 (file)
@@ -244,7 +244,7 @@ static u64 scan_dispatch_log(u64 stop_tb)
 void accumulate_stolen_time(void)
 {
        u64 sst, ust;
-       unsigned long save_soft_enabled = soft_enabled_return();
+       unsigned long save_irq_soft_mask = irq_soft_mask_return();
        struct cpu_accounting_data *acct = &local_paca->accounting;
 
        /* We are called early in the exception entry, before
@@ -253,7 +253,7 @@ void accumulate_stolen_time(void)
         * needs to reflect that so various debug stuff doesn't
         * complain
         */
-       soft_enabled_set(IRQS_DISABLED);
+       irq_soft_mask_set(IRQS_DISABLED);
 
        sst = scan_dispatch_log(acct->starttime_user);
        ust = scan_dispatch_log(acct->starttime);
@@ -261,7 +261,7 @@ void accumulate_stolen_time(void)
        acct->utime -= ust;
        acct->steal_time += ust + sst;
 
-       soft_enabled_set(save_soft_enabled);
+       irq_soft_mask_set(save_irq_soft_mask);
 }
 
 static inline u64 calculate_stolen_time(u64 stop_tb)
index 2659844784b817d7ca77e6e95ecb9418f430e62d..a92ad850091725050b45d93f5b87e7c74fb166d0 100644 (file)
@@ -3249,7 +3249,7 @@ kvmppc_bad_host_intr:
        mfctr   r4
 #endif
        mfxer   r5
-       lbz     r6, PACASOFTIRQEN(r13)
+       lbz     r6, PACAIRQSOFTMASK(r13)
        std     r3, _LINK(r1)
        std     r4, _CTR(r1)
        std     r5, _XER(r1)
index 760bb5a2b8bd51d9d02e95dee00e63a33ef8e417..876da2bc1796ba1b8568ad9a26450dcd4c162ecd 100644 (file)
@@ -752,7 +752,7 @@ void flush_dcache_icache_hugepage(struct page *page)
  * So long as we atomically load page table pointers we are safe against teardown,
  * we can follow the address down to the the page and take a ref on it.
  * This function need to be called with interrupts disabled. We use this variant
- * when we have MSR[EE] = 0 but the paca->soft_enabled = IRQS_ENABLED
+ * when we have MSR[EE] = 0 but the paca->irq_soft_mask = IRQS_ENABLED
  */
 pte_t *__find_linux_pte(pgd_t *pgdir, unsigned long ea,
                        bool *is_thp, unsigned *hpage_shift)
index 1b2d8cb49abb2e8ea209a511bd239dd58e710661..2695f8dd23595ec00d75c62d7baaa919b79503dd 100644 (file)
@@ -1623,7 +1623,7 @@ static void excprint(struct pt_regs *fp)
        printf("  current = 0x%lx\n", current);
 #ifdef CONFIG_PPC64
        printf("  paca    = 0x%lx\t softe: %d\t irq_happened: 0x%02x\n",
-              local_paca, local_paca->soft_enabled, local_paca->irq_happened);
+              local_paca, local_paca->irq_soft_mask, local_paca->irq_happened);
 #endif
        if (current) {
                printf("    pid   = %ld, comm = %s\n",
@@ -2391,7 +2391,7 @@ static void dump_one_paca(int cpu)
        DUMP(p, stab_rr, "lx");
        DUMP(p, saved_r1, "lx");
        DUMP(p, trap_save, "x");
-       DUMP(p, soft_enabled, "x");
+       DUMP(p, irq_soft_mask, "x");
        DUMP(p, irq_happened, "x");
        DUMP(p, io_sync, "x");
        DUMP(p, irq_work_pending, "x");