summaryrefslogtreecommitdiffstats
path: root/clang/lib
diff options
context:
space:
mode:
authorTed Kremenek <kremenek@apple.com>2009-11-26 07:14:50 +0000
committerTed Kremenek <kremenek@apple.com>2009-11-26 07:14:50 +0000
commit2350e0c3ba7f6c8cda1eaaa93c3427832e3ea82b (patch)
treeeca5f0f7890fd2759d1d1c809d157d1708c4acaa /clang/lib
parente5d8dd808eeb61acb8cd27b56670c45105a0827c (diff)
downloadbcm5719-llvm-2350e0c3ba7f6c8cda1eaaa93c3427832e3ea82b.tar.gz
bcm5719-llvm-2350e0c3ba7f6c8cda1eaaa93c3427832e3ea82b.zip
Improve diagnostics in ReturnStackAddressChecker for returning a stack-allocated block. Implements the rest of <rdar://problem/7387385>.
llvm-svn: 89940
Diffstat (limited to 'clang/lib')
-rw-r--r--clang/lib/Analysis/ReturnStackAddressChecker.cpp8
1 files changed, 8 insertions, 0 deletions
diff --git a/clang/lib/Analysis/ReturnStackAddressChecker.cpp b/clang/lib/Analysis/ReturnStackAddressChecker.cpp
index e8a014af291..e12158184c8 100644
--- a/clang/lib/Analysis/ReturnStackAddressChecker.cpp
+++ b/clang/lib/Analysis/ReturnStackAddressChecker.cpp
@@ -83,6 +83,14 @@ void ReturnStackAddressChecker::PreVisitReturnStmt(CheckerContext &C,
<< C.getSourceManager().getInstantiationLineNumber(L)
<< " returned to caller";
}
+ else if (const BlockDataRegion *BR = dyn_cast<BlockDataRegion>(R)) {
+ const BlockDecl *BD = BR->getCodeRegion()->getDecl();
+ SourceLocation L = BD->getLocStart();
+ range = BD->getSourceRange();
+ os << "Address of stack-allocated block declared on line "
+ << C.getSourceManager().getInstantiationLineNumber(L)
+ << " returned to caller";
+ }
else {
os << "Address of stack memory associated with local variable '"
<< R->getString() << "' returned.";
OpenPOWER on IntegriCloud