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)
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;
--- /dev/null
+! { 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