OSDN Git Service

PR debug/45105
authorjakub <jakub@138bc75d-0d04-0410-961f-82ee72b054a4>
Wed, 28 Jul 2010 17:01:05 +0000 (17:01 +0000)
committerjakub <jakub@138bc75d-0d04-0410-961f-82ee72b054a4>
Wed, 28 Jul 2010 17:01:05 +0000 (17:01 +0000)
* gcse.c (hoist_code): Use FOR_BB_INSNS macro.

* gcc.dg/pr45105.c: New test.

git-svn-id: svn+ssh://gcc.gnu.org/svn/gcc/trunk@162647 138bc75d-0d04-0410-961f-82ee72b054a4

gcc/ChangeLog
gcc/gcse.c
gcc/testsuite/ChangeLog
gcc/testsuite/gcc.dg/pr45105.c [new file with mode: 0644]

index 03c0db1..a4491cb 100644 (file)
@@ -1,5 +1,8 @@
 2010-07-28  Jakub Jelinek  <jakub@redhat.com>
 
+       PR debug/45105
+       * gcse.c (hoist_code): Use FOR_BB_INSNS macro.
+
        PR debug/45103
        * dwarf2out.c (dwarf2out_var_location): Always consider
        NOTE_DURING_CALL_P notes, even when not followed by real instructions.
index 6e923f9..15809aa 100644 (file)
@@ -4390,21 +4390,15 @@ hoist_code (void)
   FOR_EACH_BB (bb)
     {
       rtx insn;
-      rtx bb_end;
       int to_head;
 
-      insn = BB_HEAD (bb);
-      bb_end = BB_END (bb);
       to_head = 0;
-
-      while (insn != bb_end)
+      FOR_BB_INSNS (bb, insn)
        {
          /* Don't count debug instructions to avoid them affecting
             decision choices.  */
          if (NONDEBUG_INSN_P (insn))
            to_bb_head[INSN_UID (insn)] = to_head++;
-
-         insn = NEXT_INSN (insn);
        }
 
       bb_size[bb->index] = to_head;
index 3dbe028..cd97c64 100644 (file)
@@ -1,3 +1,8 @@
+2010-07-28  Jakub Jelinek  <jakub@redhat.com>
+
+       PR debug/45105
+       * gcc.dg/pr45105.c: New test.
+
 2010-07-28  Maxim Kuvyrkov  <maxim@codesourcery.com>
 
        PR rtl-optimization/45107
diff --git a/gcc/testsuite/gcc.dg/pr45105.c b/gcc/testsuite/gcc.dg/pr45105.c
new file mode 100644 (file)
index 0000000..a93a21f
--- /dev/null
@@ -0,0 +1,27 @@
+/* PR debug/45105 */
+/* { dg-do compile } */
+/* { dg-options "-Os -fcompare-debug" } */
+
+extern int *baz (int *, int *);
+
+void
+bar (int *p1, int *p2)
+{
+  int n = *baz (0, 0);
+  p1[n] = p2[n];
+}
+
+void
+foo (int *p, int l)
+{
+  int a1[32];
+  int a2[32];
+  baz (a1, a2);
+  while (l)
+    {
+      if (l & 1)
+       p = baz (a2, p);
+      l--;
+      bar (a1, a2);
+    }
+}