summaryrefslogtreecommitdiffstats
path: root/clang/lib/Analysis/MallocChecker.cpp
diff options
context:
space:
mode:
authorZhongxing Xu <xuzhongxing@gmail.com>2009-11-17 08:58:18 +0000
committerZhongxing Xu <xuzhongxing@gmail.com>2009-11-17 08:58:18 +0000
commit23baa01af443bd53ebe4e43224da6577a286262f (patch)
treea1c0fcd49ddd6d3241a01ea3300ce11f9db5a991 /clang/lib/Analysis/MallocChecker.cpp
parentfeedba68b542fb4797875340b22cd81efb9cd0f4 (diff)
downloadbcm5719-llvm-23baa01af443bd53ebe4e43224da6577a286262f.tar.gz
bcm5719-llvm-23baa01af443bd53ebe4e43224da6577a286262f.zip
Add PreVisitReturn to Malloc checker. Now we can recognize returned memory
block. llvm-svn: 89071
Diffstat (limited to 'clang/lib/Analysis/MallocChecker.cpp')
-rw-r--r--clang/lib/Analysis/MallocChecker.cpp26
1 files changed, 26 insertions, 0 deletions
diff --git a/clang/lib/Analysis/MallocChecker.cpp b/clang/lib/Analysis/MallocChecker.cpp
index fdd6a3d0265..93e708332ed 100644
--- a/clang/lib/Analysis/MallocChecker.cpp
+++ b/clang/lib/Analysis/MallocChecker.cpp
@@ -60,6 +60,7 @@ public:
void PostVisitCallExpr(CheckerContext &C, const CallExpr *CE);
void EvalDeadSymbols(CheckerContext &C,const Stmt *S,SymbolReaper &SymReaper);
void EvalEndPath(GREndPathNodeBuilder &B, void *tag, GRExprEngine &Eng);
+ void PreVisitReturnStmt(CheckerContext &C, const ReturnStmt *S);
private:
void MallocMem(CheckerContext &C, const CallExpr *CE);
void FreeMem(CheckerContext &C, const CallExpr *CE);
@@ -190,3 +191,28 @@ void MallocChecker::EvalEndPath(GREndPathNodeBuilder &B, void *tag,
}
}
}
+
+void MallocChecker::PreVisitReturnStmt(CheckerContext &C, const ReturnStmt *S) {
+ const Expr *RetE = S->getRetValue();
+ if (!RetE)
+ return;
+
+ const GRState *state = C.getState();
+
+ SymbolRef Sym = state->getSVal(RetE).getAsSymbol();
+
+ if (!Sym)
+ return;
+
+ const RefState *RS = state->get<RegionState>(Sym);
+ if (!RS)
+ return;
+
+ // FIXME: check other cases.
+ if (RS->isAllocated())
+ state = state->set<RegionState>(Sym, RefState::getEscaped(S));
+
+ ExplodedNode *N = C.GenerateNode(S, state);
+ if (N)
+ C.addTransition(N);
+}
OpenPOWER on IntegriCloud