=?utf-8?q?Donát?= Nagy <donat.n...@ericsson.com>, =?utf-8?q?Donát?= Nagy <donat.n...@ericsson.com>, =?utf-8?q?Donát?= Nagy <donat.n...@ericsson.com>, =?utf-8?q?Donát?= Nagy <donat.n...@ericsson.com>, =?utf-8?q?Donát?= Nagy <donat.n...@ericsson.com>, =?utf-8?q?Donát?= Nagy <donat.n...@ericsson.com> Message-ID: In-Reply-To: <llvm.org/llvm/llvm-project/pull/109...@github.com>
================ @@ -441,10 +441,32 @@ void CoreEngine::HandleCallEnter(const CallEnter &CE, ExplodedNode *Pred) { void CoreEngine::HandleBranch(const Stmt *Cond, const Stmt *Term, const CFGBlock * B, ExplodedNode *Pred) { assert(B->succ_size() == 2); + + const LocationContext *LC = Pred->getLocationContext(); + BlockCounter Counter = WList->getBlockCounter(); + unsigned BlockCount = + Counter.getNumVisited(LC->getStackFrame(), B->getBlockID()); + std::optional<unsigned> IterationsFinishedInLoop = std::nullopt; + if (isa<ForStmt, WhileStmt, CXXForRangeStmt>(Term)) { + // FIXME: This code approximates the number of finished iterations based on + // the block count, i.e. the number of evaluations of the terminator block + // on the current execution path (which includes the current evaluation, so + // is always >= 1). This is probably acceptable for the checker-specific + // false positive suppression that currently uses this value, but it would + // be better to calcuate an accurate count of iterations. + assert(BlockCount >= 1); + IterationsFinishedInLoop = BlockCount - 1; + } else if (isa<DoStmt>(Term)) { + // FIXME: The fixme note in the previous branch also applies here. + // In a do-while loop one iteration happens before the first evaluation of + // the loop condition, so we don't subtract one from the block count. ---------------- isuckatcs wrote: I think both of these `FIXME`s could be addressed by maintaining a state trait, where you track the current iteration count for the loop. That way you don't depend on the execution path, only on the current loop that you are visiting. E.g.: entering loop -> set the trait finsihed iteration -> increment the trait exiting loop -> remove trait This is probably a different patch anyway. 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