diff options
author | Richard Biener <rguenther@suse.de> | 2023-11-20 11:12:43 +0100 |
---|---|---|
committer | Richard Biener <rguenther@suse.de> | 2023-11-20 14:58:10 +0100 |
commit | 57c028acbec4f7b594e6b024e02d6c799b51e03d (patch) | |
tree | a3eaf40a588eaf027b798e6e90ae573ebcbb86f6 /gcc/tree-vect-loop.cc | |
parent | 3b34902417259031823bff7f853f615a60464bbd (diff) | |
download | gcc-57c028acbec4f7b594e6b024e02d6c799b51e03d.zip gcc-57c028acbec4f7b594e6b024e02d6c799b51e03d.tar.gz gcc-57c028acbec4f7b594e6b024e02d6c799b51e03d.tar.bz2 |
tree-optimization/112618 - unused .MASK_CALL
We have to make sure to remove unused .MASK_CALL internal function
calls after vectorization.
PR tree-optimization/112618
* tree-vect-loop.cc (vect_transform_loop_stmt): For not
relevant and unused .MASK_CALL make sure we remove the
scalar stmt.
* gcc.dg/pr112618.c: New testcase.
Diffstat (limited to 'gcc/tree-vect-loop.cc')
-rw-r--r-- | gcc/tree-vect-loop.cc | 11 |
1 files changed, 10 insertions, 1 deletions
diff --git a/gcc/tree-vect-loop.cc b/gcc/tree-vect-loop.cc index b7675d8..58679e91 100644 --- a/gcc/tree-vect-loop.cc +++ b/gcc/tree-vect-loop.cc @@ -11361,7 +11361,16 @@ vect_transform_loop_stmt (loop_vec_info loop_vinfo, stmt_vec_info stmt_info, if (!STMT_VINFO_RELEVANT_P (stmt_info) && !STMT_VINFO_LIVE_P (stmt_info)) - return false; + { + if (is_gimple_call (stmt_info->stmt) + && gimple_call_internal_p (stmt_info->stmt, IFN_MASK_CALL)) + { + gcc_assert (!gimple_call_lhs (stmt_info->stmt)); + *seen_store = stmt_info; + return false; + } + return false; + } if (STMT_VINFO_VECTYPE (stmt_info)) { |