S390: Fix displaced stepping of "basr r,0"
authorAndreas Arnez <arnez@linux.vnet.ibm.com>
Fri, 13 Jul 2018 10:46:14 +0000 (12:46 +0200)
committerAndreas Arnez <arnez@linux.vnet.ibm.com>
Fri, 13 Jul 2018 10:46:14 +0000 (12:46 +0200)
commit5c1eda30f55e9c543de26fec0246f4d7655c81e4
tree95ba11284f4b465c4d5f13a6827d9e05e92ce753
parenta780ef4f27f8bc44082be81fdbee44bb11f1049c
S390: Fix displaced stepping of "basr r,0"

The BASR instruction behaves differently depending on whether the second
operand is a number from 1 to 15, or zero.  In the former case BASR jumps
to the address contained in the general register of that number, but in
the latter case no jump is performed.  GDB's displaced-stepping logic does
not distinguish these cases, although it should.

This is fixed.  In the case where no jump is performed the PC is adjusted
to point back after the original instruction.  Otherwise the PC is left
alone.

gdb/ChangeLog:

* s390-tdep.c (s390_displaced_step_fixup): Adjust PC for a
non-branching basr.
gdb/ChangeLog
gdb/s390-tdep.c