* loop.c (move_movables): Handle combination of m->consec,
m->move_insn_first, and m->insert_temp all nonzero correctly.
testsuite/ChangeLog:
* gcc.dg/
20031216-1.c: New test.
git-svn-id: svn+ssh://gcc.gnu.org/svn/gcc/trunk@74778
138bc75d-0d04-0410-961f-
82ee72b054a4
+2003-12-18 Ulrich Weigand <uweigand@de.ibm.com>
+
+ * loop.c (move_movables): Handle combination of m->consec,
+ m->move_insn_first, and m->insert_temp all nonzero correctly.
+
2003-12-18 Kazu Hirata <kazu@cs.umass.edu>
* calls.c (load_register_parameters): Don't use
/* The SET_SRC might not be invariant, so we must
use the REG_EQUAL note. */
start_sequence ();
- emit_move_insn (m->set_dest, m->set_src);
+ emit_move_insn (m->insert_temp ? newreg : m->set_dest,
+ m->set_src);
seq = get_insns ();
end_sequence ();
+2003-12-18 Ulrich Weigand <uweigand@de.ibm.com>
+
+ * gcc.dg/20031216-1.c: New test.
+
2003-12-18 Giovanni Bajo <giovannibajo@gcc.gnu.org>
PR c++/9154
--- /dev/null
+/* This used to abort due to a loop bug on s390*. */
+
+/* { dg-do run } */
+/* { dg-options "-O2" } */
+/* { dg-options "-O2 -fPIC" { target s390*-*-* } } */
+
+int count = 0;
+char *str;
+
+void test (int flag)
+{
+ char *p;
+
+ for (;;)
+ {
+ if (count > 5)
+ return;
+
+ p = "test";
+
+ if (flag)
+ count++;
+
+ str = p;
+ }
+}
+
+int main (void)
+{
+ test (1);
+
+ if (str[0] != 't')
+ abort ();
+
+ return 0;
+}
+