diff options
author | Ted Kremenek <kremenek@apple.com> | 2009-11-26 07:14:50 +0000 |
---|---|---|
committer | Ted Kremenek <kremenek@apple.com> | 2009-11-26 07:14:50 +0000 |
commit | 2350e0c3ba7f6c8cda1eaaa93c3427832e3ea82b (patch) | |
tree | eca5f0f7890fd2759d1d1c809d157d1708c4acaa /clang/lib | |
parent | e5d8dd808eeb61acb8cd27b56670c45105a0827c (diff) | |
download | bcm5719-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.cpp | 8 |
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."; |