forked from OSchip/llvm-project
Change -analyzer-max-nodes to allow 0 as a parameter. This allows the analyzer to completely analyze a worklist regardless of time taken.
llvm-svn: 115108
This commit is contained in:
parent
83e471180c
commit
472205be35
|
@ -108,7 +108,7 @@ def analyzer_viz_egraph_ubigraph : Flag<"-analyzer-viz-egraph-ubigraph">,
|
|||
def analyzer_inline_call : Flag<"-analyzer-inline-call">,
|
||||
HelpText<"Experimental transfer function inlining callees when its definition is available.">;
|
||||
def analyzer_max_nodes : Separate<"-analyzer-max-nodes">,
|
||||
HelpText<"The maximum number of nodes the analyzer can generate">;
|
||||
HelpText<"The maximum number of nodes the analyzer can generate (150000 default, 0 = no limit)">;
|
||||
def analyzer_max_loop : Separate<"-analyzer-max-loop">,
|
||||
HelpText<"The maximum number of times the analyzer will go through a loop">;
|
||||
|
||||
|
|
|
@ -159,8 +159,16 @@ bool GRCoreEngine::ExecuteWorkList(const LocationContext *L, unsigned Steps,
|
|||
GenerateNode(StartLoc, InitState, 0);
|
||||
}
|
||||
|
||||
while (Steps && WList->hasWork()) {
|
||||
--Steps;
|
||||
// Check if we have a steps limit
|
||||
bool UnlimitedSteps = Steps == 0;
|
||||
|
||||
while (WList->hasWork()) {
|
||||
if (!UnlimitedSteps) {
|
||||
if (Steps == 0)
|
||||
break;
|
||||
--Steps;
|
||||
}
|
||||
|
||||
const GRWorkListUnit& WU = WList->Dequeue();
|
||||
|
||||
// Set the current block counter.
|
||||
|
|
Loading…
Reference in New Issue