summaryrefslogtreecommitdiffstats
path: root/clang/lib/StaticAnalyzer/Core/CheckerContext.cpp
diff options
context:
space:
mode:
authorAnna Zaks <ganna@apple.com>2012-01-18 02:45:07 +0000
committerAnna Zaks <ganna@apple.com>2012-01-18 02:45:07 +0000
commit5d324e509cb6147412a4484b23ac05940f04b434 (patch)
tree4d86c5be987e267df648c93958b41070b4de049d /clang/lib/StaticAnalyzer/Core/CheckerContext.cpp
parent28db7ceabd3ff35e90a70a6042db640e98ea8a37 (diff)
downloadbcm5719-llvm-5d324e509cb6147412a4484b23ac05940f04b434.tar.gz
bcm5719-llvm-5d324e509cb6147412a4484b23ac05940f04b434.zip
[analyzer] Taint: add taint propagation rules for string and memory copy
functions. llvm-svn: 148370
Diffstat (limited to 'clang/lib/StaticAnalyzer/Core/CheckerContext.cpp')
-rw-r--r--clang/lib/StaticAnalyzer/Core/CheckerContext.cpp29
1 files changed, 25 insertions, 4 deletions
diff --git a/clang/lib/StaticAnalyzer/Core/CheckerContext.cpp b/clang/lib/StaticAnalyzer/Core/CheckerContext.cpp
index 3737ca54672..cb272fb1c33 100644
--- a/clang/lib/StaticAnalyzer/Core/CheckerContext.cpp
+++ b/clang/lib/StaticAnalyzer/Core/CheckerContext.cpp
@@ -13,6 +13,8 @@
//===----------------------------------------------------------------------===//
#include "clang/StaticAnalyzer/Core/PathSensitive/CheckerContext.h"
+#include "clang/Basic/Builtins.h"
+
using namespace clang;
using namespace ento;
@@ -23,12 +25,31 @@ const FunctionDecl *CheckerContext::getCalleeDecl(const CallExpr *CE) const {
return L.getAsFunctionDecl();
}
-StringRef CheckerContext::getCalleeName(const CallExpr *CE) const {
- const FunctionDecl *funDecl = getCalleeDecl(CE);
- if (!funDecl)
+StringRef CheckerContext::getCalleeName(const FunctionDecl *FunDecl) const {
+ if (!FunDecl)
return StringRef();
- IdentifierInfo *funI = funDecl->getIdentifier();
+ IdentifierInfo *funI = FunDecl->getIdentifier();
if (!funI)
return StringRef();
return funI->getName();
}
+
+
+bool CheckerContext::isCLibraryFunction(const FunctionDecl *FD,
+ StringRef Name){
+ // To avoid false positives (Ex: finding user defined functions with
+ // similar names), only perform fuzzy name matching when it's a builtin.
+ // Using a string compare is slow, we might want to switch on BuiltinID here.
+ unsigned BId = FD->getBuiltinID();
+ if (BId != 0) {
+ ASTContext &Context = getASTContext();
+ StringRef BName = Context.BuiltinInfo.GetName(BId);
+ if (StringRef(BName).find(Name) != StringRef::npos)
+ return true;
+ }
+
+ if (FD->isExternC() && FD->getIdentifier()->getName().equals(Name))
+ return true;
+
+ return false;
+}
OpenPOWER on IntegriCloud