diff options
author | jakub <jakub@138bc75d-0d04-0410-961f-82ee72b054a4> | 2014-02-14 07:31:23 +0000 |
---|---|---|
committer | jakub <jakub@138bc75d-0d04-0410-961f-82ee72b054a4> | 2014-02-14 07:31:23 +0000 |
commit | 0b308eeee7200246d04b40353d4ab5c55b8ec486 (patch) | |
tree | a4d5bc6cbd4a114aa316acf111f478c3059b4d08 /gcc | |
parent | 0f32a27e3473a17ae6099f67d43432000bdf5521 (diff) | |
download | gcc-0b308eeee7200246d04b40353d4ab5c55b8ec486.tar.gz |
* tree-vect-loop.c (vect_is_slp_reduction): Don't set
use_stmt twice.
(get_initial_def_for_induction, vectorizable_induction): Ignore
debug stmts when looking for exit_phi.
(vectorizable_live_operation): Fix up condition.
* gcc.c-torture/compile/20140213.c: New test.
git-svn-id: svn+ssh://gcc.gnu.org/svn/gcc/trunk@207778 138bc75d-0d04-0410-961f-82ee72b054a4
Diffstat (limited to 'gcc')
-rw-r--r-- | gcc/ChangeLog | 8 | ||||
-rw-r--r-- | gcc/testsuite/ChangeLog | 4 | ||||
-rw-r--r-- | gcc/testsuite/gcc.c-torture/compile/20140213.c | 21 | ||||
-rw-r--r-- | gcc/tree-vect-loop.c | 25 |
4 files changed, 48 insertions, 10 deletions
diff --git a/gcc/ChangeLog b/gcc/ChangeLog index 3b9468d0766..99d55bfd84a 100644 --- a/gcc/ChangeLog +++ b/gcc/ChangeLog @@ -1,3 +1,11 @@ +2014-02-14 Jakub Jelinek <jakub@redhat.com> + + * tree-vect-loop.c (vect_is_slp_reduction): Don't set + use_stmt twice. + (get_initial_def_for_induction, vectorizable_induction): Ignore + debug stmts when looking for exit_phi. + (vectorizable_live_operation): Fix up condition. + 2014-02-14 Chung-Ju Wu <jasonwucj@gmail.com> * config/nds32/nds32.c (nds32_asm_function_prologue): Do not use diff --git a/gcc/testsuite/ChangeLog b/gcc/testsuite/ChangeLog index 881aa3df2a0..b2fefd0875a 100644 --- a/gcc/testsuite/ChangeLog +++ b/gcc/testsuite/ChangeLog @@ -1,3 +1,7 @@ +2014-02-14 Jakub Jelinek <jakub@redhat.com> + + * gcc.c-torture/compile/20140213.c: New test. + 2014-02-13 Jakub Jelinek <jakub@redhat.com> PR target/43546 diff --git a/gcc/testsuite/gcc.c-torture/compile/20140213.c b/gcc/testsuite/gcc.c-torture/compile/20140213.c new file mode 100644 index 00000000000..3811caa2234 --- /dev/null +++ b/gcc/testsuite/gcc.c-torture/compile/20140213.c @@ -0,0 +1,21 @@ +static unsigned short +foo (unsigned char *x, int y) +{ + unsigned short r = 0; + int i; + for (i = 0; i < y; i++) + r += x[i]; + return r; +} + +int baz (int, unsigned short); + +void +bar (unsigned char *x, unsigned char *y) +{ + int i; + unsigned short key = foo (x, 0x10000); + baz (0, 0); + for (i = 0; i < 0x80000; i++) + y[i] = x[baz (i, key)]; +} diff --git a/gcc/tree-vect-loop.c b/gcc/tree-vect-loop.c index ab4d06fef33..838803ebe52 100644 --- a/gcc/tree-vect-loop.c +++ b/gcc/tree-vect-loop.c @@ -1968,10 +1968,8 @@ vect_is_slp_reduction (loop_vec_info loop_info, gimple phi, gimple first_stmt) FOR_EACH_IMM_USE_FAST (use_p, imm_iter, lhs) { gimple use_stmt = USE_STMT (use_p); - if (is_gimple_debug (use_stmt)) - continue; - - use_stmt = USE_STMT (use_p); + if (is_gimple_debug (use_stmt)) + continue; /* Check if we got back to the reduction phi. */ if (use_stmt == phi) @@ -3507,9 +3505,13 @@ get_initial_def_for_induction (gimple iv_phi) exit_phi = NULL; FOR_EACH_IMM_USE_FAST (use_p, imm_iter, loop_arg) { - if (!flow_bb_inside_loop_p (iv_loop, gimple_bb (USE_STMT (use_p)))) + gimple use_stmt = USE_STMT (use_p); + if (is_gimple_debug (use_stmt)) + continue; + + if (!flow_bb_inside_loop_p (iv_loop, gimple_bb (use_stmt))) { - exit_phi = USE_STMT (use_p); + exit_phi = use_stmt; break; } } @@ -5413,10 +5415,13 @@ vectorizable_induction (gimple phi, gimple_stmt_iterator *gsi ATTRIBUTE_UNUSED, loop_arg = PHI_ARG_DEF_FROM_EDGE (phi, latch_e); FOR_EACH_IMM_USE_FAST (use_p, imm_iter, loop_arg) { - if (!flow_bb_inside_loop_p (loop->inner, - gimple_bb (USE_STMT (use_p)))) + gimple use_stmt = USE_STMT (use_p); + if (is_gimple_debug (use_stmt)) + continue; + + if (!flow_bb_inside_loop_p (loop->inner, gimple_bb (use_stmt))) { - exit_phi = USE_STMT (use_p); + exit_phi = use_stmt; break; } } @@ -5514,7 +5519,7 @@ vectorizable_live_operation (gimple stmt, { gimple use_stmt = USE_STMT (use_p); if (gimple_code (use_stmt) == GIMPLE_PHI - || gimple_bb (use_stmt) == merge_bb) + && gimple_bb (use_stmt) == merge_bb) { if (vec_stmt) { |