diff options
author | Zhongxing Xu <xuzhongxing@foxmail.com> | 2011-09-01 04:53:59 +0000 |
---|---|---|
committer | Zhongxing Xu <xuzhongxing@foxmail.com> | 2011-09-01 04:53:59 +0000 |
commit | bfb8e2fe6e6dd2791004594985089f9e7d3d1385 (patch) | |
tree | 5daa8c77a5d23f37abf28aa80f966ca42dd56568 /clang/lib/StaticAnalyzer/Checkers/MallocChecker.cpp | |
parent | 019f3c24447faaf142811336c436359938ca0469 (diff) | |
download | bcm5719-llvm-bfb8e2fe6e6dd2791004594985089f9e7d3d1385.tar.gz bcm5719-llvm-bfb8e2fe6e6dd2791004594985089f9e7d3d1385.zip |
If size was equal to 0, either NULL or a pointer suitable to be passed to
free() is returned by realloc(). Most code expect NULL.
And we only need to transfer one final ProgramState.
llvm-svn: 138937
Diffstat (limited to 'clang/lib/StaticAnalyzer/Checkers/MallocChecker.cpp')
-rw-r--r-- | clang/lib/StaticAnalyzer/Checkers/MallocChecker.cpp | 7 |
1 files changed, 2 insertions, 5 deletions
diff --git a/clang/lib/StaticAnalyzer/Checkers/MallocChecker.cpp b/clang/lib/StaticAnalyzer/Checkers/MallocChecker.cpp index 7462ec59842..f0f56efa9e7 100644 --- a/clang/lib/StaticAnalyzer/Checkers/MallocChecker.cpp +++ b/clang/lib/StaticAnalyzer/Checkers/MallocChecker.cpp @@ -538,11 +538,8 @@ void MallocChecker::ReallocMem(CheckerContext &C, const CallExpr *CE) const { if (const ProgramState *stateFree = FreeMemAux(C, CE, stateSizeZero, 0, false)) { - // Add the state transition to set input pointer argument to be free. - C.addTransition(stateFree); - - // Bind the return value to UndefinedVal because it is now free. - C.addTransition(stateFree->BindExpr(CE, UndefinedVal(), true)); + // Bind the return value to NULL because it is now free. + C.addTransition(stateFree->BindExpr(CE, svalBuilder.makeNull(), true)); } if (const ProgramState *stateSizeNotZero = stateNotEqual->assume(SizeZero,false)) if (const ProgramState *stateFree = FreeMemAux(C, CE, stateSizeNotZero, |