diff options
author | Jim Blandy <jimb@codesourcery.com> | 2001-12-05 00:20:37 +0000 |
---|---|---|
committer | Jim Blandy <jimb@codesourcery.com> | 2001-12-05 00:20:37 +0000 |
commit | 7666f43c32c4d59bdf906d9ba4b0a471c0a11409 (patch) | |
tree | d24d7095531c6bac6024a933eecbf70cc12e1742 /gdb/s390-tdep.c | |
parent | 7286245e1f4bd8f5ed8407ffdb0fad5439709967 (diff) | |
download | gdb-7666f43c32c4d59bdf906d9ba4b0a471c0a11409.zip gdb-7666f43c32c4d59bdf906d9ba4b0a471c0a11409.tar.gz gdb-7666f43c32c4d59bdf906d9ba4b0a471c0a11409.tar.bz2 |
* s390-tdep.c (s390_get_frame_info): Recognize spills of reg
arguments into their stack slots.
Diffstat (limited to 'gdb/s390-tdep.c')
-rw-r--r-- | gdb/s390-tdep.c | 17 |
1 files changed, 17 insertions, 0 deletions
diff --git a/gdb/s390-tdep.c b/gdb/s390-tdep.c index 2d28d9c..cefa9b7 100644 --- a/gdb/s390-tdep.c +++ b/gdb/s390-tdep.c @@ -405,6 +405,23 @@ 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 + 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 + could only be an initializing store, which isn't too bad to + skip. The consequences of not including arg-to-stack spills + 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) + { + valid_prologue = 1; + continue; + } + /* check for STD */ if (instr[0] == 0x60 && (instr[2] >> 4) == 0xf) { |