aboutsummaryrefslogtreecommitdiff
path: root/gcc/tree-data-ref.c
diff options
context:
space:
mode:
authorJakub Jelinek <jakub@redhat.com>2014-02-04 14:08:00 +0100
committerJakub Jelinek <jakub@gcc.gnu.org>2014-02-04 14:08:00 +0100
commit8e91d222caa45afa9dc15aff60df1bf378fe2545 (patch)
treec3cb8d1b945a0700909d02857e6552cf666be347 /gcc/tree-data-ref.c
parenteb259c4a329898bbae30bf7b55f9598fa73c7dd1 (diff)
downloadgcc-8e91d222caa45afa9dc15aff60df1bf378fe2545.zip
gcc-8e91d222caa45afa9dc15aff60df1bf378fe2545.tar.gz
gcc-8e91d222caa45afa9dc15aff60df1bf378fe2545.tar.bz2
re PR tree-optimization/60023 (ICE: verify_gimple failed: dead STMT in EH table with -O3 -fnon-call-exceptions -mavx2)
PR tree-optimization/60023 * tree-if-conv.c (predicate_mem_writes): Pass true instead of false to gsi_replace. * tree-vect-stmts.c (vect_finish_stmt_generation): If stmt has been in some EH region and vec_stmt could throw, add vec_stmt into the same EH region. * tree-data-ref.c (get_references_in_stmt): If IFN_MASK_LOAD has no lhs, ignore it. * internal-fn.c (expand_MASK_LOAD): Likewise. * g++.dg/vect/pr60023.cc: New test. From-SVN: r207464
Diffstat (limited to 'gcc/tree-data-ref.c')
-rw-r--r--gcc/tree-data-ref.c2
1 files changed, 2 insertions, 0 deletions
diff --git a/gcc/tree-data-ref.c b/gcc/tree-data-ref.c
index 91601ef..01d0a7a 100644
--- a/gcc/tree-data-ref.c
+++ b/gcc/tree-data-ref.c
@@ -4401,6 +4401,8 @@ get_references_in_stmt (gimple stmt, vec<data_ref_loc, va_heap> *references)
switch (gimple_call_internal_fn (stmt))
{
case IFN_MASK_LOAD:
+ if (gimple_call_lhs (stmt) == NULL_TREE)
+ break;
ref.is_read = true;
case IFN_MASK_STORE:
ref.ref = fold_build2 (MEM_REF,