From: Jakub Jelinek Date: Thu, 1 Jul 2010 11:11:46 +0000 (+0200) Subject: re PR debug/44694 (Long var tracking compile time of GiNaC tests) X-Git-Url: https://git.libre-soc.org/?a=commitdiff_plain;h=3aa05bb6cebdf040fff41f0ff71dbd6025c0a18d;p=gcc.git re PR debug/44694 (Long var tracking compile time of GiNaC tests) PR debug/44694 * dwarf2out.c (reg_loc_descriptor): For eliminated arg_pointer_rtx or frame_pointer_rtx use DW_OP_fbreg offset DW_OP_stack_value. From-SVN: r161662 --- diff --git a/gcc/ChangeLog b/gcc/ChangeLog index e54886b2444..e1c6e860651 100644 --- a/gcc/ChangeLog +++ b/gcc/ChangeLog @@ -1,3 +1,9 @@ +2010-07-01 Jakub Jelinek + + PR debug/44694 + * dwarf2out.c (reg_loc_descriptor): For eliminated arg_pointer_rtx + or frame_pointer_rtx use DW_OP_fbreg offset DW_OP_stack_value. + 2010-07-01 Richard Guenther * emit-rtl.c (set_mem_attributes_minus_bitpos): Use unsigned diff --git a/gcc/dwarf2out.c b/gcc/dwarf2out.c index 3faa1754859..6decc6f050e 100644 --- a/gcc/dwarf2out.c +++ b/gcc/dwarf2out.c @@ -12999,6 +12999,26 @@ reg_loc_descriptor (rtx rtl, enum var_init_status initialized) if (REGNO (rtl) >= FIRST_PSEUDO_REGISTER) return 0; + /* We only use "frame base" when we're sure we're talking about the + post-prologue local stack frame. We do this by *not* running + register elimination until this point, and recognizing the special + argument pointer and soft frame pointer rtx's. + Use DW_OP_fbreg offset DW_OP_stack_value in this case. */ + if ((rtl == arg_pointer_rtx || rtl == frame_pointer_rtx) + && eliminate_regs (rtl, VOIDmode, NULL_RTX) != rtl) + { + dw_loc_descr_ref result = NULL; + + if (dwarf_version >= 4 || !dwarf_strict) + { + result = mem_loc_descriptor (rtl, VOIDmode, initialized); + if (result) + add_loc_descr (&result, + new_loc_descr (DW_OP_stack_value, 0, 0)); + } + return result; + } + regs = targetm.dwarf_register_span (rtl); if (hard_regno_nregs[REGNO (rtl)][GET_MODE (rtl)] > 1 || regs)