]> git.ipfire.org Git - thirdparty/gcc.git/commitdiff
re PR tree-optimization/16808 (verify_ssa failed: Missing definition for SSA_NAME)
authorAndrew Pinski <pinskia@physics.uc.edu>
Tue, 2 Nov 2004 16:38:18 +0000 (16:38 +0000)
committerAndrew Pinski <pinskia@gcc.gnu.org>
Tue, 2 Nov 2004 16:38:18 +0000 (08:38 -0800)
2004-11-02  Andrew Pinski  <pinskia@physics.uc.edu>

        PR tree-opt/16808
        * gcc.c-torture/compile/pr16808.c: New test.

2004-11-02  Andrew Pinski  <pinskia@physics.uc.edu>

        PR tree-opt/16808
        * tree-ssa.c (replace_immediate_uses): If we call fold_stmt, make sure
        that the vops get marked for renaming.

From-SVN: r89990

gcc/ChangeLog
gcc/testsuite/ChangeLog
gcc/testsuite/gcc.c-torture/compile/pr16808.c [new file with mode: 0644]
gcc/tree-ssa.c

index e3ef271a0fe12835f4e7fbf92c37bd7c0eaee64d..00dc1027ea9dc03d9c98ff02c8a3e03a21a81c47 100644 (file)
@@ -1,3 +1,9 @@
+2004-11-02  Andrew Pinski  <pinskia@physics.uc.edu>
+
+       PR tree-opt/16808
+       * tree-ssa.c (replace_immediate_uses): If we call fold_stmt, make sure
+       that the vops get marked for renaming.
+
 2004-11-02  Andreas Krebbel  <krebbel1@de.ibm.com>
 
        * config/s390/s390.md ("movcc"): Set type attribute.
index 296b5c689bd938e8d4c6de09921d4e1b7aec0c23..4fea20658781185d7a705dca78d77c1b4cfa20f6 100644 (file)
@@ -1,3 +1,8 @@
+2004-11-02  Andrew Pinski  <pinskia@physics.uc.edu>
+
+       PR tree-opt/16808
+       * gcc.c-torture/compile/pr16808.c: New test.
+
 2004-11-02  Nathan Sidwell  <nathan@codesourcery.com>
 
        PR rtl-optimization/17104
diff --git a/gcc/testsuite/gcc.c-torture/compile/pr16808.c b/gcc/testsuite/gcc.c-torture/compile/pr16808.c
new file mode 100644 (file)
index 0000000..28527de
--- /dev/null
@@ -0,0 +1,38 @@
+/* We used to ICE as we did not mark a Vop for rename as
+   we changed a function call to a normal modify statement
+   while folding exp(0.0); */
+
+double exp(double);
+void f0(void);
+void f(double);
+typedef struct Parser {
+    int x;
+    char *s;
+} Parser;
+static double pop(Parser *p) {
+    if (p->s[0] <= 0) {
+       f0();
+       return 0;
+    }
+    --p->x;
+    return 0;
+}
+static void evalFactor(Parser *p) {
+    while (p->x)
+       f(exp(pop(p)));
+}
+static void evalTerm(Parser *p) {
+    while (p->s[0])
+       evalFactor(p);
+}
+static void evalExpression(Parser *p) {
+    evalTerm(p);
+    while (p->s[0])
+       evalTerm(p);
+}
+void evalPrimary(Parser *p) {
+    if (p->s)
+       return;
+    evalExpression(p);
+}
+
index 3ba15ee3c1ccf0a703eb5903ade9db29f20a3b68..8002565d3437d835e368306d106fe1758afeb5f0 100644 (file)
@@ -1124,6 +1124,7 @@ replace_immediate_uses (tree var, tree repl)
        {
          tree tmp = stmt;
          fold_stmt (&tmp);
+          mark_new_vars = true;
          if (tmp != stmt)
            {
              block_stmt_iterator si = bsi_for_stmt (stmt);