diff options
author | Richard Biener <rguenther@suse.de> | 2013-01-03 12:34:34 +0000 |
---|---|---|
committer | Richard Biener <rguenth@gcc.gnu.org> | 2013-01-03 12:34:34 +0000 |
commit | 90bb7d7ab2ccd6b7c9c311867e319057b402a075 (patch) | |
tree | 473846c2d8f4055af981fce9809e4eec4c75c2c2 | |
parent | 8190087e812225b4a1cf5bab944a3c3d1c476d0e (diff) | |
download | gcc-90bb7d7ab2ccd6b7c9c311867e319057b402a075.zip gcc-90bb7d7ab2ccd6b7c9c311867e319057b402a075.tar.gz gcc-90bb7d7ab2ccd6b7c9c311867e319057b402a075.tar.bz2 |
re PR tree-optimization/55857 (ICE: verify_ssa failed)
2013-01-03 Richard Biener <rguenther@suse.de>
PR tree-optimization/55857
* tree-vect-stmts.c (vectorizable_load): Do not setup
re-alignment for invariant loads.
* gcc.dg/vect/pr55857-1.c: New testcase.
* gcc.dg/vect/pr55857-2.c: Likewise.
From-SVN: r194850
-rw-r--r-- | gcc/ChangeLog | 6 | ||||
-rw-r--r-- | gcc/testsuite/ChangeLog | 6 | ||||
-rw-r--r-- | gcc/testsuite/gcc.dg/vect/pr55857-1.c | 17 | ||||
-rw-r--r-- | gcc/testsuite/gcc.dg/vect/pr55857-2.c | 21 | ||||
-rw-r--r-- | gcc/tree-vect-stmts.c | 3 |
5 files changed, 52 insertions, 1 deletions
diff --git a/gcc/ChangeLog b/gcc/ChangeLog index da7cc29..0680d23 100644 --- a/gcc/ChangeLog +++ b/gcc/ChangeLog @@ -1,5 +1,11 @@ 2013-01-03 Richard Biener <rguenther@suse.de> + PR tree-optimization/55857 + * tree-vect-stmts.c (vectorizable_load): Do not setup + re-alignment for invariant loads. + +2013-01-03 Richard Biener <rguenther@suse.de> + PR lto/55848 * lto-symtab.c (lto_symtab_merge_decls_1): As last resort, always prefer a built-in decl. diff --git a/gcc/testsuite/ChangeLog b/gcc/testsuite/ChangeLog index 0b77bdd..3beff10 100644 --- a/gcc/testsuite/ChangeLog +++ b/gcc/testsuite/ChangeLog @@ -1,3 +1,9 @@ +2013-01-03 Richard Biener <rguenther@suse.de> + + PR tree-optimization/55857 + * gcc.dg/vect/pr55857-1.c: New testcase. + * gcc.dg/vect/pr55857-2.c: Likewise. + 2013-01-03 Jakub Jelinek <jakub@redhat.com> PR rtl-optimization/55838 diff --git a/gcc/testsuite/gcc.dg/vect/pr55857-1.c b/gcc/testsuite/gcc.dg/vect/pr55857-1.c new file mode 100644 index 0000000..ad41d30 --- /dev/null +++ b/gcc/testsuite/gcc.dg/vect/pr55857-1.c @@ -0,0 +1,17 @@ +/* { dg-do compile } */ + +void +foo (int *data, unsigned len, const int qlp_coeff[], int lp, int residual[]) +{ + int i; + int sum; + for(i = 0; i < (int)len; i++) + { + sum = 0; + sum += qlp_coeff[1] * data[i-2]; + sum += qlp_coeff[0] * data[i-1]; + residual[i] = data[i] - (sum >> lp); + } +} + +/* { dg-final { cleanup-tree-dump "vect" } } */ diff --git a/gcc/testsuite/gcc.dg/vect/pr55857-2.c b/gcc/testsuite/gcc.dg/vect/pr55857-2.c new file mode 100644 index 0000000..3bfff82 --- /dev/null +++ b/gcc/testsuite/gcc.dg/vect/pr55857-2.c @@ -0,0 +1,21 @@ +/* { dg-do compile } */ + +void foo (int *data, unsigned len, const int qlp_coeff[], + unsigned order, int lp, int residual[]) +{ + int i; + int sum; + if(order == 2) + for(i = 0; i < (int)len; i++) + { + sum = 0; + sum += qlp_coeff[1] * data[i-2]; + sum += qlp_coeff[0] * data[i-1]; + residual[i] = data[i] - (sum >> lp); + } + else + for(i = 0; i < (int)len; i++) + residual[i] = data[i] - ((qlp_coeff[0] * data[i-1]) >> lp); +} + +/* { dg-final { cleanup-tree-dump "vect" } } */ diff --git a/gcc/tree-vect-stmts.c b/gcc/tree-vect-stmts.c index da9f12b..dfbce96 100644 --- a/gcc/tree-vect-stmts.c +++ b/gcc/tree-vect-stmts.c @@ -4927,7 +4927,8 @@ vectorizable_load (gimple stmt, gimple_stmt_iterator *gsi, gimple *vec_stmt, if ((alignment_support_scheme == dr_explicit_realign_optimized || alignment_support_scheme == dr_explicit_realign) - && !compute_in_loop) + && !compute_in_loop + && !integer_zerop (DR_STEP (dr))) { msq = vect_setup_realignment (first_stmt, gsi, &realignment_token, alignment_support_scheme, NULL_TREE, |