Blame SOURCES/gcc49-pr63285.patch

72e591
2014-09-18  Vladimir Makarov  <vmakarov@redhat.com>
72e591
72e591
	PR debug/63285
72e591
	* haifa-sched.c (schedule_block): Advance cycle at the end of BB
72e591
	if advance != 0.
72e591
72e591
	* gcc.target/i386/pr63285.c: New test.
72e591
72e591
--- gcc/haifa-sched.c	(revision 215363)
72e591
+++ gcc/haifa-sched.c	(revision 215364)
72e591
@@ -6473,7 +6473,7 @@ schedule_block (basic_block *target_bb,
72e591
   if (ls.modulo_epilogue)
72e591
     success = true;
72e591
  end_schedule:
72e591
-  if (!ls.first_cycle_insn_p)
72e591
+  if (!ls.first_cycle_insn_p || advance)
72e591
     advance_one_cycle ();
72e591
   perform_replacements_new_cycle ();
72e591
   if (modulo_ii > 0)
72e591
--- gcc/testsuite/gcc.target/i386/pr63285.c	(revision 0)
72e591
+++ gcc/testsuite/gcc.target/i386/pr63285.c	(revision 215364)
72e591
@@ -0,0 +1,28 @@
72e591
+/* { dg-do compile } */
72e591
+/* { dg-options "-O2 -fcompare-debug" } */
72e591
+
72e591
+struct S { int a; };
72e591
+struct T { int b, c; } a;
72e591
+long b;
72e591
+int c, d;
72e591
+void bar (int, int);
72e591
+void baz (void *, int);
72e591
+
72e591
+void
72e591
+foo (struct S *x, int y, int z, void *f, int *p, struct T *e)
72e591
+{
72e591
+  while (x)
72e591
+    {
72e591
+      baz (f, &d > p);
72e591
+      if (z & 1)
72e591
+        bar (f > (void *) &f, z);
72e591
+    }
72e591
+  if (c)
72e591
+    {
72e591
+      asm ("" : "+m" (a) : "i" (0));
72e591
+      y--;
72e591
+    }
72e591
+  if (e->b == e->c)
72e591
+    c = y;
72e591
+  y--;
72e591
+}