Szelethus added inline comments.

================
Comment at: 
clang/lib/StaticAnalyzer/Checkers/RetainCountChecker/RetainCountDiagnostics.cpp:953-957
+      // Let's traverse...
+      for (const ExplodedNode *N = ExprNode;
+           // ...all the nodes corresponding to the given expression...
+           N != nullptr && N->getStmtForDiagnostics() == E;
+           N = N->getFirstPred()) {
----------------
vsavchenko wrote:
> Szelethus wrote:
> > vsavchenko wrote:
> > > NoQ wrote:
> > > > I guess this part should ultimately be written in one place, eg. 
> > > > `ExplodedNode::findTag()` or something like that.
> > > > 
> > > > I'd also really like to explore the possibility to further limit the 
> > > > variety of nodes traversed here. What nodes are typically traversed 
> > > > here? Is it checker-tagged nodes or is it purge dead symbol nodes or 
> > > > something else?
> > > Yes, `ExplodedNode::findTag()` sounds like a great idea!
> > > 
> > > I mean it is hard to tell without calculating statistics right here and 
> > > running it on a bunch of projects.  However, it is always possible to 
> > > write the code that will have it the other way.  My take on it is that it 
> > > is probably a mix of things.
> > > 
> > > I'd also prefer to traverse less, do you have any specific ideas here?
> > > I'd also really like to explore the possibility to further limit the 
> > > variety of nodes traversed here. What nodes are typically traversed here? 
> > > Is it checker-tagged nodes or is it purge dead symbol nodes or something 
> > > else?
> > 
> > Is there something I'm not seeing here? Trackers basically ascend //a// 
> > path from the error node to at most the root of the ExplodedGraph (not the 
> > trimmed version, as `Tracker::track()` is called before any of that process 
> > happens), so its not much slower than `trackExpressionValue`, right?
> > 
> > Or does this, and likely many other future handlers run such a loop more 
> > often then what I imagine?
> > 
> > 
> Essentially, yes.  `trackExpressionValue` (and `Tracker::track`) ascend the 
> graph searching for a node where the give expression is evaluated.  The 
> problem here is that whenever we ask to track some expression, not only 
> `trackExpressionValue` will do its traversal (much longer), but also this 
> handler will do its (shorter).  It would be better not to do this altogether, 
> but I personally don't see any solutions how we can cut on this part.
> At the same time, I don't think that it is performance critical, considering 
> that the part of the graph where `N->getStmtForDiagnostics() == E` is small.
Ah, so, this is your patch:

```
E: Error Node
C: Identity function call
V: Argument evaluation
A: Origin of the argument value
---->: Nodes traversed by the tracker
====>: Nodes traversed by the handler

*              *           *           *
E->O->O->O->O->C->O->O->O->V->O->O->O->A->X->X->X

--------------->          
               ============>----------->
```
This is fine, because its just a single ascend, made a little worse by the fact 
that we do it for each tracked variable. But later, with more handlers, it 
might get worse (per variable):
```
*              *           *           *
E->O->O->O->O->C->O->O->O->V->O->O->O->A->X->X->X

--------------->           
               ============>----------->
               ===============>----->
               ==============>------------------>
               =================================>
               ======================>
```
Now, I can't immediately imagine a case where someone would add THAT many 
handlers, or track that many variables, even in extreme circumstances, but I 
don't posses a crystal ball either :^)


Repository:
  rG LLVM Github Monorepo

CHANGES SINCE LAST ACTION
  https://reviews.llvm.org/D104136/new/

https://reviews.llvm.org/D104136

_______________________________________________
cfe-commits mailing list
cfe-commits@lists.llvm.org
https://lists.llvm.org/cgi-bin/mailman/listinfo/cfe-commits

Reply via email to