diff options
Diffstat (limited to 'gcc')
-rw-r--r-- | gcc/ChangeLog | 6 | ||||
-rw-r--r-- | gcc/testsuite/ChangeLog | 5 | ||||
-rw-r--r-- | gcc/testsuite/gcc.dg/vect/bb-slp-37.c | 32 | ||||
-rw-r--r-- | gcc/tree-vect-slp.c | 4 |
4 files changed, 46 insertions, 1 deletions
diff --git a/gcc/ChangeLog b/gcc/ChangeLog index 4cb6446..c4897ca 100644 --- a/gcc/ChangeLog +++ b/gcc/ChangeLog @@ -1,3 +1,9 @@ +2015-06-09 Richard Biener <rguenther@suse.de> + + PR tree-optimization/66419 + * tree-vect-slp.c (vect_supported_load_permutation_p): Properly + consider GROUP_GAP when detecting a perfect subchain. + 2015-06-09 Nick Clifton <nickc@redhat.com> * config/rl78/rl78.c (rl78_select_section): When -mes0 is active diff --git a/gcc/testsuite/ChangeLog b/gcc/testsuite/ChangeLog index a51682a..80fba49 100644 --- a/gcc/testsuite/ChangeLog +++ b/gcc/testsuite/ChangeLog @@ -1,3 +1,8 @@ +2015-06-09 Richard Biener <rguenther@suse.de> + + PR tree-optimization/66419 + * gcc.dg/vect/bb-slp-37.c: New testcase. + 2015-06-09 Shiva Chen <shiva0217@gmail.com> * gcc.target/arm/stl-cond.c: New test. diff --git a/gcc/testsuite/gcc.dg/vect/bb-slp-37.c b/gcc/testsuite/gcc.dg/vect/bb-slp-37.c new file mode 100644 index 0000000..dbbba87 --- /dev/null +++ b/gcc/testsuite/gcc.dg/vect/bb-slp-37.c @@ -0,0 +1,32 @@ +/* { dg-require-effective-target vect_int } */ + +#include "tree-vect.h" + +extern void abort (void); + +int a[16]; +int b[4]; + +void __attribute__((noinline)) +foo (void) +{ + b[0] = a[0]; + b[1] = a[4]; + b[2] = a[8]; + b[3] = a[12]; +} + +int main() +{ + int i; + check_vect (); + for (i = 0; i < 16; ++i) + { + a[i] = i; + __asm__ volatile (""); + } + foo (); + if (b[0] != 0 || b[1] != 4 || b[2] != 8 || b[3] != 12) + abort (); + return 0; +} diff --git a/gcc/tree-vect-slp.c b/gcc/tree-vect-slp.c index 9d8211e..660c8b2 100644 --- a/gcc/tree-vect-slp.c +++ b/gcc/tree-vect-slp.c @@ -1439,7 +1439,9 @@ vect_supported_load_permutation_p (slp_instance slp_instn) next_load = NULL; FOR_EACH_VEC_ELT (SLP_TREE_SCALAR_STMTS (node), j, load) { - if (j != 0 && next_load != load) + if (j != 0 + && (next_load != load + || GROUP_GAP (vinfo_for_stmt (load)) != 1)) { subchain_p = false; break; |