diff options
author | Nicholas Piggin <npiggin@gmail.com> | 2023-01-21 11:01:56 +0100 |
---|---|---|
committer | Michael Ellerman <mpe@ellerman.id.au> | 2023-01-30 10:07:42 +0100 |
commit | c28548012ee2bac55772ef7685138bd1124b80c3 (patch) | |
tree | d89e4e5290744797f80f470183b029a598012dd2 /arch/powerpc/kernel/dbell.c | |
parent | powerpc/64s: Fix local irq disable when PMIs are disabled (diff) | |
download | linux-c28548012ee2bac55772ef7685138bd1124b80c3.tar.xz linux-c28548012ee2bac55772ef7685138bd1124b80c3.zip |
powerpc/64: Fix perf profiling asynchronous interrupt handlers
Interrupt entry sets the soft mask to IRQS_ALL_DISABLED to match the
hard irq disabled state. So when should_hard_irq_enable() returns true
because we want PMI interrupts in irq handlers, MSR[EE] is enabled but
PMIs just get soft-masked. Fix this by clearing IRQS_PMI_DISABLED before
enabling MSR[EE].
This also tidies some of the warnings, no need to duplicate them in
both should_hard_irq_enable() and do_hard_irq_enable().
Signed-off-by: Nicholas Piggin <npiggin@gmail.com>
Signed-off-by: Michael Ellerman <mpe@ellerman.id.au>
Link: https://lore.kernel.org/r/20230121100156.2824054-1-npiggin@gmail.com
Diffstat (limited to 'arch/powerpc/kernel/dbell.c')
-rw-r--r-- | arch/powerpc/kernel/dbell.c | 2 |
1 files changed, 1 insertions, 1 deletions
diff --git a/arch/powerpc/kernel/dbell.c b/arch/powerpc/kernel/dbell.c index f55c6fb34a3a..5712dd846263 100644 --- a/arch/powerpc/kernel/dbell.c +++ b/arch/powerpc/kernel/dbell.c @@ -27,7 +27,7 @@ DEFINE_INTERRUPT_HANDLER_ASYNC(doorbell_exception) ppc_msgsync(); - if (should_hard_irq_enable()) + if (should_hard_irq_enable(regs)) do_hard_irq_enable(); kvmppc_clear_host_ipi(smp_processor_id()); |