diff options
author | Richard Guenther <rguenther@suse.de> | 2006-03-14 12:50:10 +0000 |
---|---|---|
committer | Richard Biener <rguenth@gcc.gnu.org> | 2006-03-14 12:50:10 +0000 |
commit | b5564e87d4237cd8fd1d926dcee6df27707e87f7 (patch) | |
tree | 19e4dea139dd060d0cd57bb423461e38b906afee | |
parent | 6971d714fe697f099327fcfac909497e1a7e906d (diff) | |
download | gcc-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/ChangeLog | 6 | ||||
-rw-r--r-- | gcc/testsuite/ChangeLog | 5 | ||||
-rw-r--r-- | gcc/testsuite/gcc.dg/torture/pr26672.c | 8 | ||||
-rw-r--r-- | gcc/tree-ssa-propagate.c | 3 |
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. */ |