s390/unwind: fix mixing regs and sp
authorIlya Leoshkevich <iii@linux.ibm.com>
Wed, 2 Oct 2019 11:29:57 +0000 (13:29 +0200)
committerGreg Kroah-Hartman <gregkh@linuxfoundation.org>
Wed, 6 Nov 2019 12:09:11 +0000 (13:09 +0100)
commitb180b41bb01df39a49da28deae4a66888e554f77
tree1fbfb3b98b7b1ec4ddabb6d0c22f90a7c9ef3283
parent6a85f952934bc8f155636c5ce3c1257182d9c535
s390/unwind: fix mixing regs and sp

commit a1d863ac3e1085e1fea9caafd87252d08731de2e upstream.

unwind_for_each_frame stops after the first frame if regs->gprs[15] <=
sp.

The reason is that in case regs are specified, the first frame should be
regs->psw.addr and the second frame should be sp->gprs[8]. However,
currently the second frame is regs->gprs[15], which confuses
outside_of_stack().

Fix by introducing a flag to distinguish this special case from
unwinding the interrupt handler, for which the current behavior is
appropriate.

Fixes: 78c98f907413 ("s390/unwind: introduce stack unwind API")
Signed-off-by: Ilya Leoshkevich <iii@linux.ibm.com>
Cc: stable@vger.kernel.org # v5.2+
Reviewed-by: Heiko Carstens <heiko.carstens@de.ibm.com>
Signed-off-by: Vasily Gorbik <gor@linux.ibm.com>
Signed-off-by: Greg Kroah-Hartman <gregkh@linuxfoundation.org>
arch/s390/include/asm/unwind.h
arch/s390/kernel/unwind_bc.c