diff options
author | Bin Cheng <bin.cheng@arm.com> | 2017-06-29 10:41:28 +0000 |
---|---|---|
committer | Bin Cheng <amker@gcc.gnu.org> | 2017-06-29 10:41:28 +0000 |
commit | 6cd83bec4b76e19175a425b7e1841d9c5d0d164e (patch) | |
tree | c6e71e3aaba5005f83a4159c4ed5f4696d06f7d8 /gcc | |
parent | a7c9a3042453642fd220e01b2063307cd479472a (diff) | |
download | gcc-6cd83bec4b76e19175a425b7e1841d9c5d0d164e.zip gcc-6cd83bec4b76e19175a425b7e1841d9c5d0d164e.tar.gz gcc-6cd83bec4b76e19175a425b7e1841d9c5d0d164e.tar.bz2 |
re PR tree-optimization/81196 (Number of iterations found for p!=q but not for p<q)
PR tree-optimization/81196
* tree-ssa-loop-niter.c (number_of_iterations_cond): Handle loop
exit condition comparing two IVs.
gcc/testsuite
* gcc.dg/vect/pr81196.c: New.
From-SVN: r249778
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/pr81196.c | 19 | ||||
-rw-r--r-- | gcc/tree-ssa-loop-niter.c | 30 |
4 files changed, 53 insertions, 7 deletions
diff --git a/gcc/ChangeLog b/gcc/ChangeLog index af354cc..bed5b90 100644 --- a/gcc/ChangeLog +++ b/gcc/ChangeLog @@ -1,3 +1,9 @@ +2017-06-29 Bin Cheng <bin.cheng@arm.com> + + PR tree-optimization/81196 + * tree-ssa-loop-niter.c (number_of_iterations_cond): Handle loop + exit condition comparing two IVs. + 2017-06-29 Richard Earnshaw <rearnsha@arm.com> * config/arm/parsecpu.awk (gen_comm_data): Add initializer for diff --git a/gcc/testsuite/ChangeLog b/gcc/testsuite/ChangeLog index cf4d7e6..c38422a 100644 --- a/gcc/testsuite/ChangeLog +++ b/gcc/testsuite/ChangeLog @@ -1,3 +1,8 @@ +2017-06-29 Bin Cheng <bin.cheng@arm.com> + + PR tree-optimization/81196 + * gcc.dg/vect/pr81196.c: New. + 2017-06-29 Michael Collison <michael.collison@arm.com> Fix date on previous ChangeLog entry. diff --git a/gcc/testsuite/gcc.dg/vect/pr81196.c b/gcc/testsuite/gcc.dg/vect/pr81196.c new file mode 100644 index 0000000..46d7a9e --- /dev/null +++ b/gcc/testsuite/gcc.dg/vect/pr81196.c @@ -0,0 +1,19 @@ +/* { dg-do compile } */ +/* { dg-require-effective-target vect_int } */ +/* { dg-require-effective-target vect_perm_short } */ + +void f(short*p){ + p=(short*)__builtin_assume_aligned(p,64); + short*q=p+256; + for(;p!=q;++p,--q){ + short t=*p;*p=*q;*q=t; + } +} +void b(short*p){ + p=(short*)__builtin_assume_aligned(p,64); + short*q=p+256; + for(;p<q;++p,--q){ + short t=*p;*p=*q;*q=t; + } +} +/* { dg-final { scan-tree-dump-times "vectorized 1 loops" 2 "vect" } } */ diff --git a/gcc/tree-ssa-loop-niter.c b/gcc/tree-ssa-loop-niter.c index 848e812..5a7cab5 100644 --- a/gcc/tree-ssa-loop-niter.c +++ b/gcc/tree-ssa-loop-niter.c @@ -1668,18 +1668,34 @@ number_of_iterations_cond (struct loop *loop, exit_must_be_taken = true; } - /* We can handle the case when neither of the sides of the comparison is - invariant, provided that the test is NE_EXPR. This rarely occurs in - practice, but it is simple enough to manage. */ + /* We can handle cases which neither of the sides of the comparison is + invariant: + + {iv0.base, iv0.step} cmp_code {iv1.base, iv1.step} + as if: + {iv0.base, iv0.step - iv1.step} cmp_code {iv1.base, 0} + + provided that either below condition is satisfied: + + a) the test is NE_EXPR; + b) iv0.step - iv1.step is positive integer. + + This rarely occurs in practice, but it is simple enough to manage. */ if (!integer_zerop (iv0->step) && !integer_zerop (iv1->step)) { tree step_type = POINTER_TYPE_P (type) ? sizetype : type; - if (code != NE_EXPR) + tree step = fold_binary_to_constant (MINUS_EXPR, step_type, + iv0->step, iv1->step); + + /* No need to check sign of the new step since below code takes care + of this well. */ + if (code != NE_EXPR && TREE_CODE (step) != INTEGER_CST) return false; - iv0->step = fold_binary_to_constant (MINUS_EXPR, step_type, - iv0->step, iv1->step); - iv0->no_overflow = false; + iv0->step = step; + if (!POINTER_TYPE_P (type)) + iv0->no_overflow = false; + iv1->step = build_int_cst (step_type, 0); iv1->no_overflow = true; } |