diff options
author | Andrew Cagney <cagney@redhat.com> | 2002-11-29 01:52:02 +0000 |
---|---|---|
committer | Andrew Cagney <cagney@redhat.com> | 2002-11-29 01:52:02 +0000 |
commit | 1058bca7483f329cd60fba85ce7391d522885fde (patch) | |
tree | 036848f60b897b3e984bd3b9863fb1ed44ba8496 /gdb/frame.c | |
parent | d92419e5e96545b7021e28c14db0576ad0b1790b (diff) | |
download | gdb-1058bca7483f329cd60fba85ce7391d522885fde.zip gdb-1058bca7483f329cd60fba85ce7391d522885fde.tar.gz gdb-1058bca7483f329cd60fba85ce7391d522885fde.tar.bz2 |
2002-11-28 Andrew Cagney <ac131313@redhat.com>
* frame.c (pc_notcurrent): New function.
(find_frame_sal): New function.
* frame.h (find_frame_sal): Declare.
(struct symtab_and_line): Add opaque declaration.
* stack.c (print_frame_info_base): Use find_pc_line instead of
find_frame_sal.
(frame_info): Ditto.
* ada-lang.c (find_printable_frame): Ditto.
Index: tui/ChangeLog
2002-11-28 Andrew Cagney <ac131313@redhat.com>
* tuiStack.c (tuiShowFrameInfo): Use find_frame_sal instead of
find_pc_line.
Diffstat (limited to 'gdb/frame.c')
-rw-r--r-- | gdb/frame.c | 23 |
1 files changed, 23 insertions, 0 deletions
diff --git a/gdb/frame.c b/gdb/frame.c index 44207f3..1918114 100644 --- a/gdb/frame.c +++ b/gdb/frame.c @@ -1021,6 +1021,29 @@ get_frame_pc (struct frame_info *frame) return frame->pc; } +static int +pc_notcurrent (struct frame_info *frame) +{ + /* If FRAME is not the innermost frame, that normally means that + FRAME->pc points at the return instruction (which is *after* the + call instruction), and we want to get the line containing the + call (because the call is where the user thinks the program is). + However, if the next frame is either a SIGTRAMP_FRAME or a + DUMMY_FRAME, then the next frame will contain a saved interrupt + PC and such a PC indicates the current (rather than next) + instruction/line, consequently, for such cases, want to get the + line containing fi->pc. */ + struct frame_info *next = get_next_frame (frame); + int notcurrent = (next != NULL && get_frame_type (next) == NORMAL_FRAME); + return notcurrent; +} + +void +find_frame_sal (struct frame_info *frame, struct symtab_and_line *sal) +{ + (*sal) = find_pc_line (frame->pc, pc_notcurrent (frame)); +} + /* Per "frame.h", return the ``address'' of the frame. Code should really be using get_frame_id(). */ CORE_ADDR |