================ @@ -2808,27 +2825,63 @@ void ExprEngine::processBranch(const Stmt *Condition, std::tie(StTrue, StFalse) = *KnownCondValueAssumption; else { assert(!isa<ObjCForCollectionStmt>(Condition)); + // TODO: instead of this shortcut perhaps it would be better to "rejoin" + // the common execution path with + // StTrue = StFalse = PrevState; builder.generateNode(PrevState, true, PredN); builder.generateNode(PrevState, false, PredN); continue; } if (StTrue && StFalse) assert(!isa<ObjCForCollectionStmt>(Condition)); + const Expr *EagerlyAssumeExpr = + PrevState->get<LastEagerlyAssumeAssumptionAt>(); + const Expr *ConditionExpr = dyn_cast<Expr>(Condition); + if (ConditionExpr) + ConditionExpr = ConditionExpr->IgnoreParenCasts(); + bool DidEagerlyAssume = EagerlyAssumeExpr == ConditionExpr; + bool BothFeasible = (DidEagerlyAssume || (StTrue && StFalse)) && + builder.isFeasible(true) && builder.isFeasible(false); + // Process the true branch. if (builder.isFeasible(true)) { - if (StTrue) + if (StTrue) { + if (BothFeasible && IterationsFinishedInLoop && + *IterationsFinishedInLoop >= 2) { ---------------- NagyDonat wrote:
Because that's the natural value here; see my top-level comment. https://github.com/llvm/llvm-project/pull/109804 _______________________________________________ cfe-commits mailing list cfe-commits@lists.llvm.org https://lists.llvm.org/cgi-bin/mailman/listinfo/cfe-commits