It should be prohibitted to use priority masking in NMI context.

Using local_irq_disable() under the above conditions causes a WARNING.
Then, there will be also a mismatch between the PSR.I values and PMR 
GIC_PRIO_PSR_I_SET.

Signed-off-by: Yuichi Ito <[email protected]>
---
 arch/arm64/kernel/smp.c | 4 +++-
 1 file changed, 3 insertions(+), 1 deletion(-)

diff --git a/arch/arm64/kernel/smp.c b/arch/arm64/kernel/smp.c
index fd59bc7..3c49f06 100644
--- a/arch/arm64/kernel/smp.c
+++ b/arch/arm64/kernel/smp.c
@@ -872,7 +872,9 @@ static void ipi_cpu_crash_stop(unsigned int cpu, struct 
pt_regs *regs)
 
        atomic_dec(&waiting_for_crash_ipi);
 
-       local_irq_disable();
+       if(!in_nmi())
+               local_irq_disable();
+
        sdei_mask_local_cpu();
 
        if (IS_ENABLED(CONFIG_HOTPLUG_CPU))
-- 
1.8.3.1

Reply via email to