From: bonzini Date: Thu, 26 May 2005 07:58:47 +0000 (+0000) Subject: 2005-05-26 Paolo Bonzini X-Git-Tag: upstream/4.9.2~60916 X-Git-Url: http://review.tizen.org/git/?a=commitdiff_plain;h=bca23cb7b229239882285ef126c3f766a932af85;p=platform%2Fupstream%2Flinaro-gcc.git 2005-05-26 Paolo Bonzini * tree-vect-transform.c (vectorizable_operation): Try word_mode vectorization if UNITS_PER_WORD == UNITS_PER_SIMD_WORD, even if a vector mode is available. testsuite/ChangeLog: 2005-05-26 Paolo Bonzini * gcc.dg/vect/vect-7.c: Remove xfail for alpha. git-svn-id: svn+ssh://gcc.gnu.org/svn/gcc/trunk@100195 138bc75d-0d04-0410-961f-82ee72b054a4 --- diff --git a/gcc/ChangeLog b/gcc/ChangeLog index 6d9e69f..73e4675 100644 --- a/gcc/ChangeLog +++ b/gcc/ChangeLog @@ -1,3 +1,9 @@ +2005-05-26 Paolo Bonzini + + * tree-vect-transform.c (vectorizable_operation): Try word_mode + vectorization if UNITS_PER_WORD == UNITS_PER_SIMD_WORD, even + if a vector mode is available. + 2005-05-25 Roger Sayle PR middle-end/21709 @@ -1044,6 +1050,10 @@ 2005-05-17 Paolo Bonzini + * tree-ssa-math-opts.c: New file. + +2005-05-17 Paolo Bonzini + * Makefile.in: Add tree-ssa-math-opts.c. * expr.c (expand_expr_real_1) : Never emit as a*(1/b). * fold-const.c (distribute_real_division): New. diff --git a/gcc/testsuite/ChangeLog b/gcc/testsuite/ChangeLog index e7747a3..ae03c42 100644 --- a/gcc/testsuite/ChangeLog +++ b/gcc/testsuite/ChangeLog @@ -1,3 +1,7 @@ +2005-05-26 Paolo Bonzini + + * gcc.dg/vect/vect-7.c: Remove xfail for alpha. + 2005-05-26 Andreas Jaeger * gcc.dg/tree-ssa/ssa-pre-14.c (foo): Use correct type for strlen. diff --git a/gcc/testsuite/gcc.dg/vect/vect-7.c b/gcc/testsuite/gcc.dg/vect/vect-7.c index c753de8..e359bbe 100644 --- a/gcc/testsuite/gcc.dg/vect/vect-7.c +++ b/gcc/testsuite/gcc.dg/vect/vect-7.c @@ -45,7 +45,7 @@ int main (void) return main1 (); } -/* Fails for targets that don't vectorize PLUS. */ -/* { dg-final { scan-tree-dump-times "vectorized 2 loops" 1 "vect" { xfail alpha*-*-* } } } */ +/* Fails for 32-bit targets that don't vectorize PLUS. */ +/* { dg-final { scan-tree-dump-times "vectorized 2 loops" 1 "vect" } } */ /* { dg-final { scan-tree-dump-times "Vectorizing an unaligned access" 0 "vect" } } */ /* { dg-final { cleanup-tree-dump "vect" } } */ diff --git a/gcc/tree-vect-transform.c b/gcc/tree-vect-transform.c index 17d6589..5b5bf22 100644 --- a/gcc/tree-vect-transform.c +++ b/gcc/tree-vect-transform.c @@ -815,7 +815,12 @@ vectorizable_operation (tree stmt, block_stmt_iterator *bsi, tree *vec_stmt) { if (vect_print_dump_info (REPORT_DETAILS, UNKNOWN_LOC)) fprintf (vect_dump, "op not supported by target."); - return false; + if (GET_MODE_SIZE (vec_mode) != UNITS_PER_WORD + || LOOP_VINFO_VECT_FACTOR (loop_vinfo) + < vect_min_worthwhile_factor (code)) + return false; + if (vect_print_dump_info (REPORT_DETAILS, UNKNOWN_LOC)) + fprintf (vect_dump, "proceeding using word mode."); } /* Worthwhile without SIMD support? */