4.19-stable review patch.  If anyone has any objections, please let me know.

------------------

From: Christophe Leroy <[email protected]>

commit 0bbea75c476b77fa7d7811d6be911cc7583e640f upstream.

Looks like book3s/32 doesn't set RI on machine check, so
checking RI before calling die() will always be fatal
allthought this is not an issue in most cases.

Fixes: b96672dd840f ("powerpc: Machine check interrupt is a non-maskable 
interrupt")
Fixes: daf00ae71dad ("powerpc/traps: restore recoverability of machine_check 
interrupts")
Signed-off-by: Christophe Leroy <[email protected]>
Cc: [email protected]
Signed-off-by: Michael Ellerman <[email protected]>
Signed-off-by: Greg Kroah-Hartman <[email protected]>

---
 arch/powerpc/kernel/traps.c |    8 ++++----
 1 file changed, 4 insertions(+), 4 deletions(-)

--- a/arch/powerpc/kernel/traps.c
+++ b/arch/powerpc/kernel/traps.c
@@ -767,15 +767,15 @@ void machine_check_exception(struct pt_r
        if (check_io_access(regs))
                goto bail;
 
-       /* Must die if the interrupt is not recoverable */
-       if (!(regs->msr & MSR_RI))
-               nmi_panic(regs, "Unrecoverable Machine check");
-
        if (!nested)
                nmi_exit();
 
        die("Machine check", regs, SIGBUS);
 
+       /* Must die if the interrupt is not recoverable */
+       if (!(regs->msr & MSR_RI))
+               nmi_panic(regs, "Unrecoverable Machine check");
+
        return;
 
 bail:


Reply via email to