diff options
author | Daniel Jacobowitz <drow@false.org> | 2007-02-27 20:17:19 +0000 |
---|---|---|
committer | Daniel Jacobowitz <drow@false.org> | 2007-02-27 20:17:19 +0000 |
commit | 93d42b302eb91d758191675dcaf3bd90323b5224 (patch) | |
tree | eb45d933ae4389284a4e1a14f2d1c564bca3da47 /gdb/dwarf2-frame.c | |
parent | 206415a3eac4f69d24cf872f880f554d3d43f1bb (diff) | |
download | gdb-93d42b302eb91d758191675dcaf3bd90323b5224.zip gdb-93d42b302eb91d758191675dcaf3bd90323b5224.tar.gz gdb-93d42b302eb91d758191675dcaf3bd90323b5224.tar.bz2 |
* dwarf2-frame.c (dwarf2_frame_cache, dwarf2_frame_this_id)
(dwarf2_frame_sniffer): Update.
(dwarf2_signal_frame_this_id): New function.
(dwarf2_signal_frame_unwind): Use it.
(dwarf2_frame_base_sniffer): Use frame_unwind_address_in_block.
* frame.c (frame_func_unwind): Add this_type argument.
(get_frame_func): Update.
(frame_unwind_address_in_block): Add this_type argument and check it.
Fix a typo.
(get_frame_address_in_block): Update.
* frame.h (enum frame_type): Move higher in the file.
(frame_unwind_address_in_block, frame_func_unwind): Add enum frame_type
argument.
* alpha-mdebug-tdep.c, alpha-tdep.c, amd64-tdep.c, amd64obsd-tdep.c,
arm-tdep.c, avr-tdep.c, cris-tdep.c, frv-tdep.c, h8300-tdep.c,
hppa-tdep.c, i386-tdep.c, i386obsd-tdep.c, ia64-tdep.c,
libunwind-frame.c, m32c-tdep.c, m32r-linux-tdep.c, m32r-tdep.c,
m68hc11-tdep.c, m68k-tdep.c, m88k-tdep.c, mips-mdebug-tdep.c,
mips-tdep.c, mn10300-tdep.c, mt-tdep.c, rs6000-tdep.c, s390-tdep.c,
score-tdep.c, sh-tdep.c, sh64-tdep.c, sparc-tdep.c,
sparc64obsd-tdep.c, spu-tdep.c, v850-tdep.c, vax-tdep.c,
xstormy16-tdep.c, xtensa-tdep.c: Update calls to
frame_func_unwind and frame_unwind_address_in_block to specify
the frame type. Use frame_unwind_address_in_block instead of
frame_pc_unwind in sniffers.
* gdb.arch/i386-signal.c, gdb.arch/i386-signal.exp: New files.
Diffstat (limited to 'gdb/dwarf2-frame.c')
-rw-r--r-- | gdb/dwarf2-frame.c | 34 |
1 files changed, 27 insertions, 7 deletions
diff --git a/gdb/dwarf2-frame.c b/gdb/dwarf2-frame.c index fd4002c..be61a0e 100644 --- a/gdb/dwarf2-frame.c +++ b/gdb/dwarf2-frame.c @@ -848,7 +848,7 @@ dwarf2_frame_cache (struct frame_info *next_frame, void **this_cache) frame_unwind_address_in_block does just this. It's not clear how reliable the method is though; there is the potential for the register state pre-call being different to that on return. */ - fs->pc = frame_unwind_address_in_block (next_frame); + fs->pc = frame_unwind_address_in_block (next_frame, NORMAL_FRAME); /* Find the correct FDE. */ fde = dwarf2_frame_find_fde (&fs->pc); @@ -1011,7 +1011,22 @@ dwarf2_frame_this_id (struct frame_info *next_frame, void **this_cache, if (cache->undefined_retaddr) return; - (*this_id) = frame_id_build (cache->cfa, frame_func_unwind (next_frame)); + (*this_id) = frame_id_build (cache->cfa, + frame_func_unwind (next_frame, NORMAL_FRAME)); +} + +static void +dwarf2_signal_frame_this_id (struct frame_info *next_frame, void **this_cache, + struct frame_id *this_id) +{ + struct dwarf2_frame_cache *cache = + dwarf2_frame_cache (next_frame, this_cache); + + if (cache->undefined_retaddr) + return; + + (*this_id) = frame_id_build (cache->cfa, + frame_func_unwind (next_frame, SIGTRAMP_FRAME)); } static void @@ -1179,7 +1194,7 @@ static const struct frame_unwind dwarf2_frame_unwind = static const struct frame_unwind dwarf2_signal_frame_unwind = { SIGTRAMP_FRAME, - dwarf2_frame_this_id, + dwarf2_signal_frame_this_id, dwarf2_frame_prev_register }; @@ -1188,8 +1203,12 @@ dwarf2_frame_sniffer (struct frame_info *next_frame) { /* Grab an address that is guarenteed to reside somewhere within the function. frame_pc_unwind(), for a no-return next function, can - end up returning something past the end of this function's body. */ - CORE_ADDR block_addr = frame_unwind_address_in_block (next_frame); + end up returning something past the end of this function's body. + If the frame we're sniffing for is a signal frame whose start + address is placed on the stack by the OS, its FDE must + extend one byte before its start address or we will miss it. */ + CORE_ADDR block_addr = frame_unwind_address_in_block (next_frame, + NORMAL_FRAME); struct dwarf2_fde *fde = dwarf2_frame_find_fde (&block_addr); if (!fde) return NULL; @@ -1233,8 +1252,9 @@ static const struct frame_base dwarf2_frame_base = const struct frame_base * dwarf2_frame_base_sniffer (struct frame_info *next_frame) { - CORE_ADDR pc = frame_pc_unwind (next_frame); - if (dwarf2_frame_find_fde (&pc)) + CORE_ADDR block_addr = frame_unwind_address_in_block (next_frame, + NORMAL_FRAME); + if (dwarf2_frame_find_fde (&block_addr)) return &dwarf2_frame_base; return NULL; |