Skip to content
  1. Dec 16, 2009
    • Ted Kremenek's avatar
      Add (initial?) static analyzer support for handling C++ references. · 4cad5fc0
      Ted Kremenek authored
      This change was a lot bigger than I originally anticipated; among
      other things it requires us storing more information in the CFG to
      record what block-level expressions need to be evaluated as lvalues.
      
      The big change is that CFGBlocks no longer contain Stmt*'s by
      CFGElements.  Currently CFGElements just wrap Stmt*, but they also
      store a bit indicating whether the block-level expression should be
      evalauted as an lvalue.  DeclStmts involving the initialization of a
      reference require us treating the initialization expression as an
      lvalue, even though that information isn't recorded in the AST.
      Conceptually this change isn't that complicated, but it required
      bubbling up the data through the CFGBuilder, to GRCoreEngine, and
      eventually to GRExprEngine.
      
      The addition of CFGElement is also useful for when we want to handle
      more control-flow constructs or other data we want to keep in the CFG
      that isn't represented well with just a block of statements.
      
      In GRExprEngine, this patch introduces logic for evaluating the
      lvalues of references, which currently retrieves the internal "pointer
      value" that the reference represents.  EvalLoad does a two stage load
      to catch null dereferences involving an invalid reference (although
      this could possibly be caught earlier during the initialization of a
      reference).
      
      Symbols are currently symbolicated using the reference type, instead
      of a pointer type, and special handling is required creating
      ElementRegions that layer on SymbolicRegions (see the changes to
      RegionStoreManager).
      
      Along the way, the DeadStoresChecker also silences warnings involving
      dead stores to references.  This was the original change I introduced
      (which I wrote test cases for) that I realized caused GRExprEngine to
      crash.
      
      llvm-svn: 91501
      4cad5fc0
  2. Dec 15, 2009
  3. Dec 04, 2009
  4. Nov 30, 2009
  5. Nov 28, 2009
  6. Nov 25, 2009
  7. Oct 21, 2009
  8. Oct 12, 2009
  9. Sep 24, 2009
    • Ted Kremenek's avatar
      When building CFGs, no longer reverse the statements in the CFGBlock. Instead · 0868eea3
      Ted Kremenek authored
      have the iterators and operator[] handle the traversal of statements, as they
      are stored in reverse order. Tests show this has no real performance impact, but
      it does simply the CFG construction logic and will make it slightly easier to
      change the allocation strategy for CFGBlocks (as we have fewer copies).
      
      llvm-svn: 82702
      0868eea3
  10. Sep 09, 2009
  11. Aug 28, 2009
  12. Aug 24, 2009
  13. Aug 23, 2009
  14. Aug 20, 2009
  15. Jul 25, 2009
  16. Jul 24, 2009
  17. Jul 23, 2009
  18. Jul 22, 2009
  19. Jul 21, 2009
  20. Jul 18, 2009
  21. Jul 17, 2009
  22. Jul 16, 2009
  23. Jul 03, 2009
  24. Jun 30, 2009
    • Chris Lattner's avatar
      Key decisions about 'bool' vs '_Bool' to be based on a new flag in langoptions. · c61089a6
      Chris Lattner authored
      This is simple enough, but then I thought it would be nice to make PrintingPolicy
      get a LangOptions so that various things can key off "bool" and "C++" independently.
      This spiraled out of control.  There are many fixme's, but I think things are slightly
      better than they were before.
      
      One thing that can be improved: CFG should probably have an ASTContext pointer in it,
      which would simplify its clients.
      
      llvm-svn: 74493
      c61089a6
Loading