From: Ulrich Weigand Date: Mon, 25 Aug 2003 20:10:03 +0000 (+0000) Subject: * combine.c (combine_simplify_rtx): Fix RTL sharing bug. X-Git-Tag: releases/gcc-3.4.0~4080 X-Git-Url: http://git.ipfire.org/cgi-bin/gitweb.cgi?a=commitdiff_plain;h=c62793785d1e305f11ad72d3bd20820da5d3d7c2;p=thirdparty%2Fgcc.git * combine.c (combine_simplify_rtx): Fix RTL sharing bug. From-SVN: r70778 --- diff --git a/gcc/ChangeLog b/gcc/ChangeLog index ff2e17591a38..019fca2fa6ed 100644 --- a/gcc/ChangeLog +++ b/gcc/ChangeLog @@ -1,3 +1,7 @@ +2003-08-25 Ulrich Weigand + + * combine.c (combine_simplify_rtx): Fix RTL sharing bug. + 2003-08-25 Gabriel Dos Reis * pretty-print.h (pp_maybe_newline_and_indent): New macro. diff --git a/gcc/combine.c b/gcc/combine.c index 821acb228844..67e4b0195670 100644 --- a/gcc/combine.c +++ b/gcc/combine.c @@ -3636,9 +3636,11 @@ combine_simplify_rtx (rtx x, enum machine_mode op0_mode, int last, return x; /* Simplify the alternative arms; this may collapse the true and - false arms to store-flag values. */ - true_rtx = subst (true_rtx, pc_rtx, pc_rtx, 0, 0); - false_rtx = subst (false_rtx, pc_rtx, pc_rtx, 0, 0); + false arms to store-flag values. Be careful to use copy_rtx + here since true_rtx or false_rtx might share RTL with x as a + result of the if_then_else_cond call above. */ + true_rtx = subst (copy_rtx (true_rtx), pc_rtx, pc_rtx, 0, 0); + false_rtx = subst (copy_rtx (false_rtx), pc_rtx, pc_rtx, 0, 0); /* If true_rtx and false_rtx are not general_operands, an if_then_else is unlikely to be simpler. */