From: Jason Merrill Date: Tue, 29 Apr 2003 20:25:11 +0000 (-0400) Subject: re PR middle-end/10336 (ICE with -Wunreachable-code) X-Git-Tag: releases/gcc-3.4.0~6954 X-Git-Url: http://git.ipfire.org/gitweb.cgi?a=commitdiff_plain;h=72e940d286a2ffee8fafa04431da540d9646622e;p=thirdparty%2Fgcc.git re PR middle-end/10336 (ICE with -Wunreachable-code) PR middle-end/10336 * jump.c (never_reached_warning): Really stop looking if we reach the beginning of the function. From-SVN: r66249 --- diff --git a/gcc/ChangeLog b/gcc/ChangeLog index c22b671de013..b7bb449594ec 100644 --- a/gcc/ChangeLog +++ b/gcc/ChangeLog @@ -1,3 +1,9 @@ +2003-04-29 Jason Merrill + + PR middle-end/10336 + * jump.c (never_reached_warning): Really stop looking if we reach + the beginning of the function. + 2003-04-29 Bob Wilson * config/xtensa/elf.h (SIZE_TYPE, PTRDIFF_TYPE, USER_LABEL_PREFIX): diff --git a/gcc/jump.c b/gcc/jump.c index 5563ee34581a..5bed408fb5ca 100644 --- a/gcc/jump.c +++ b/gcc/jump.c @@ -1912,13 +1912,15 @@ never_reached_warning (avoided_insn, finish) /* Back up to the first of any NOTEs preceding avoided_insn; flow passes us the head of a block, a NOTE_INSN_BASIC_BLOCK, which often follows the line note. */ - for (insn = PREV_INSN (avoided_insn); ; insn = PREV_INSN (insn)) - if (GET_CODE (insn) != NOTE - || NOTE_LINE_NUMBER (insn) == NOTE_INSN_FUNCTION_BEG) - { - insn = NEXT_INSN (insn); + insn = avoided_insn; + while (1) + { + rtx prev = PREV_INSN (insn); + if (prev == NULL_RTX + || GET_CODE (prev) != NOTE) break; - } + insn = prev; + } /* Scan forwards, looking at LINE_NUMBER notes, until we hit a LABEL in case FINISH is NULL, otherwise until we run out of insns. */