From: Richard Henderson Date: Tue, 7 Jun 2005 23:45:06 +0000 (-0700) Subject: re PR rtl-optimization/21528 (Boost shared_ptr_test.cpp fails with -O3) X-Git-Url: https://git.libre-soc.org/?a=commitdiff_plain;h=3b009185b3b4a8f44bd656db309e9440d0be89f4;p=gcc.git re PR rtl-optimization/21528 (Boost shared_ptr_test.cpp fails with -O3) PR rtl-opt/21528 * rtlanal.c (reg_overlap_mentioned_p) : Handle 'E' formats. From-SVN: r100730 --- diff --git a/gcc/ChangeLog b/gcc/ChangeLog index fbd36e16f08..b504b101acb 100644 --- a/gcc/ChangeLog +++ b/gcc/ChangeLog @@ -1,3 +1,8 @@ +2005-06-07 Richard Henderson + + PR rtl-opt/21528 + * rtlanal.c (reg_overlap_mentioned_p) : Handle 'E' formats. + 2005-06-07 Dale Johannesen * tree-nested.c (finalize_nesting_tree_1): Disable diff --git a/gcc/rtlanal.c b/gcc/rtlanal.c index 0bdcbbadbcf..2561e32f661 100644 --- a/gcc/rtlanal.c +++ b/gcc/rtlanal.c @@ -1309,8 +1309,18 @@ reg_overlap_mentioned_p (rtx x, rtx in) fmt = GET_RTX_FORMAT (GET_CODE (in)); for (i = GET_RTX_LENGTH (GET_CODE (in)) - 1; i >= 0; i--) - if (fmt[i] == 'e' && reg_overlap_mentioned_p (x, XEXP (in, i))) - return 1; + if (fmt[i] == 'e') + { + if (reg_overlap_mentioned_p (x, XEXP (in, i))) + return 1; + } + else if (fmt[i] == 'E') + { + int j; + for (j = XVECLEN (in, i) - 1; j >= 0; --j) + if (reg_overlap_mentioned_p (x, XVECEXP (in, i, j))) + return 1; + } return 0; }