From 94d5c4563ffc5fdb44851687b3531d5fd4a0d2cc Mon Sep 17 00:00:00 2001 From: Jeffrey A Law Date: Wed, 7 Apr 1999 13:22:29 +0000 Subject: [PATCH] unroll.c (copy_loop_body): Always ensure at least two insns are in the copied loop. * unroll.c (copy_loop_body): Always ensure at least two insns are in the copied loop. From-SVN: r26261 --- gcc/ChangeLog | 5 +++++ gcc/unroll.c | 6 ++++++ 2 files changed, 11 insertions(+) diff --git a/gcc/ChangeLog b/gcc/ChangeLog index da8276f3c32..d33bd4b6344 100644 --- a/gcc/ChangeLog +++ b/gcc/ChangeLog @@ -1,3 +1,8 @@ +Wed Apr 7 14:07:34 1999 Jeffrey A Law (law@cygnus.com) + + * unroll.c (copy_loop_body): Always ensure at least two insns + are in the copied loop. + Wed Apr 7 14:52:18 1999 Catherine Moore * config/mips/elf.h (MAKE_DECL_ONE_ONLY): Define. diff --git a/gcc/unroll.c b/gcc/unroll.c index e119352dc8a..9c0109da86b 100644 --- a/gcc/unroll.c +++ b/gcc/unroll.c @@ -1671,6 +1671,12 @@ copy_loop_body (copy_start, copy_end, map, exit_label, last_iteration, start_sequence (); + /* Emit a NOTE_INSN_DELETED to force at least two insns onto the sequence. + Else gen_sequence could return a raw pattern for a jump which we pass + off to emit_insn_before (instead of emit_jump_insn_before) which causes + a variety of losing behaviors later. */ + emit_note (0, NOTE_INSN_DELETED); + insn = copy_start; do { -- 2.30.2