From a601baa0f795f5f3df9bfa326be8feb1d7e0c2dc Mon Sep 17 00:00:00 2001 From: Jakub Jelinek Date: Fri, 14 Nov 2014 20:41:00 +0100 Subject: [PATCH] tree-ssa.dce.c (eliminate_unnecessary_stmts): Eliminate IFN_GOMP_SIMD_LANE without lhs as useless. * tree-ssa.dce.c (eliminate_unnecessary_stmts): Eliminate IFN_GOMP_SIMD_LANE without lhs as useless. From-SVN: r217584 --- gcc/ChangeLog | 3 +++ gcc/tree-ssa-dce.c | 5 +++++ 2 files changed, 8 insertions(+) diff --git a/gcc/ChangeLog b/gcc/ChangeLog index c5ea4811458..161b2a03f17 100644 --- a/gcc/ChangeLog +++ b/gcc/ChangeLog @@ -1,5 +1,8 @@ 2014-11-14 Jakub Jelinek + * tree-ssa.dce.c (eliminate_unnecessary_stmts): Eliminate + IFN_GOMP_SIMD_LANE without lhs as useless. + * ipa-pure-const.c (struct funct_state_d): Add can_free field. (varying_state): Add true for can_free. (check_call): For builtin or internal !nonfreeing_call_p set diff --git a/gcc/tree-ssa-dce.c b/gcc/tree-ssa-dce.c index 6543dc7d26a..3a230584853 100644 --- a/gcc/tree-ssa-dce.c +++ b/gcc/tree-ssa-dce.c @@ -1402,6 +1402,11 @@ eliminate_unnecessary_stmts (void) maybe_clean_or_replace_eh_stmt (stmt, stmt); update_stmt (stmt); release_ssa_name (name); + + /* GOMP_SIMD_LANE without lhs is not needed. */ + if (gimple_call_internal_p (stmt) + && gimple_call_internal_fn (stmt) == IFN_GOMP_SIMD_LANE) + remove_dead_stmt (&gsi, bb); } else if (gimple_call_internal_p (stmt)) switch (gimple_call_internal_fn (stmt)) -- 2.30.2