diff options
author | Zhongxing Xu <xuzhongxing@gmail.com> | 2009-11-17 08:58:18 +0000 |
---|---|---|
committer | Zhongxing Xu <xuzhongxing@gmail.com> | 2009-11-17 08:58:18 +0000 |
commit | 23baa01af443bd53ebe4e43224da6577a286262f (patch) | |
tree | a1c0fcd49ddd6d3241a01ea3300ce11f9db5a991 /clang/lib/Analysis/MallocChecker.cpp | |
parent | feedba68b542fb4797875340b22cd81efb9cd0f4 (diff) | |
download | bcm5719-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.cpp | 26 |
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); +} |