sgatev marked 3 inline comments as done.
sgatev added inline comments.

================
Comment at: 
clang/lib/Analysis/FlowSensitive/Models/UncheckedOptionalAccessModel.cpp:596-598
+      MergedEnv.makeOr(
+          MergedEnv.makeAnd(Env1.getFlowConditionToken(), *HasValueVal1),
+          MergedEnv.makeAnd(Env2.getFlowConditionToken(), *HasValueVal2)));
----------------
ymandel wrote:
> xazax.hun wrote:
> > ymandel wrote:
> > > What's the plan for loops? This will increase the size of the constraint 
> > > on every iteration, preventing termination.
> > I have nothing to add, just a brain dump. In this particular case, the 
> > analysis domain has infinite chains, the size of the Boolean formulas can 
> > increase indefinitely (at least syntactically). The canonical solution to 
> > deal with infinite chains is to do a widening operation such that the 
> > widened state over approximates both the state of the old and the new 
> > iteration. A very simple way of doing this would be to simply erase all 
> > knowledge we accumulated about the Boolean value. On the other hand, I 
> > wonder if it is often possible to do something smarter. There might be 
> > cases when the value is syntactically larger in the new iteration but 
> > actually it has the exact same truth table. The solver might be able to 
> > show this. On the other hand, if the loop generates new Boolean symbols in 
> > each iteration, we have little hope fore that.
> > I have nothing to add, just a brain dump. In this particular case, the 
> > analysis domain has infinite chains, the size of the Boolean formulas can 
> > increase indefinitely (at least syntactically). The canonical solution to 
> > deal with infinite chains is to do a widening operation such that the 
> > widened state over approximates both the state of the old and the new 
> > iteration. A very simple way of doing this would be to simply erase all 
> > knowledge we accumulated about the Boolean value. On the other hand, I 
> > wonder if it is often possible to do something smarter. There might be 
> > cases when the value is syntactically larger in the new iteration but 
> > actually it has the exact same truth table. The solver might be able to 
> > show this. On the other hand, if the loop generates new Boolean symbols in 
> > each iteration, we have little hope fore that.
> 
> Agreed. In our internal implementation, we have something like this -- it 
> consults the solver to see if the two are logically equivalent.  That loses 
> the (subtle) support for correlated conditions. However, until we have more 
> precise support for widening (that is, separate from `merge`), I think this 
> is the only way to go to ensure that loop analysis terminates.
After discussing this, we decided to go for the internal implementation which 
is tested on a large codebase and commit to smarter merging that preserves flow 
condition information only after testing it extensively. I have updated the 
patch accordingly, please take a look.


Repository:
  rG LLVM Github Monorepo

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

https://reviews.llvm.org/D125931

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

Reply via email to