re PR tree-optimization/41011 (ICE in ipcp_lattice_from_jfunc, at ipa-cp.c:328)
authorRichard Guenther <rguenther@suse.de>
Wed, 12 Aug 2009 17:55:40 +0000 (17:55 +0000)
committerRichard Biener <rguenth@gcc.gnu.org>
Wed, 12 Aug 2009 17:55:40 +0000 (17:55 +0000)
2009-08-12  Richard Guenther  <rguenther@suse.de>

PR tree-optimization/41011
* ipa-cp.c (ipcp_lattice_from_jfunc): Deal with failing fold
and reference constructing.

* gfortran.dg/pr41011.f: New testcase.

From-SVN: r150705

gcc/ChangeLog
gcc/ipa-cp.c
gcc/testsuite/ChangeLog
gcc/testsuite/gfortran.dg/pr41011.f [new file with mode: 0644]

index 2bfd318..a76a372 100644 (file)
@@ -1,3 +1,9 @@
+2009-08-12  Richard Guenther  <rguenther@suse.de>
+
+       PR tree-optimization/41011
+       * ipa-cp.c (ipcp_lattice_from_jfunc): Deal with failing fold
+       and reference constructing.
+
 2009-08-12  Xinliang David Li  <davidxl@google.com>
 
        PR tree-optimization/41012
index df69724..f7782cb 100644 (file)
@@ -302,7 +302,8 @@ ipcp_lattice_from_jfunc (struct ipa_node_params *info, struct ipcp_lattice *lat,
        cst = fold_binary (jfunc->value.pass_through.operation,
                           TREE_TYPE (cst), cst,
                           jfunc->value.pass_through.operand);
-      gcc_assert (cst && is_gimple_ip_invariant (cst));
+      if (!cst || !is_gimple_ip_invariant (cst))
+       lat->type = IPA_BOTTOM;
       lat->constant = cst;
     }
   else if (jfunc->type == IPA_JF_ANCESTOR)
@@ -325,8 +326,13 @@ ipcp_lattice_from_jfunc (struct ipa_node_params *info, struct ipcp_lattice *lat,
       ok = build_ref_for_offset (&t, TREE_TYPE (t),
                                 jfunc->value.ancestor.offset,
                                 jfunc->value.ancestor.type, false);
-      gcc_assert (ok);
-      lat->constant = build_fold_addr_expr (t);
+      if (!ok)
+       {
+         lat->type = IPA_BOTTOM;
+         lat->constant = NULL_TREE;
+       }
+      else
+       lat->constant = build_fold_addr_expr (t);
     }
   else
     lat->type = IPA_BOTTOM;
index 76913f6..fd1aa26 100644 (file)
@@ -1,3 +1,8 @@
+2009-08-12  Richard Guenther  <rguenther@suse.de>
+
+       PR tree-optimization/41011
+       * gfortran.dg/pr41011.f: New testcase.
+
 2009-08-11  Andrew Haley  <aph@redhat.com>
 
        * gcc.target/arm/synchronize.c: New file.
diff --git a/gcc/testsuite/gfortran.dg/pr41011.f b/gcc/testsuite/gfortran.dg/pr41011.f
new file mode 100644 (file)
index 0000000..4ad4a8f
--- /dev/null
@@ -0,0 +1,23 @@
+! { dg-do compile }
+! { dg-options "-O3 -fwhole-file" }
+      CALL UVSET(NX,NY,NZ,HVAR,ZET,NP,DZ,DKM,UM,VM,UG,VG,TM,DCDX, ! { dg-warning "Rank mismatch" }
+     *ITY,ISH,NSMT,F)
+         CALL DCTDX(NX,NY,NX1,NFILT,C(MLAG),DCDX(MLAG),HELP,HELPA,
+     *   HELP,HELPA,FY,FYC,SAVEY)
+      END
+      SUBROUTINE PADEC(DKS,DKDS,HVAR,WM,WG,FN,NS,AN,BN,CN,IT)
+      COMPLEX*16 WM(*),WG(*),FN(*),AN(*),BN(*),CN(*)
+         BN(J)=F4+AS+GAMMA*F2
+         CN(J)=F4-AS+GAMMA*F2
+         FN(J)=(AS+F4-GAMMA*F2)*H2+(F4-AS-GAMMA*F2)*H0+
+     *   H1*(F3-GAMMA/3.D0)+GAMMA*WG(J)-CONST
+      END
+      SUBROUTINE UVSET(NX,NY,NZ,HVAR,ZET,NP,DZ,DKM,UM,VM,UG,VG,TM,
+     *WORK,ITY,IH,NSMT,F)
+      DIMENSION HVAR(*),ZET(*),TM(*),DKM(*),UM(*),VM(*),UG(*),VG(*),
+     *WORK(*)
+      IF(IH.EQ.0) THEN
+         CALL PADEC(DKM,VM,HVAR,WORK(LWM),WORK(LWG), ! { dg-warning "Rank mismatch" }
+     *   WORK(LF),NZ,WORK(LA),WORK(LB),WORK(LC),ITY)
+      ENDIF
+      END