diff options
author | Richard Biener <rguenther@suse.de> | 2024-07-25 12:46:30 +0200 |
---|---|---|
committer | Thomas Koenig <tkoenig@gcc.gnu.org> | 2024-07-28 19:05:57 +0200 |
commit | 3257d6e954c9650940162f08613fee25602ec5d4 (patch) | |
tree | 7c6848d3bf354c77a1560c79efe04f49d4ecefcc | |
parent | b42f73132c51aece4bed43cdceb4b8cf31197a2b (diff) | |
download | gcc-3257d6e954c9650940162f08613fee25602ec5d4.zip gcc-3257d6e954c9650940162f08613fee25602ec5d4.tar.gz gcc-3257d6e954c9650940162f08613fee25602ec5d4.tar.bz2 |
tree-optimization/116081 - typedef vs. non-typedef in vectorization
The following fixes the code generation difference when using
a typedef for the scalar type. The issue is using a pointer
equality test for an INTEGER_CST which fails when the types
are different variants.
PR tree-optimization/116081
* tree-vect-loop.cc (get_initial_defs_for_reduction):
Use operand_equal_p for comparing the element with the
neutral op.
-rw-r--r-- | gcc/tree-vect-loop.cc | 2 |
1 files changed, 1 insertions, 1 deletions
diff --git a/gcc/tree-vect-loop.cc b/gcc/tree-vect-loop.cc index d7d628e..856ce49 100644 --- a/gcc/tree-vect-loop.cc +++ b/gcc/tree-vect-loop.cc @@ -5652,7 +5652,7 @@ get_initial_defs_for_reduction (loop_vec_info loop_vinfo, init = gimple_build_vector_from_val (&ctor_seq, vector_type, neutral_op); int k = nunits; - while (k > 0 && elts[k - 1] == neutral_op) + while (k > 0 && operand_equal_p (elts[k - 1], neutral_op)) k -= 1; while (k > 0) { |