diff options
author | Jim Kingdon <jkingdon@engr.sgi.com> | 1993-09-22 19:31:42 +0000 |
---|---|---|
committer | Jim Kingdon <jkingdon@engr.sgi.com> | 1993-09-22 19:31:42 +0000 |
commit | bdef72d222b9c87a023d511388125c187f74c683 (patch) | |
tree | 279925e85a3d6f9d4c1bc43a076864a21d49eaa7 | |
parent | 07a5991a095f75d6869c8bc62ab0308ad465ad6e (diff) | |
download | gdb-bdef72d222b9c87a023d511388125c187f74c683.zip gdb-bdef72d222b9c87a023d511388125c187f74c683.tar.gz gdb-bdef72d222b9c87a023d511388125c187f74c683.tar.bz2 |
* mips-tdep.c (mips_frame_chain): If PROC_FRAME_OFFSET is zero,
then return zero.
-rw-r--r-- | gdb/ChangeLog | 6 | ||||
-rw-r--r-- | gdb/mips-tdep.c | 14 |
2 files changed, 17 insertions, 3 deletions
diff --git a/gdb/ChangeLog b/gdb/ChangeLog index 6d71aa3..235330f 100644 --- a/gdb/ChangeLog +++ b/gdb/ChangeLog @@ -1,5 +1,11 @@ Wed Sep 22 10:28:06 1993 Jim Kingdon (kingdon@lioth.cygnus.com) + * breakpoint.c (bpstat_what): Initialize retval.call_dummy and + retval.step_resume. + + * mips-tdep.c (mips_frame_chain): If PROC_FRAME_OFFSET is zero, + then return zero. + * remote-nindy.c: Declare ninMemGet and ninMemPut. Wed Sep 22 08:02:57 1993 Stu Grossman (grossman at cygnus.com) diff --git a/gdb/mips-tdep.c b/gdb/mips-tdep.c index d2d712a..3ed7c4b 100644 --- a/gdb/mips-tdep.c +++ b/gdb/mips-tdep.c @@ -341,8 +341,13 @@ mips_frame_chain(frame) return 0; cached_proc_desc = proc_desc; - return read_next_frame_reg(frame, PROC_FRAME_REG(proc_desc)) - + PROC_FRAME_OFFSET(proc_desc); + /* If frame size is zero, we must be at end of stack (or otherwise hosed). + If we don't check frame size, we loop forever if we see it == 0. */ + if (PROC_FRAME_OFFSET (proc_desc) == 0) + return 0; + else + return read_next_frame_reg(frame, PROC_FRAME_REG(proc_desc)) + + PROC_FRAME_OFFSET(proc_desc); } void @@ -943,7 +948,10 @@ Turn off to avoid using floating point instructions when calling functions\n\ or dealing with return values.", &setlist), &showlist); - c = add_set_cmd ("heuristic-fence-post", class_support, var_uinteger, + /* We really would like to have both "0" and "unlimited" work, but + command.c doesn't deal with that. So make it a var_zinteger + because the user can always use "999999" or some such for unlimited. */ + c = add_set_cmd ("heuristic-fence-post", class_support, var_zinteger, (char *) &heuristic_fence_post, "\ Set the distance searched for the start of a function.\n\ |