From: Jim Kingdon Date: Tue, 20 Apr 1993 18:02:54 +0000 (+0000) Subject: * rs6000-tdep.c: Delete unused function print_frame. X-Git-Url: https://git.libre-soc.org/?a=commitdiff_plain;h=cee86be37f49b8e1ec399271b9e7a4945faf34e5;p=binutils-gdb.git * rs6000-tdep.c: Delete unused function print_frame. * frame.h (struct frame_info): Doc fix for next_frame. New field signal_handler_caller. blockframe.c (create_new_frame, get_prev_frame_info), config/rs6000/tm-rs6000.h (INIT_EXTRA_FRAME_INFO): Set it (needs INIT_FRAME_PC_FIRST). stack.c (print_frame_info), rs6000-tdep.c (rs6000_frame_chain): Check it. --- diff --git a/gdb/ChangeLog b/gdb/ChangeLog index 6f2ca5a53f8..774c63da5b2 100644 --- a/gdb/ChangeLog +++ b/gdb/ChangeLog @@ -1,3 +1,15 @@ +Tue Apr 20 08:55:11 1993 Jim Kingdon (kingdon@cygnus.com) + + * rs6000-tdep.c: Delete unused function print_frame. + + * frame.h (struct frame_info): Doc fix for next_frame. + New field signal_handler_caller. + blockframe.c (create_new_frame, get_prev_frame_info), + config/rs6000/tm-rs6000.h (INIT_EXTRA_FRAME_INFO): Set it (needs + INIT_FRAME_PC_FIRST). + stack.c (print_frame_info), rs6000-tdep.c (rs6000_frame_chain): + Check it. + Mon Apr 19 22:52:33 1993 Stu Grossman (grossman@cygnus.com) * irix4-nat.c (fetch_core_registers): Special version of this for diff --git a/gdb/rs6000-tdep.c b/gdb/rs6000-tdep.c index 5aa76326485..12d33619854 100644 --- a/gdb/rs6000-tdep.c +++ b/gdb/rs6000-tdep.c @@ -892,23 +892,6 @@ extract_return_value (valtype, regbuf, valbuf) CORE_ADDR rs6000_struct_return_address; -/* Throw away this debugging code. FIXMEmgo. */ -void -print_frame(fram) -int fram; -{ - int ii, val; - for (ii=0; ii<40; ++ii) { - if ((ii % 4) == 0) - printf ("\n"); - val = read_memory_integer (fram + ii * 4, 4); - printf ("0x%08x\t", val); - } - printf ("\n"); -} - - - /* Indirect function calls use a piece of trampoline code to do context switching, i.e. to set the new TOC table. Skip such code if we are on its first instruction (as when we have single-stepped to here). @@ -1098,12 +1081,8 @@ rs6000_frame_chain (thisframe) FRAME_ADDR fp; if (inside_entry_file ((thisframe)->pc)) return 0; - fp = read_memory_integer ((thisframe)->frame, 4); - if (fp == 0 && thisframe->pc < TEXT_SEGMENT_BASE) + if (thisframe->signal_handler_caller) { - /* If we are doing a backtrace from a signal handler, fp will be 0 - and thisframe->pc will be something like 0x3f88 or 0x2790. */ - /* This was determined by experimentation on AIX 3.2. Perhaps it corresponds to some offset in /usr/include/sys/user.h or something like that. Using some system include file would @@ -1114,6 +1093,9 @@ rs6000_frame_chain (thisframe) #define SIG_FRAME_FP_OFFSET 284 fp = read_memory_integer (thisframe->frame + SIG_FRAME_FP_OFFSET, 4); } + else + fp = read_memory_integer ((thisframe)->frame, 4); + return fp; } diff --git a/gdb/stack.c b/gdb/stack.c index b5f965e4c4e..3d3d135cce8 100644 --- a/gdb/stack.c +++ b/gdb/stack.c @@ -152,6 +152,15 @@ print_frame_info (fi, level, source, args) printf_filtered ("\n"); return; } + if (fi->signal_handler_caller) + { + /* Do this regardless of SOURCE because we don't have any source + to list for this frame. */ + if (level >= 0) + printf_filtered ("#%-2d ", level); + printf_filtered ("\n"); + return; + } sal = find_pc_line (fi->pc, fi->next_frame); func = find_pc_function (fi->pc);