From 3aa05bb6cebdf040fff41f0ff71dbd6025c0a18d Mon Sep 17 00:00:00 2001 From: Jakub Jelinek Date: Thu, 1 Jul 2010 13:11:46 +0200 Subject: [PATCH] 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 --- gcc/ChangeLog | 6 ++++++ gcc/dwarf2out.c | 20 ++++++++++++++++++++ 2 files changed, 26 insertions(+) diff --git a/gcc/ChangeLog b/gcc/ChangeLog index e54886b24446..e1c6e860651f 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 3faa17548599..6decc6f050ef 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) -- 2.43.5