|  | Commit message (Collapse) | Author | Age | Files | Lines | 
|---|
| | 
| 
| 
| | llvm-svn: 210615 | 
| | 
| 
| 
| | llvm-svn: 209191 | 
| | 
| 
| 
| 
| 
| | iterator_range captures(). Updating all of the usages of the iterators with range-based for loops.
llvm-svn: 203958 | 
| | 
| 
| 
| 
| 
| | iterator_range decls(). Updating all of the usages of the iterators with range-based for loops.
llvm-svn: 203947 | 
| | 
| 
| 
| 
| 
| | class.
llvm-svn: 203893 | 
| | 
| 
| 
| 
| 
| 
| 
| 
| 
| 
| 
| 
| 
| 
| 
| 
| 
| 
| 
| 
| 
| 
| 
| 
| 
| | making them NULL.
This is to support some analyses, like -Wunreachable-code, that
will need to recover the original unprunned CFG edges in order
to suppress issues that aren't really bugs in practice.
There are two important changes here:
- AdjacentBlock replaces CFGBlock* for CFG successors/predecessors.
  This has the size of 2 pointers, instead of 1.  This is unlikely
  to have a significant memory impact on Sema since a single
  CFG usually exists at one time, but could impact the memory
  usage of the static analyzer.  This could possibly be optimized
  down to a single pointer with some cleverness.
- Predecessors can now contain null predecessors, which means
  some analyses doing a reverse traversal will need to take into
  account.  This already exists for successors, which contain
  successor slots for specific branch kinds (e.g., 'if') that
  expect a fixed number of successors, even if a branch is
  not reachable.
llvm-svn: 202325 | 
| | 
| 
| 
| 
| 
| 
| 
| 
| 
| 
| | variable uninitialized every time we reach its (reachable) declaration, or
every time we call the surrounding function, promote the warning from
-Wmaybe-uninitialized to -Wsometimes-uninitialized.
This is still slightly weaker than desired: we should, in general, warn
if a use is uninitialized the first time it is evaluated.
llvm-svn: 190623 | 
| | 
| 
| 
| 
| 
| | No functionality change intended.
llvm-svn: 189112 | 
| | 
| 
| 
| 
| 
| 
| 
| 
| 
| 
| 
| 
| 
| 
| 
| 
| | This class is a StmtVisitor that distinguishes between block-level and
non-block-level statements in a CFG. However, it does so using a hard-coded
idea of which statements might be block-level, which probably isn't accurate
anymore. The only implementer of the CFGStmtVisitor hierarchy was the
analyzer's DeadStoresChecker, and the analyzer creates a linearized CFG
anyway (every non-trivial statement is a block-level statement).
This also allows us to remove the block-expr map ("BlkExprMap"), which
mapped statements to positions in the CFG. Apart from having a helper type
that really should have just been Optional<unsigned>, it was only being
used to ask /if/ a particular expression was block-level, for traversal
purposes in CFGStmtVisitor.
llvm-svn: 181945 | 
| | 
| 
| 
| 
| 
| 
| 
| 
| 
| 
| 
| 
| | 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 | 
| | 
| 
| 
| | llvm-svn: 175705 | 
| | 
| 
| 
| 
| 
| | Post-commit CR feedback from Jordan Rose regarding r175594.
llvm-svn: 175679 | 
| | 
| 
| 
| 
| 
| | evaluate to lvalues (in C++).
llvm-svn: 172875 | 
| | 
| 
| 
| 
| 
| | brought into 'clang' namespace by clang/Basic/LLVM.h
llvm-svn: 172323 | 
| | 
| 
| 
| | llvm-svn: 172195 | 
| | 
| 
| 
| 
| 
| 
| 
| 
| | pull in all the generated Attr code.
Required to pull some functions out of line, but this shouldn't have a perf impact.
No functionality change.
llvm-svn: 169092 | 
| | 
| 
| 
| 
| 
| | 2.5% using intelligent pruning of blocks during the final reporting pass.
llvm-svn: 168257 | 
| | 
| 
| 
| 
| 
| 
| 
| 
| | an initial baseline for enqueued blocks, but use a simple DFS stack
for propagating changes quickly up back edges.
This provides a 3.5% reduction in -fsyntax-only time on sqlite3.c.
llvm-svn: 168241 | 
| | 
| 
| 
| 
| 
| 
| | - The size of the packed vector is often small, save mallocs using SmallBitVector.
- Copying SmallBitVectors is also cheap, remove a level of indirection.
llvm-svn: 164827 | 
| | 
| 
| 
| 
| 
| 
| 
| 
| 
| 
| 
| 
| | Objective-C related to NSException.
Fixes <rdar://problem/12287498>
I debated whether or not this logic should be sunk into the CFG
itself.  It's not clear if we should, as different analyses may
wish to have different policies.  We can re-evaluate this in the
future.
llvm-svn: 163760 | 
| | 
| 
| 
| 
| 
| 
| 
| 
| 
| 
| 
| 
| 
| 
| 
| 
| 
| | for halting the propagation of uninitialized value tracking along
a path.  Unlike __attribute__((noreturn)), this attribute (which
is used by clients of the static analyzer) can be used to annotate
functions that essentially never return, but in rare cares may be
allowed to return for (special) debugging purposes.  This attribute
has been shown in reducing false positives in the static analyzer
by pruning false postives, and is equally applicable here.
Handling this attribute in the CFG itself is another option, but
this is not something all clients (e.g., possibly -Wunreachable-code)
would want to see.
Addresses <rdar://problem/12281583>.
llvm-svn: 163681 | 
| | 
| 
| 
| 
| 
| 
| 
| | (imprecise) representation
of '&&' and '||' in the CFG.  This is no longer needed, and greatly simplifies the code.
llvm-svn: 160494 | 
| | 
| 
| 
| 
| 
| 
| | * Treat compound assignment as a use, at Jordy's request.
 * Always add compound assignments into the CFG, so we can correctly diagnose the use in 'return x += 1;'
llvm-svn: 160334 | 
| | 
| 
| 
| 
| 
| 
| 
| 
| 
| | use out of TransferFunctions, and compute it in advance rather than on-the-fly.
This allows us to handle compound assignments with DeclRefExprs on the RHS
correctly, and also makes it trivial to treat const& function parameters as not
initializing the argument. The patch also makes both of those changes.
llvm-svn: 160330 | 
| | 
| 
| 
| 
| 
| 
| | uninitialized variable use, walk back over branches where we've reached all the
non-null successors, not just cases where we've reached all successors.
llvm-svn: 160206 | 
| | 
| 
| 
| 
| 
| 
| | initialize any variable. This is extremely conservative, but is sufficient for
now.
llvm-svn: 159620 | 
| | 
| 
| 
| 
| 
| 
| | initializer, it is uninitialized, even if we may be coming from somewhere where
it was initialized.
llvm-svn: 158611 | 
| | 
| 
| 
| 
| 
| 
| 
| 
| 
| 
| 
| 
| 
| | value_type
In addition, I've made the pointer and reference typedef 'void' rather than T*
just so they can't get misused. I would've omitted them entirely but
std::distance likes them to be there even if it doesn't use them.
This rolls back r155808 and r155869.
Review by Doug Gregor incorporating feedback from Chandler Carruth.
llvm-svn: 158104 | 
| | 
| 
| 
| 
| 
| 
| 
| 
| 
| 
| | -Wsometimes-uninitialized. This detects cases where an explicitly-written branch
inevitably leads to an uninitialized variable use (so either the branch is dead
code or there is an uninitialized use bug).
This chunk of warnings tentatively lives within -Wuninitialized, in order to
give it more visibility to existing Clang users.
llvm-svn: 157458 | 
| | 
| 
| 
| 
| 
| | functional change.
llvm-svn: 157440 | 
| | 
| 
| 
| 
| 
| 
| 
| 
| 
| 
| 
| 
| | filter_decl_iterator had a weird mismatch where both op* and op-> returned T*
making it difficult to generalize this filtering behavior into a reusable
library of any kind.
This change errs on the side of value, making op-> return T* and op* return
T&.
(reviewed by Richard Smith)
llvm-svn: 155808 | 
| | 
| 
| 
| 
| 
| 
| 
| 
| 
| 
| | g++4.7, which reuses stack space allocated for temporaries. CFGElement::getAs
returns a suitably-cast version of 'this'. Patch by Markus Trippelsdorf!
No test: this code has the same observable behavior as the old code when built
with most compilers, and the tests were already failing when built with a
compiler for which this produced a broken binary.
llvm-svn: 155803 | 
| | 
| 
| 
| 
| 
| | Needs llvm update.
llvm-svn: 151829 | 
| | 
| 
| 
| 
| 
| 
| 
| | to make it more widely available.
Depends on llvm commit r151564
llvm-svn: 151566 | 
| | 
| 
| 
| 
| 
| | accurate, but it frees up the name AnalysisContext for other uses.
llvm-svn: 142782 | 
| | 
| 
| 
| 
| 
| | cause of an uninitialized variable IFF there are other uses of that uninitialized variable.  Fixes <rdar://problem/9259237>.
llvm-svn: 141881 | 
| | 
| 
| 
| | llvm-svn: 141345 | 
| | 
| 
| 
| 
| 
| | dead code.  Fixes <rdar://problem/10060250>.
llvm-svn: 139027 | 
| | 
| 
| 
| | llvm-svn: 138408 | 
| | 
| 
| 
| | llvm-svn: 138183 | 
| | 
| 
| 
| | llvm-svn: 137896 | 
| | 
| 
| 
| 
| 
| | and libStaticAnalyzer[*].  It was highly inconsistent, and very ugly to look at.
llvm-svn: 137537 | 
| | 
| 
| 
| 
| 
| | resulting from the recent -Wuninitialized changes.
llvm-svn: 137068 | 
| | 
| 
| 
| | llvm-svn: 136939 | 
| | 
| 
| 
| 
| 
| 
| 
| | LLVM.h imports
them into the clang namespace.
llvm-svn: 135852 | 
| | 
| 
| 
| 
| 
| 
| 
| 
| 
| 
| 
| | AnalysisBasedWarnings Sema layer and out of the Analysis library itself.
This returns the uninitialized values analysis to a more pure form,
allowing its original logic to correctly detect some categories of
definitely uninitialized values. Fixes PR10358 (again).
Thanks to Ted for reviewing and updating this patch after his rewrite of
several portions of this analysis.
llvm-svn: 135748 | 
| | 
| 
| 
| 
| 
| | passed by reference.
llvm-svn: 135610 | 
| | 
| 
| 
| 
| 
| | lvalue-to-rvalue conversion in a DeclStmt.
llvm-svn: 135525 | 
| | 
| 
| 
| 
| 
| | conversion is wrapped in a parenthesis.
llvm-svn: 135519 |