diff options
author | Devin Coughlin <dcoughlin@apple.com> | 2016-10-16 22:19:03 +0000 |
---|---|---|
committer | Devin Coughlin <dcoughlin@apple.com> | 2016-10-16 22:19:03 +0000 |
commit | 684d19d8795980b12183d50158c24e426b968879 (patch) | |
tree | 937ac2e75c965e85bcf4091b8dd052166c577178 /clang/lib/StaticAnalyzer/Checkers/MallocChecker.cpp | |
parent | 0db71d9e5802c6e409cc5a593e7a849f780eab13 (diff) | |
download | bcm5719-llvm-684d19d8795980b12183d50158c24e426b968879.tar.gz bcm5719-llvm-684d19d8795980b12183d50158c24e426b968879.zip |
Revert "Revert "[analyzer] Make MallocChecker more robust against custom redeclarations""
This reverts commit r284340 to reapply r284335. The bot breakage was due to
an unrelated change in the polybench test suite.
llvm-svn: 284351
Diffstat (limited to 'clang/lib/StaticAnalyzer/Checkers/MallocChecker.cpp')
-rw-r--r-- | clang/lib/StaticAnalyzer/Checkers/MallocChecker.cpp | 4 |
1 files changed, 4 insertions, 0 deletions
diff --git a/clang/lib/StaticAnalyzer/Checkers/MallocChecker.cpp b/clang/lib/StaticAnalyzer/Checkers/MallocChecker.cpp index e3c940f6be8..a00fd1d421e 100644 --- a/clang/lib/StaticAnalyzer/Checkers/MallocChecker.cpp +++ b/clang/lib/StaticAnalyzer/Checkers/MallocChecker.cpp @@ -778,6 +778,8 @@ void MallocChecker::checkPostStmt(const CallExpr *CE, CheckerContext &C) const { State = MallocMemAux(C, CE, CE->getArg(0), UndefinedVal(), State); } } else if (FunI == II_kmalloc) { + if (CE->getNumArgs() < 1) + return; llvm::Optional<ProgramStateRef> MaybeState = performKernelMalloc(CE, C, State); if (MaybeState.hasValue()) @@ -807,6 +809,8 @@ void MallocChecker::checkPostStmt(const CallExpr *CE, CheckerContext &C) const { } else if (FunI == II_strndup) { State = MallocUpdateRefState(C, CE, State); } else if (FunI == II_alloca || FunI == II_win_alloca) { + if (CE->getNumArgs() < 1) + return; State = MallocMemAux(C, CE, CE->getArg(0), UndefinedVal(), State, AF_Alloca); State = ProcessZeroAllocation(C, CE, 0, State); |