]> granicus.if.org Git - clang/commitdiff
Improve diagnostics in ReturnStackAddressChecker for returning a stack-allocated...
authorTed Kremenek <kremenek@apple.com>
Thu, 26 Nov 2009 07:14:50 +0000 (07:14 +0000)
committerTed Kremenek <kremenek@apple.com>
Thu, 26 Nov 2009 07:14:50 +0000 (07:14 +0000)
git-svn-id: https://llvm.org/svn/llvm-project/cfe/trunk@89940 91177308-0d34-0410-b5e6-96231b3b80d8

lib/Analysis/ReturnStackAddressChecker.cpp
test/Analysis/stack-addr-ps.c

index e8a014af29100871e61641fdd7d974621c7d768a..e12158184c895f020d0b86206b769c48fa1fe26a 100644 (file)
@@ -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.";
index f26e2f0c63529b0661a5960cf76df033390d35a7..5d1ce253fc35f94067e617446936752bb95a4273 100644 (file)
@@ -1,5 +1,5 @@
-// RUN: clang-cc -analyze -checker-cfref -analyzer-store=basic -verify %s
-// RUN: clang-cc -analyze -checker-cfref -analyzer-store=region -verify %s
+// RUN: clang-cc -analyze -checker-cfref -analyzer-store=basic -fblocks -verify %s
+// RUN: clang-cc -analyze -checker-cfref -analyzer-store=region -fblocks -verify %s
 
 int* f1() {
   int x = 0;
@@ -55,3 +55,16 @@ int struct_test(struct baz byVal, int flag) {
     return byVal.y[0]; // no-warning
   }
 }
+
+typedef int (^ComparatorBlock)(int a, int b);
+ComparatorBlock test_return_block(void) {
+  ComparatorBlock b = ^int(int a, int b){ return a > b; };
+  return b; // expected-warning{{Address of stack-allocated block declared on line 61 returned to caller}}
+}
+
+ComparatorBlock test_return_block_neg_aux(void);
+ComparatorBlock test_return_block_neg(void) {
+  ComparatorBlock b = test_return_block_neg_aux();
+  return b; // no-warning
+}
+