From: Martin Schwidefsky Date: Fri, 2 Dec 2016 12:29:22 +0000 (+0100) Subject: s390: fix machine check panic stack switch X-Git-Url: https://git.stricted.de/?a=commitdiff_plain;h=ce4dda3f02aca959bdd18b596513791d77b8b7e1;p=GitHub%2Fmoto-9609%2Fandroid_kernel_motorola_exynos9610.git s390: fix machine check panic stack switch For system damage machine checks or machine checks due to invalid PSW fields the system will be stopped. In order to get an oops message out before killing the system the machine check handler branches to .Lmcck_panic, switches to the panic stack and then does the usual machine check handling. The switch to the panic stack is incomplete, the stack pointer in %r15 is replaced, but the pt_regs pointer in %r11 is not. The result is a program check which will kill the system in a slightly different way. Signed-off-by: Martin Schwidefsky --- diff --git a/arch/s390/kernel/entry.S b/arch/s390/kernel/entry.S index 161f4e66f67d..1a450d220f56 100644 --- a/arch/s390/kernel/entry.S +++ b/arch/s390/kernel/entry.S @@ -958,7 +958,7 @@ ENTRY(mcck_int_handler) .Lmcck_panic: lg %r15,__LC_PANIC_STACK - aghi %r15,-(STACK_FRAME_OVERHEAD + __PT_SIZE) + la %r11,STACK_FRAME_OVERHEAD(%r15) j .Lmcck_skip #