From: Fred Fish Date: Thu, 25 Nov 2004 02:48:27 +0000 (+0000) Subject: Approved by Kevin Buettner X-Git-Tag: gdb-pre-i18n-errorwarning-20050211~783 X-Git-Url: http://review.tizen.org/git/?a=commitdiff_plain;h=ebd98106b23a4d1d64a492cf26977e66c32393ac;p=external%2Fbinutils.git Approved by Kevin Buettner 2004-11-24 Fred Fish * rs6000-tdep.c (skip_prologue): Use line table info to skip over compiler generated function calls made as part of a prologue. --- diff --git a/gdb/ChangeLog b/gdb/ChangeLog index fcdbd92..f5f0574 100644 --- a/gdb/ChangeLog +++ b/gdb/ChangeLog @@ -1,3 +1,8 @@ +2004-11-24 Fred Fish + + * rs6000-tdep.c (skip_prologue): Use line table info to skip over + compiler generated function calls made as part of a prologue. + 2004-11-23 Mark Kettenis * inf-ttrace.c: New file. diff --git a/gdb/rs6000-tdep.c b/gdb/rs6000-tdep.c index 54842cd..8b341b2 100644 --- a/gdb/rs6000-tdep.c +++ b/gdb/rs6000-tdep.c @@ -1048,9 +1048,18 @@ skip_prologue (CORE_ADDR pc, CORE_ADDR lim_pc, struct rs6000_framedata *fdata) fdata->frameless = 0; /* Don't skip over the subroutine call if it is not within - the first three instructions of the prologue. */ + the first three instructions of the prologue and either + we have no line table information or the line info tells + us that the subroutine call is not part of the line + associated with the prologue. */ if ((pc - orig_pc) > 8) - break; + { + struct symtab_and_line prologue_sal = find_pc_line (orig_pc, 0); + struct symtab_and_line this_sal = find_pc_line (pc, 0); + + if ((prologue_sal.line == 0) || (prologue_sal.line != this_sal.line)) + break; + } op = read_memory_integer (pc + 4, 4);