Skip to content
  1. Jan 05, 2010
    • Ted Kremenek's avatar
      Remove references to 'Checker' and 'GRTransferFuncs' from · de8e7447
      Ted Kremenek authored
      GRStateManager.  Having these references was an abstraction violation,
      as they really should only be known about GRExprEngine.
      
      This change required adding a new 'ProcessAssume' callback in
      GRSubEngine.  GRExprEngine implements this callback by calling
      'EvalAssume' on all registered Checker objects as well as the
      registered GRTransferFunc object.
      
      llvm-svn: 92549
      de8e7447
  2. Nov 28, 2009
  3. Sep 09, 2009
  4. Jun 25, 2009
  5. Jun 19, 2009
  6. Jun 18, 2009
  7. Feb 14, 2009
    • Ted Kremenek's avatar
      Patch by Ben Laurie: · 7efe43db
      Ted Kremenek authored
      ConstraintManager:
      - constify getSymVal()
      
      BasicConstraintManager:
      - Pull out logic that would be common to ConstraintManagers of a similar nature
        and put them in a parent class called 'SimpleConstraintManager'.
      
      RangeConstraintManager:
      - Added a new prototype ConstraintManager to track ranges of variables! This
        ConstraintManager keeps tracks of ranges of concrete integers that a symbolic
        integer may have.
      
      AnalysisConsumer:
      - Add driver option to use RangeConstraintManager with GRExprEngine-based
        analyses.
      
      llvm-svn: 64558
      7efe43db
  8. Feb 05, 2009
    • Zhongxing Xu's avatar
      Make SymbolicRegion subclass TypedRegion, for symbols usually have types, so · 9103df16
      Zhongxing Xu authored
      do the symblic regions associated with them and we need them to be typed.
      
      Current SymbolicRegion::getRValueType() method is very restricting. It may be
      modified when we are more clear about what could be the types of symblic
      regions.
      
      BasicConstraintManager::Assume() is changed due to that now SymblicRegion is a
      subclass of SubRegion.
       
      
      llvm-svn: 63844
      9103df16
  9. Jan 30, 2009
  10. Jan 28, 2009
  11. Jan 26, 2009
  12. Jan 22, 2009
    • Ted Kremenek's avatar
      Static analyzer: Remove a bunch of outdated SymbolData objects and · 74040833
      Ted Kremenek authored
      their associated APIs.  We no longer need separate SymbolData objects
      for fields, variables, etc.  Instead, we now associated symbols with
      the "rvalue" of a MemRegion (i.e., the value stored at that region).
      Now we only have two kinds of SymbolData objects: SymbolRegionRValue
      and SymbolConjured.
      
      This cleanup also makes the distinction between a SymbolicRegion and a
      symbolic value that is a location much clearer.  A SymbolicRegion
      represents a chunk of symbolic memory, while a symbolic location is
      just a "pointer" with different possible values.  Without any specific
      knowledge, a symbolic location resolves (i.e., via a dereference) to a
      SymbolicRegion.  In the future, when we do better alias reasoning, a
      symbolic location can become an alias for another location, thus
      merging the constraints on the referred SymbolicRegion with the other
      region.
      
      llvm-svn: 62769
      74040833
  13. Jan 21, 2009
  14. Dec 17, 2008
    • Ted Kremenek's avatar
      CF-retain/release checker: · 62d4c12d
      Ted Kremenek authored
      - Fix regression reported in <rdar://problem/6452745>.  After a null check, null references to resources should not have a retain count.  This regression was caused by removing the call to "GRTransferFuncs::EvalAssume" in BasicConstraintManager.
      - Added a test case to test this behavior.
      
      llvm-svn: 61155
      62d4c12d
  15. Dec 05, 2008
  16. Dec 03, 2008
    • Ted Kremenek's avatar
      BasicConstraintManager: · fff9f4aa
      Ted Kremenek authored
      - Fix nonsensical logic in AssumeSymGE. When comparing 'sym >= constant' and the
        constant is the maximum integer value, add the constraint that 'sym ==
        constant' when the path is deemed feasible.  All other cases are feasible.
      - Improve AssumeSymGT. When comparing 'sym > constant' and constant is the
        maximum integer value we know the path is infeasible.
      - Add test case for this enhancement to AssumeSymGT.
      
      llvm-svn: 60490
      fff9f4aa
    • Ted Kremenek's avatar
      BasicConstraintManager: · f935cfe2
      Ted Kremenek authored
      - Fix nonsensical logic in AssumeSymLE. When comparing 'sym <= constant' and the
        constant is the minimum integer value, add the constraint that 'sym ==
        constant' when the path is deemed feasible.  All other cases are feasible.
      - Improve AssumeSymLT to address <rdar://problem/6407949>.  When comparing
        'sym < constant' and constant is the minimum integer value we know the
        path is infeasible.
      - Add test case for <rdar://problem/6407949>.
      
      llvm-svn: 60489
      f935cfe2
  17. Nov 27, 2008
  18. Nov 24, 2008
  19. Nov 22, 2008
  20. Nov 10, 2008
  21. Oct 26, 2008
  22. Oct 17, 2008
  23. Oct 04, 2008
    • Ted Kremenek's avatar
      This is a big patch, but the functionality change is small and the rest of the... · 5ca90a24
      Ted Kremenek authored
      This is a big patch, but the functionality change is small and the rest of the patch consists of deltas due to API changes.
      
      This patch overhauls the "memory region" abstraction that was prototyped (but never really used) as part of the Store.h.  This patch adds MemRegion.h and MemRegion.cpp, which defines the class MemRegion and its subclasses.  This classes serve to define an abstract representation of memory, with regions being layered on other regions to to capture the relationships between fields and variables, variables and the address space they are allocated in, and so on.  
      
      The main motivation of this patch is that key parts of the analyzer assumed that all value bindings were to VarDecls.  In the future this won't be the case, and this patch removes lval::DeclVal and replaces it with lval::MemRegionVal.  Now all pieces of the analyzer must reason about abstract memory blocks instead of just variables.
      
      There should be no functionality change from this patch, but it opens the door for significant improvements to the analyzer such as field-sensitivity and object-sensitivity, both which were on hold until the memory abstraction got generalized.
      
      The memory region abstraction also allows type-information to literally be affixed to a memory region.  This will allow the some now redundant logic to be removed from the retain/release checker.
      
      llvm-svn: 57042
      5ca90a24
  24. Sep 19, 2008
    • Ted Kremenek's avatar
      Fixed logic error in BasicConstraintManager pointed out by Zhongxing Xu. · 34bfd8a4
      Ted Kremenek authored
      For checking if a symbol >= value, we need to check if symbol == value || symbol
      > value. When checking symbol > value and we know that symbol != value, the path
      is infeasible only if value == maximum integer.
      
      For checking if a symbol <= value, we need to check if symbol == value || symbol
      < value. When checking symbol < value and we know that symbol != value, the path
      is infeasible only if value == minimum integer.
      
      Updated test case exercising this logic: we only prune paths if the values are
      unsigned.
      
      llvm-svn: 56354
      34bfd8a4
    • Zhongxing Xu's avatar
      Add an omitted case for AssumeSymInt. · a8e88ecd
      Zhongxing Xu authored
      llvm-svn: 56334
      a8e88ecd
  25. Sep 17, 2008
  26. Aug 30, 2008
  27. Aug 29, 2008
  28. Aug 27, 2008
Loading