aboutsummaryrefslogtreecommitdiff
diff options
context:
space:
mode:
-rw-r--r--gcc/ChangeLog4
-rw-r--r--gcc/unroll.c10
2 files changed, 13 insertions, 1 deletions
diff --git a/gcc/ChangeLog b/gcc/ChangeLog
index a56814c5..e61f154 100644
--- a/gcc/ChangeLog
+++ b/gcc/ChangeLog
@@ -1,3 +1,7 @@
+Wed May 5 23:44:15 1999 J"orn Rennecke <amylaar@cygnus.co.uk>
+
+ * unroll.c (copy_loop_body): Don't copy VTOP notes from copy_notes_from.
+
Wed May 5 16:26:13 1999 Vladimir Makarov <vmakarov@tofu.to.cygnus.com>
* function.c (purge_addressof_replacements): Rename into
diff --git a/gcc/unroll.c b/gcc/unroll.c
index f1080aa..7e584c9 100644
--- a/gcc/unroll.c
+++ b/gcc/unroll.c
@@ -2193,9 +2193,17 @@ copy_loop_body (copy_start, copy_end, map, exit_label, last_iteration,
{
for (insn = copy_notes_from; insn != loop_end; insn = NEXT_INSN (insn))
{
+ /* VTOP notes are valid only before the loop exit test.
+ If placed anywhere else, loop may generate bad code.
+ There is no need to test for NOTE_INSN_LOOP_CONT notes
+ here, since COPY_NOTES_FROM will be at most one or two (for cc0)
+ instructions before the last insn in the loop, and if the
+ end test is that short, there will be a VTOP note between
+ the CONT note and the test. */
if (GET_CODE (insn) == NOTE
&& NOTE_LINE_NUMBER (insn) != NOTE_INSN_DELETED
- && NOTE_LINE_NUMBER (insn) != NOTE_INSN_BASIC_BLOCK)
+ && NOTE_LINE_NUMBER (insn) != NOTE_INSN_BASIC_BLOCK
+ && NOTE_LINE_NUMBER (insn) != NOTE_INSN_LOOP_VTOP)
emit_note (NOTE_SOURCE_FILE (insn), NOTE_LINE_NUMBER (insn));
}
}