From: jakub Date: Thu, 20 May 2010 16:34:43 +0000 (+0000) Subject: PR debug/44178 X-Git-Url: http://git.ipfire.org/cgi-bin/gitweb.cgi?a=commitdiff_plain;h=20f8d64b13a3e10f2dd713a085cd9d4a1ecbfaec;p=thirdparty%2Fgcc.git PR debug/44178 * haifa-sched.c (initiate_bb_reg_pressure_info): Do not call setup_ref_regs for DEBUG_INSNs. * g++.dg/debug/pr44178.C: New test. git-svn-id: svn+ssh://gcc.gnu.org/svn/gcc/trunk@159632 138bc75d-0d04-0410-961f-82ee72b054a4 --- diff --git a/gcc/ChangeLog b/gcc/ChangeLog index 5f96aa7fe90a..769697c87165 100644 --- a/gcc/ChangeLog +++ b/gcc/ChangeLog @@ -1,3 +1,9 @@ +2010-05-20 Jakub Jelinek + + PR debug/44178 + * haifa-sched.c (initiate_bb_reg_pressure_info): Do not call + setup_ref_regs for DEBUG_INSNs. + 2010-05-20 Jan Hubicka PR middle-end/44197 diff --git a/gcc/haifa-sched.c b/gcc/haifa-sched.c index 8bea5e3811e6..f7c087fef79c 100644 --- a/gcc/haifa-sched.c +++ b/gcc/haifa-sched.c @@ -718,7 +718,7 @@ initiate_bb_reg_pressure_info (basic_block bb) if (current_nr_blocks > 1) FOR_BB_INSNS (bb, insn) - if (INSN_P (insn)) + if (NONDEBUG_INSN_P (insn)) setup_ref_regs (PATTERN (insn)); initiate_reg_pressure_info (df_get_live_in (bb)); #ifdef EH_RETURN_DATA_REGNO diff --git a/gcc/testsuite/ChangeLog b/gcc/testsuite/ChangeLog index ddeef01abb1e..d50e8baf8def 100644 --- a/gcc/testsuite/ChangeLog +++ b/gcc/testsuite/ChangeLog @@ -1,3 +1,8 @@ +2010-05-20 Jakub Jelinek + + PR debug/44178 + * g++.dg/debug/pr44178.C: New test. + 2010-05-20 Changpeng Fang PR middle-end/44185 diff --git a/gcc/testsuite/g++.dg/debug/pr44178.C b/gcc/testsuite/g++.dg/debug/pr44178.C new file mode 100644 index 000000000000..2df566926697 --- /dev/null +++ b/gcc/testsuite/g++.dg/debug/pr44178.C @@ -0,0 +1,39 @@ +// PR debug/44178 +// { dg-do compile } +// { dg-options "-funroll-loops -fcompare-debug" { target i?86-*-* x86_64-*-* } } +// { dg-options "-fsched-pressure -funroll-loops -fschedule-insns -fcompare-debug" { target i?86-*-* x86_64-*-* } } + +struct A +{ + A (); + A (const A &) {} + A &operator = (const A &); +}; + +struct B +{ + int u1; + A u2; + int u3; + int i; +}; + +B f1 (int *); +B f2 (int, int, int, int); +B f3 (B *, B *); + +B +f4 (int x, int y, int z) +{ + B b1, b2; + for (int i = x; i > 0; i--) + for (int j = y; j > 0; j--) + { + int k; + f1 (&k); + b2 = f2 (i, 0, 0, z); + if (b2.i) return b2; + f3 (&b1, &b2); + } + return b1; +}