From: Jeff Law Date: Fri, 8 Feb 2013 20:03:52 +0000 (-0700) Subject: re PR debug/53948 (Assignment line missing for -O0 -g) X-Git-Tag: releases/gcc-4.8.0~523 X-Git-Url: http://git.ipfire.org/?a=commitdiff_plain;h=a698cc0308468029029e0501815747284194e407;p=thirdparty%2Fgcc.git re PR debug/53948 (Assignment line missing for -O0 -g) PR debug/53948 * emit-rtl.c (reg_is_parm_p): New function. * regs.h (reg_is_parm_p): New prototype. * ira-conflicts.c (ira_build_conflicts): Allow parameters in callee-clobbered registers. PR debug/53948 * gcc.dg/debug/dwarf2/pr53948.c: New test. From-SVN: r195900 --- diff --git a/gcc/ChangeLog b/gcc/ChangeLog index 9d668885f259..2693b7e843e6 100644 --- a/gcc/ChangeLog +++ b/gcc/ChangeLog @@ -1,3 +1,11 @@ +2013-02-08 Jeff Law + + PR debug/53948 + * emit-rtl.c (reg_is_parm_p): New function. + * regs.h (reg_is_parm_p): New prototype. + * ira-conflicts.c (ira_build_conflicts): Allow parameters in + callee-clobbered registers. + 2013-02-08 Michael Meissner PR target/56043 diff --git a/gcc/emit-rtl.c b/gcc/emit-rtl.c index f997e5d319bc..2c70fb1841da 100644 --- a/gcc/emit-rtl.c +++ b/gcc/emit-rtl.c @@ -919,6 +919,18 @@ gen_reg_rtx (enum machine_mode mode) return val; } +/* Return TRUE if REG is a PARM_DECL, FALSE otherwise. */ + +bool +reg_is_parm_p (rtx reg) +{ + tree decl; + + gcc_assert (REG_P (reg)); + decl = REG_EXPR (reg); + return (decl && TREE_CODE (decl) == PARM_DECL); +} + /* Update NEW with the same attributes as REG, but with OFFSET added to the REG_OFFSET. */ diff --git a/gcc/ira-conflicts.c b/gcc/ira-conflicts.c index 711db0fb4c1f..710986b073e4 100644 --- a/gcc/ira-conflicts.c +++ b/gcc/ira-conflicts.c @@ -895,8 +895,12 @@ ira_build_conflicts (void) if ((! flag_caller_saves && ALLOCNO_CALLS_CROSSED_NUM (a) != 0) /* For debugging purposes don't put user defined variables in - callee-clobbered registers. */ - || (optimize == 0 && REG_USERVAR_P (allocno_reg))) + callee-clobbered registers. However, do allow parameters + in callee-clobbered registers to improve debugging. This + is a bit of a fragile hack. */ + || (optimize == 0 + && REG_USERVAR_P (allocno_reg) + && ! reg_is_parm_p (allocno_reg))) { IOR_HARD_REG_SET (OBJECT_TOTAL_CONFLICT_HARD_REGS (obj), call_used_reg_set); diff --git a/gcc/regs.h b/gcc/regs.h index 0532d08ca1f6..090d6b64e833 100644 --- a/gcc/regs.h +++ b/gcc/regs.h @@ -89,6 +89,8 @@ REG_N_SETS (int regno) #define SET_REG_N_SETS(N,V) (regstat_n_sets_and_refs[N].sets = V) #define INC_REG_N_SETS(N,V) (regstat_n_sets_and_refs[N].sets += V) +/* Given a REG, return TRUE if the reg is a PARM_DECL, FALSE otherwise. */ +extern bool reg_is_parm_p (rtx); /* Functions defined in regstat.c. */ extern void regstat_init_n_sets_and_refs (void); diff --git a/gcc/testsuite/ChangeLog b/gcc/testsuite/ChangeLog index 583e7d59f451..83843b765810 100644 --- a/gcc/testsuite/ChangeLog +++ b/gcc/testsuite/ChangeLog @@ -1,3 +1,8 @@ +2013-02-08 Jeff Law + + PR debug/53948 + * gcc.dg/debug/dwarf2/pr53948.c: New test. + 2013-02-08 Michael Meissner PR target/56043 diff --git a/gcc/testsuite/gcc.dg/debug/dwarf2/pr53948.c b/gcc/testsuite/gcc.dg/debug/dwarf2/pr53948.c new file mode 100644 index 000000000000..f0600b77a147 --- /dev/null +++ b/gcc/testsuite/gcc.dg/debug/dwarf2/pr53948.c @@ -0,0 +1,10 @@ +/* Test that we have line information for the line + with local variable initializations. */ +/* { dg-options "-O0 -g -dA" } */ +/* { dg-final { scan-assembler ".loc 1 8 0|# line 8" } } */ + + +int f (register int a, register int b) { + register int x = b, y = a; + return x + y; } +