aboutsummaryrefslogtreecommitdiff
diff options
context:
space:
mode:
authorRichard Guenther <rguenther@suse.de>2006-03-14 12:50:10 +0000
committerRichard Biener <rguenth@gcc.gnu.org>2006-03-14 12:50:10 +0000
commitb5564e87d4237cd8fd1d926dcee6df27707e87f7 (patch)
tree19e4dea139dd060d0cd57bb423461e38b906afee
parent6971d714fe697f099327fcfac909497e1a7e906d (diff)
downloadgcc-b5564e87d4237cd8fd1d926dcee6df27707e87f7.zip
gcc-b5564e87d4237cd8fd1d926dcee6df27707e87f7.tar.gz
gcc-b5564e87d4237cd8fd1d926dcee6df27707e87f7.tar.bz2
re PR tree-optimization/26672 (ICE in op_iter_init, triggered by printf->puts optimization)
2006-03-14 Richard Guenther <rguenther@suse.de> PR tree-optimization/26672 * tree-ssa-propagate.c (set_rhs): Don't walk DEFs if not in SSA form. * gcc.dg/torture/pr26672.c: New testcase. From-SVN: r112050
-rw-r--r--gcc/ChangeLog6
-rw-r--r--gcc/testsuite/ChangeLog5
-rw-r--r--gcc/testsuite/gcc.dg/torture/pr26672.c8
-rw-r--r--gcc/tree-ssa-propagate.c3
4 files changed, 21 insertions, 1 deletions
diff --git a/gcc/ChangeLog b/gcc/ChangeLog
index 63d589b..813e37d 100644
--- a/gcc/ChangeLog
+++ b/gcc/ChangeLog
@@ -1,5 +1,11 @@
2006-03-14 Richard Guenther <rguenther@suse.de>
+ PR tree-optimization/26672
+ * tree-ssa-propagate.c (set_rhs): Don't walk DEFs if not in
+ SSA form.
+
+2006-03-14 Richard Guenther <rguenther@suse.de>
+
PR tree-optimization/26667
* ipa-inline.c (cgraph_check_inline_limits): Walk the correct
node for the callees. Always allow inlining if it will shrink
diff --git a/gcc/testsuite/ChangeLog b/gcc/testsuite/ChangeLog
index 5d89feb..e955f5e 100644
--- a/gcc/testsuite/ChangeLog
+++ b/gcc/testsuite/ChangeLog
@@ -1,3 +1,8 @@
+2006-03-14 Richard Guenther <rguenther@suse.de>
+
+ PR tree-optimization/26672
+ * gcc.dg/torture/pr26672.c: New testcase.
+
2006-03-14 Joseph S. Myers <joseph@codesourcery.com>
* gcc.target/powerpc/405-dlmzb-strlen-1.c,
diff --git a/gcc/testsuite/gcc.dg/torture/pr26672.c b/gcc/testsuite/gcc.dg/torture/pr26672.c
new file mode 100644
index 0000000..b13b5dc
--- /dev/null
+++ b/gcc/testsuite/gcc.dg/torture/pr26672.c
@@ -0,0 +1,8 @@
+/* { dg-do compile } */
+
+int printf(const char *format, ...);
+extern const char help_string[];
+void app_opts(void) {
+ printf("%s", help_string);
+}
+const char help_string[] = "foo\n";
diff --git a/gcc/tree-ssa-propagate.c b/gcc/tree-ssa-propagate.c
index dcdc6ad..00d5a94 100644
--- a/gcc/tree-ssa-propagate.c
+++ b/gcc/tree-ssa-propagate.c
@@ -632,7 +632,8 @@ set_rhs (tree *stmt_p, tree expr)
*stmt_p = TREE_SIDE_EFFECTS (expr) ? expr : build_empty_stmt ();
(*stmt_p)->common.ann = (tree_ann_t) ann;
- if (TREE_SIDE_EFFECTS (expr))
+ if (in_ssa_p
+ && TREE_SIDE_EFFECTS (expr))
{
/* Fix all the SSA_NAMEs created by *STMT_P to point to its new
replacement. */