aboutsummaryrefslogtreecommitdiff
path: root/gcc
diff options
context:
space:
mode:
authorJakub Jelinek <jakub@redhat.com>2016-12-12 23:02:52 +0100
committerJakub Jelinek <jakub@gcc.gnu.org>2016-12-12 23:02:52 +0100
commit1697df8c99b5b5d0252c7c26113f16f0d0c87c1b (patch)
tree804190b7b83c8a1f184990fb9350a40ad0146095 /gcc
parent27ec22668ffe96569b1860008e398d29f08ebd6c (diff)
downloadgcc-1697df8c99b5b5d0252c7c26113f16f0d0c87c1b.zip
gcc-1697df8c99b5b5d0252c7c26113f16f0d0c87c1b.tar.gz
gcc-1697df8c99b5b5d0252c7c26113f16f0d0c87c1b.tar.bz2
re PR tree-optimization/78777 (ICE in mark_reachable_handlers, at tree-eh.c:3823 (aarch64-linux-gnu))
PR tree-optimization/78777 * gimple-ssa-strength-reduction.c (create_add_on_incoming_edge, insert_initializers): Use stmt_ends_bb_p instead of is_ctrl_stmt. * g++.dg/torture/pr78777.C: New test. From-SVN: r243584
Diffstat (limited to 'gcc')
-rw-r--r--gcc/ChangeLog4
-rw-r--r--gcc/gimple-ssa-strength-reduction.c4
-rw-r--r--gcc/testsuite/ChangeLog5
-rw-r--r--gcc/testsuite/g++.dg/torture/pr78777.C29
4 files changed, 40 insertions, 2 deletions
diff --git a/gcc/ChangeLog b/gcc/ChangeLog
index 50a9cf7..95e8966 100644
--- a/gcc/ChangeLog
+++ b/gcc/ChangeLog
@@ -1,5 +1,9 @@
2016-12-12 Jakub Jelinek <jakub@redhat.com>
+ PR tree-optimization/78777
+ * gimple-ssa-strength-reduction.c (create_add_on_incoming_edge,
+ insert_initializers): Use stmt_ends_bb_p instead of is_ctrl_stmt.
+
PR other/78766
* opt-functions.awk (opt_args): Use [{] instead of { in regexps.
Formatting fix.
diff --git a/gcc/gimple-ssa-strength-reduction.c b/gcc/gimple-ssa-strength-reduction.c
index 21dcbb0..ba82a20 100644
--- a/gcc/gimple-ssa-strength-reduction.c
+++ b/gcc/gimple-ssa-strength-reduction.c
@@ -2253,7 +2253,7 @@ create_add_on_incoming_edge (slsr_cand_t c, tree basis_name,
insert_bb = single_succ_p (e->src) ? e->src : split_edge (e);
gsi = gsi_last_bb (insert_bb);
- if (!gsi_end_p (gsi) && is_ctrl_stmt (gsi_stmt (gsi)))
+ if (!gsi_end_p (gsi) && stmt_ends_bb_p (gsi_stmt (gsi)))
{
gsi_insert_before (&gsi, new_stmt, GSI_SAME_STMT);
if (cast_stmt)
@@ -3243,7 +3243,7 @@ insert_initializers (slsr_cand_t c)
gimple *basis_stmt = lookup_cand (c->basis)->cand_stmt;
location_t loc = gimple_location (basis_stmt);
- if (!gsi_end_p (gsi) && is_ctrl_stmt (gsi_stmt (gsi)))
+ if (!gsi_end_p (gsi) && stmt_ends_bb_p (gsi_stmt (gsi)))
{
if (cast_stmt)
{
diff --git a/gcc/testsuite/ChangeLog b/gcc/testsuite/ChangeLog
index 71a6e2a..b4eea72 100644
--- a/gcc/testsuite/ChangeLog
+++ b/gcc/testsuite/ChangeLog
@@ -1,3 +1,8 @@
+2016-12-12 Jakub Jelinek <jakub@redhat.com>
+
+ PR tree-optimization/78777
+ * g++.dg/torture/pr78777.C: New test.
+
2016-12-12 Martin Sebor <msebor@redhat.com>
PR middle-end/78622
diff --git a/gcc/testsuite/g++.dg/torture/pr78777.C b/gcc/testsuite/g++.dg/torture/pr78777.C
new file mode 100644
index 0000000..451289e
--- /dev/null
+++ b/gcc/testsuite/g++.dg/torture/pr78777.C
@@ -0,0 +1,29 @@
+// PR tree-optimization/78777
+
+void bar (char);
+struct C { char b; };
+struct H { char d[5]; int e; C *f[4]; int g[10]; };
+void baz (C *, unsigned char *, int);
+unsigned char j[10];
+
+void
+foo (H *o, int p, unsigned char *q, int r, char n, H *b)
+{
+ for (int m = 0; m < o->e; m++)
+ {
+ if (o->f[m] || o->g[m])
+ continue;
+ try
+ {
+ baz (o->f[m], j, 5);
+ if (p)
+ baz (o->f[m], q, r);
+ }
+ catch (int)
+ {
+ C a = *o->f[m];
+ if (b)
+ bar (n & a.b);
+ }
+ }
+}