aboutsummaryrefslogtreecommitdiff
path: root/gdb/s390-tdep.c
diff options
context:
space:
mode:
authorJim Blandy <jimb@codesourcery.com>2001-12-05 22:20:00 +0000
committerJim Blandy <jimb@codesourcery.com>2001-12-05 22:20:00 +0000
commit12bffad7cc26991a622f9e90e11e5da31424feef (patch)
tree623058eec49488c3aa7669f525b9e45ce000a4ba /gdb/s390-tdep.c
parentf2eab0af2bc08ed54c4cfa38774341390dc16981 (diff)
downloadfsf-binutils-gdb-12bffad7cc26991a622f9e90e11e5da31424feef.zip
fsf-binutils-gdb-12bffad7cc26991a622f9e90e11e5da31424feef.tar.gz
fsf-binutils-gdb-12bffad7cc26991a622f9e90e11e5da31424feef.tar.bz2
* s390-tdep.c (s390_get_frame_info): Recognize argument register
spills that use the `stm' instruction. (is_arg_reg): New function.
Diffstat (limited to 'gdb/s390-tdep.c')
-rw-r--r--gdb/s390-tdep.c21
1 files changed, 17 insertions, 4 deletions
diff --git a/gdb/s390-tdep.c b/gdb/s390-tdep.c
index cefa9b7..cc28224 100644
--- a/gdb/s390-tdep.c
+++ b/gdb/s390-tdep.c
@@ -180,6 +180,14 @@ s390_stab_reg_to_regnum (int regno)
}
+/* Return true if REGIDX is the number of a register used to pass
+ arguments, false otherwise. */
+static int
+is_arg_reg (int regidx)
+{
+ return 2 <= regidx && regidx <= 6;
+}
+
/* s390_get_frame_info based on Hartmuts
prologue definition in
@@ -405,7 +413,7 @@ s390_get_frame_info (CORE_ADDR pc, struct frame_extra_info *fextra_info,
continue;
}
- /* Check for an fp-relative STG or ST. This is probably
+ /* Check for an fp-relative STG, ST, or STM. This is probably
spilling an argument from a register out into a stack slot.
This could be a user instruction, but if we haven't included
any other suspicious instructions in the prologue, this
@@ -414,9 +422,14 @@ s390_get_frame_info (CORE_ADDR pc, struct frame_extra_info *fextra_info,
are more serious, though --- you don't see the proper values
of the arguments. */
if ((save_link_state == 3 || save_link_state == 4)
- && instr[0] == 0x50 /* st %rA, D(%rX,%rB) */
- && (instr[1] & 0xf) == 0 /* %rX is zero, no index reg */
- && ((instr[2] >> 4) & 0xf) == frame_pointer_regidx)
+ && ((instr[0] == 0x50 /* st %rA, D(%rX,%rB) */
+ && (instr[1] & 0xf) == 0 /* %rX is zero, no index reg */
+ && is_arg_reg ((instr[1] >> 4) & 0xf)
+ && ((instr[2] >> 4) & 0xf) == frame_pointer_regidx)
+ || (instr[0] == 0x90 /* stm %rA, %rB, D(%rC) */
+ && is_arg_reg ((instr[1] >> 4) & 0xf)
+ && is_arg_reg (instr[1] & 0xf)
+ && ((instr[2] >> 4) & 0xf) == frame_pointer_regidx)))
{
valid_prologue = 1;
continue;