|  | Commit message (Collapse) | Author | Age | Files | Lines | 
|---|
| | 
| 
| 
| 
| 
| 
| 
| 
| 
| | This reverts commit r189090.
The original patch introduced regressions (see the added live-variables.* tests). The patch depends on the correctness of live variable analyses, which are not computed correctly. I've opened PR18159 to track the proper resolution to this problem.
The patch was a stepping block to r189746. This is why part of the patch reverts temporary destructor tests that started crashing. The temporary destructors feature is disabled by default.
llvm-svn: 196593 | 
| | 
| 
| 
| 
| 
| | No functionality change intended.
llvm-svn: 189112 | 
| | 
| 
| 
| 
| 
| 
| 
| 
| 
| 
| 
| 
| 
| 
| 
| 
| 
| 
| | Summary:
Instead of digging through the ExplodedGraph, to figure out which edge brought
us here, I compute the value of conditional expression by looking at the
sub-expression values.
To do this, I needed to change the liveness algorithm a bit -- now, the full
conditional expression also depends on all atomic sub-expressions, not only the
outermost ones.
Reviewers: jordan_rose
CC: cfe-commits
Differential Revision: http://llvm-reviews.chandlerc.com/D1340
llvm-svn: 189090 | 
| | 
| 
| 
| 
| 
| 
| 
| 
| 
| 
| 
| 
| | Use Optional<CFG*> where invalid states were needed previously. In the one case
where that's not possible (beginAutomaticObjDtorsInsert) just use a dummy
CFGAutomaticObjDtor.
Thanks for the help from Jordan Rose & discussion/feedback from Ted Kremenek
and Doug Gregor.
Post commit code review feedback on r175796 by Ted Kremenek.
llvm-svn: 175938 | 
| | 
| 
| 
| 
| 
| | See r175462 for another example/more details.
llvm-svn: 175796 | 
| | 
| 
| 
| 
| 
| 
| 
| 
| 
| 
| 
| 
| | uncovered.
This required manually correcting all of the incorrect main-module
headers I could find, and running the new llvm/utils/sort_includes.py
script over the files.
I also manually added quite a few missing headers that were uncovered by
shuffling the order or moving headers up to be main-module-headers.
llvm-svn: 169237 | 
| | 
| 
| 
| | llvm-svn: 169095 | 
| | 
| 
| 
| | llvm-svn: 161822 | 
| | 
| 
| 
| 
| 
| 
| | Test case in the next commit, which enables destructors under certain
circumstances.
llvm-svn: 160805 | 
| | 
| 
| 
| 
| 
| 
| 
| 
| | we are encountering some scalability issues with memory usage.   The
appropriate long term fix is to make the analysis more scalable, but
this will at least prevent the analyzer swapping when
analyzing very large functions.
llvm-svn: 159578 | 
| | 
| 
| 
| 
| 
| 
| 
| | PseudoObjExprs.  It turns out
that the information collected by this method is a super set of the captured variables in BlockDecl.
llvm-svn: 147122 | 
| | 
| 
| 
| 
| 
| | blocks.
llvm-svn: 147116 | 
| | 
| 
| 
| 
| 
| | http://llvm.org/docs/CodingStandards.html#ll_virtual_anch
llvm-svn: 146959 | 
| | 
| 
| 
| 
| 
| 
| | through it, so we should look through it for the live-values
analysis as well.
llvm-svn: 144190 | 
| | 
| 
| 
| 
| 
| 
| 
| 
| 
| 
| 
| 
| 
| 
| 
| 
| 
| 
| 
| 
| 
| 
| 
| 
| 
| 
| 
| | property references to use a new PseudoObjectExpr
expression which pairs a syntactic form of the expression
with a set of semantic expressions implementing it.
This should significantly reduce the complexity required
elsewhere in the compiler to deal with these kinds of
expressions (e.g. IR generation's special l-value kind,
the static analyzer's Message abstraction), at the lower
cost of specifically dealing with the odd AST structure
of these expressions.  It should also greatly simplify
efforts to implement similar language features in the
future, most notably Managed C++'s properties and indexed
properties.
Most of the effort here is in dealing with the various
clients of the AST.  I've gone ahead and simplified the
ObjC rewriter's use of properties;  other clients, like
IR-gen and the static analyzer, have all the old
complexity *and* all the new complexity, at least
temporarily.  Many thanks to Ted for writing and advising
on the necessary changes to the static analyzer.
I've xfailed a small diagnostics regression in the static
analyzer at Ted's request.
llvm-svn: 143867 | 
| | 
| 
| 
| 
| 
| | alternativing ParenExprs and OpaqueValueExprs.  Thanks to Anna and Argiris for iterating on this function.  My original patch embarssingly didn't even pass the Clang tests.
llvm-svn: 143797 | 
| | 
| 
| 
| | llvm-svn: 143796 | 
| | 
| 
| 
| | llvm-svn: 143795 | 
| | 
| 
| 
| | llvm-svn: 143794 | 
| | 
| 
| 
| 
| 
| | Make test/Analysis/misc-ps.c test pass.
llvm-svn: 143790 | 
| | 
| 
| 
| 
| 
| 
| 
| | break out of
switch statement, not the while loop).
llvm-svn: 143780 | 
| | 
| 
| 
| 
| 
| | liveness.
llvm-svn: 143767 | 
| | 
| 
| 
| 
| 
| | accurate, but it frees up the name AnalysisContext for other uses.
llvm-svn: 142782 | 
| | 
| 
| 
| 
| 
| | PostOrderCFGView.
llvm-svn: 142713 | 
| | 
| 
| 
| 
| 
| | mechanism to lazily create analyses that are attached to AnalysisContext objects.
llvm-svn: 141425 | 
| | 
| 
| 
| 
| 
| | analyzing C++ pointer-to-member calls.  Fixes <rdar://problem/10243398>.
llvm-svn: 141312 | 
| | 
| 
| 
| 
| 
| | canonicalizing the underlying ImmutableSets on every analyzed statement (just at merges).  Fixes <rdar://problem/10087538>.
llvm-svn: 140958 | 
| | 
| 
| 
| 
| 
| | handling in ExprEngine.  Fixes <rdar://problem/10201666>.
llvm-svn: 140956 | 
| | 
| 
| 
| 
| 
| 
| 
| 
| 
| 
| 
| 
| 
| 
| 
| | addressing two performance problems:
- Speed of "merge()", which merged data flow facts.  This was doing a set canonicalization on every insertion, which was super slow.
  To fix this, we use ImmutableSetRef.
- Visit CFGBlocks in reverse postorder.  This is a huge speedup, as on some test cases the algorithm would take many iterations
  to converge.
This contains a bunch of copy-paste from UninitializedValues.cpp and ThreadSafety.cpp.  The idea
was to get something working first, and then refactor the common logic for all three files into
a separate analysis/library entry point.
llvm-svn: 139968 | 
| | 
| 
| 
| | llvm-svn: 138408 | 
| | 
| 
| 
| 
| 
| | and libStaticAnalyzer[*].  It was highly inconsistent, and very ugly to look at.
llvm-svn: 137537 | 
| | 
| 
| 
| 
| 
| 
| 
| | avoid recursion to subexpression.
This exposed bugs in the live variables analysis, and a latent analyzer bug in the SymbolReaper.
llvm-svn: 137006 | 
| | 
| 
| 
| | llvm-svn: 136679 | 
| | 
| 
| 
| 
| 
| 
| 
| 
| 
| 
| 
| | be linearized only when used by the static analyzer.  This required a rewrite of LiveVariables, and exposed a ton of subtle bugs.
The motivation of this large change is to drastically simplify the logic in ExprEngine going forward.
Some fallout is that the output of some BugReporterVisitors is not as accurate as before; those will
need to be fixed over time.  There is also some possible performance regression as RemoveDeadBindings
will be called frequently; this can also be improved over time.
llvm-svn: 136419 | 
| | 
| 
| 
| 
| 
| 
| 
| | LLVM.h imports
them into the clang namespace.
llvm-svn: 135852 | 
| | 
| 
| 
| 
| 
| 
| 
| | expressions (by calling IgnoreParens before adding expressions to blocks). Undo 132769 (LiveVariables' local IgnoreParens), since it's no longer necessary.
Also, have Environment stop looking through NoOp casts; it didn't match the behavior of LiveVariables. And once that's gone, the whole cast block of that switch is unnecessary.
llvm-svn: 132840 | 
| | 
| 
| 
| 
| 
| | liveness. Fixes the other half of PR8962.
llvm-svn: 132769 | 
| | 
| 
| 
| 
| 
| | <rdar://problem/8405222>.
llvm-svn: 125415 | 
| | 
| 
| 
| 
| 
| 
| 
| 
| | at assignments. This 'relaxed' liveness is useful in path sensitive analysis for situations where the resulting extended liveness allows us to find some bugs.
- Added killAtAssign flag to LiveVariables
- Added relaxed LiveVariables to AnalysisContext with an accessor
llvm-svn: 112306 | 
| | 
| 
| 
| 
| 
| | to the new constants.
llvm-svn: 112047 | 
| | 
| 
| 
| | llvm-svn: 105452 | 
| | 
| 
| 
| 
| 
| 
| | If an initializer in a DeclStmt references the declared variable, that
extends the liveness of that variable.
llvm-svn: 97624 | 
| | 
| 
| 
| 
| 
| 
| | We may query their liveness because they are added to store when passing
argument values.
llvm-svn: 97562 | 
| | 
| 
| 
| 
| 
| 
| 
| 
| 
| 
| 
| 
| 
| 
| 
| 
| 
| 
| 
| 
| 
| 
| 
| 
| | (1) libAnalysis is a generic analysis library that can be used by
    Sema.  It defines the CFG, basic dataflow analysis primitives, and
    inexpensive flow-sensitive analyses (e.g. LiveVariables).
(2) libChecker contains the guts of the static analyzer, incuding the
    path-sensitive analysis engine and domain-specific checks.
Now any clients that want to use the frontend to build their own tools
don't need to link in the entire static analyzer.
This change exposes various obvious cleanups that can be made to the
layout of files and headers in libChecker.  More changes pending.  :)
This change also exposed a layering violation between AnalysisContext
and MemRegion.  BlockInvocationContext shouldn't explicitly know about
BlockDataRegions.  For now I've removed the BlockDataRegion* from
BlockInvocationContext (removing context-sensitivity; although this
wasn't used yet).  We need to have a better way to extend
BlockInvocationContext (and any LocationContext) to add
context-sensitivty.
llvm-svn: 94406 | 
| | 
| 
| 
| | llvm-svn: 92305 | 
| | 
| 
| 
| 
| 
| | hooks for the initialization of condition variables.
llvm-svn: 92119 | 
| | 
| 
| 
| | llvm-svn: 90028 | 
| | 
| 
| 
| 
| 
| 
| 
| 
| 
| 
| 
| 
| 
| 
| | variable by "capturing" them in a BlockExpr.
This required two changes:
1) Added 'getReferencedgetReferencedBlockVars()' to AnalysisContext so
that clients can iterate over the "captured" variables in a block.
2) Modified LiveVariables to take an AnalysisContext& in its
constructor and to call getReferencedgetReferencedBlockVars() when it
processes a BlockExpr*.
llvm-svn: 89924 | 
| | 
| 
| 
| 
| 
| | Patch by Victor Zverovich!
llvm-svn: 86638 | 
| | 
| 
| 
| 
| 
| | Patch by Kovarththanan Rajaratnam!
llvm-svn: 86343 |