summaryrefslogtreecommitdiff
diff options
context:
space:
mode:
authorrguenth <rguenth@138bc75d-0d04-0410-961f-82ee72b054a4>2017-09-05 08:15:21 +0000
committerrguenth <rguenth@138bc75d-0d04-0410-961f-82ee72b054a4>2017-09-05 08:15:21 +0000
commit9b53a7514a42ef1cc590bb96c830fc040c4b4d48 (patch)
tree4e6d55caa111216facd52e6c8a47450ca293be65
parent05b127f6b4cbdc02ac9ff4ebaa69888cf35c00bb (diff)
downloadgcc-9b53a7514a42ef1cc590bb96c830fc040c4b4d48.tar.gz
2017-09-05 Richard Biener <rguenther@suse.de>
PR tree-optimization/82102 * tree-ssa-pre.c (fini_eliminate): Check if lhs is NULL. * gcc.dg/torture/pr82102.c: New testcase. git-svn-id: svn+ssh://gcc.gnu.org/svn/gcc/trunk@251692 138bc75d-0d04-0410-961f-82ee72b054a4
-rw-r--r--gcc/ChangeLog5
-rw-r--r--gcc/testsuite/ChangeLog5
-rw-r--r--gcc/testsuite/gcc.dg/torture/pr82102.c21
-rw-r--r--gcc/tree-ssa-pre.c1
4 files changed, 32 insertions, 0 deletions
diff --git a/gcc/ChangeLog b/gcc/ChangeLog
index 7a824f82a2e..5f60fe27690 100644
--- a/gcc/ChangeLog
+++ b/gcc/ChangeLog
@@ -1,3 +1,8 @@
+2017-09-05 Richard Biener <rguenther@suse.de>
+
+ PR tree-optimization/82102
+ * tree-ssa-pre.c (fini_eliminate): Check if lhs is NULL.
+
2017-09-05 Martin Liska <mliska@suse.cz>
PR tree-optimization/82032
diff --git a/gcc/testsuite/ChangeLog b/gcc/testsuite/ChangeLog
index 28691293aa6..a21730089ed 100644
--- a/gcc/testsuite/ChangeLog
+++ b/gcc/testsuite/ChangeLog
@@ -1,3 +1,8 @@
+2017-09-05 Richard Biener <rguenther@suse.de>
+
+ PR tree-optimization/82102
+ * gcc.dg/torture/pr82102.c: New testcase.
+
2017-09-05 Eric Botcazou <ebotcazou@adacore.com>
* testsuite/gnat.dg/array29.ad[sb]: New test.
diff --git a/gcc/testsuite/gcc.dg/torture/pr82102.c b/gcc/testsuite/gcc.dg/torture/pr82102.c
new file mode 100644
index 00000000000..393f8bf9590
--- /dev/null
+++ b/gcc/testsuite/gcc.dg/torture/pr82102.c
@@ -0,0 +1,21 @@
+/* { dg-do compile } */
+
+void *a, *b;
+struct pt3_i2cbuf {
+ int num_cmds;
+} c;
+void *memcpy(void *, void *, __SIZE_TYPE__);
+void put_stop();
+void translate(struct pt3_i2cbuf *p1, int p2)
+{
+ p1->num_cmds = 0;
+ if (p2)
+ put_stop();
+}
+void pt3_i2c_master_xfer(int p1)
+{
+ translate(&c, p1);
+ memcpy(a, b, c.num_cmds);
+ for (; p1;)
+ ;
+}
diff --git a/gcc/tree-ssa-pre.c b/gcc/tree-ssa-pre.c
index 185c19268ec..f6fa3bbddc0 100644
--- a/gcc/tree-ssa-pre.c
+++ b/gcc/tree-ssa-pre.c
@@ -4860,6 +4860,7 @@ fini_eliminate (void)
lhs = gimple_get_lhs (stmt);
if (inserted_exprs
+ && lhs
&& TREE_CODE (lhs) == SSA_NAME
&& bitmap_bit_p (inserted_exprs, SSA_NAME_VERSION (lhs)))
continue;