]> granicus.if.org Git - clang/commitdiff
Hook up Malloc checker.
authorZhongxing Xu <xuzhongxing@gmail.com>
Fri, 13 Nov 2009 07:25:27 +0000 (07:25 +0000)
committerZhongxing Xu <xuzhongxing@gmail.com>
Fri, 13 Nov 2009 07:25:27 +0000 (07:25 +0000)
git-svn-id: https://llvm.org/svn/llvm-project/cfe/trunk@87093 91177308-0d34-0410-b5e6-96231b3b80d8

lib/Analysis/GRExprEngineExperimentalChecks.cpp
lib/Analysis/GRExprEngineExperimentalChecks.h
lib/Analysis/MallocChecker.cpp

index e50dbeba68875e2534e0ac3b007bc65efa34d66f..75f97898ff14ea7bacd9349de7ba21feb167f12a 100644 (file)
@@ -19,5 +19,6 @@ using namespace clang;
 
 void clang::RegisterExperimentalChecks(GRExprEngine &Eng) {
   RegisterPthreadLockChecker(Eng);  
+  RegisterMallocChecker(Eng);
 }
 
index bb9af3a416f150b051ae9725df64d1fd0c405c8a..9a9da32e556e6951a14754c03f1671db7ea2db85 100644 (file)
@@ -20,6 +20,7 @@ namespace clang {
 class GRExprEngine;
 
 void RegisterPthreadLockChecker(GRExprEngine &Eng);
+void RegisterMallocChecker(GRExprEngine &Eng);
 
 } // end clang namespace
 #endif
index cbc115f9dae8094d3febbe7c420093b977e781e3..f007aa65da1b1dd1be933837a731d36e647bd85c 100644 (file)
@@ -12,6 +12,7 @@
 //
 //===----------------------------------------------------------------------===//
 
+#include "GRExprEngineExperimentalChecks.h"
 #include "clang/Analysis/PathSensitive/CheckerVisitor.h"
 #include "clang/Analysis/PathSensitive/GRState.h"
 #include "clang/Analysis/PathSensitive/GRStateTrait.h"
@@ -33,8 +34,11 @@ class VISIBILITY_HIDDEN MallocChecker : public CheckerVisitor<MallocChecker> {
   IdentifierInfo *II_free;
 
 public:
+  MallocChecker() : BT_DoubleFree(0) {}
   static void *getTag();
   void PostVisitCallExpr(CheckerContext &C, const CallExpr *CE);
+  void EvalDeadSymbols(CheckerContext &C,const Stmt *S,SymbolReaper &SymReaper);
+private:
   void MallocMem(CheckerContext &C, const CallExpr *CE);
   void FreeMem(CheckerContext &C, const CallExpr *CE);
 };
@@ -59,6 +63,10 @@ namespace clang {
   };
 }
 
+void clang::RegisterMallocChecker(GRExprEngine &Eng) {
+  Eng.registerCheck(new MallocChecker());
+}
+
 void *MallocChecker::getTag() {
   static int x;
   return &x;
@@ -124,3 +132,7 @@ void MallocChecker::FreeMem(CheckerContext &C, const CallExpr *CE) {
   const GRState *FreedState = state->set<RegionState>(Sym, Released);
   C.addTransition(C.GenerateNode(CE, FreedState));
 }
+
+void MallocChecker::EvalDeadSymbols(CheckerContext &C, const Stmt *S,
+                                    SymbolReaper &SymReaper) {
+}