diff options
Diffstat (limited to 'clang/lib/StaticAnalyzer/Checkers')
| -rw-r--r-- | clang/lib/StaticAnalyzer/Checkers/CMakeLists.txt | 12 | ||||
| -rw-r--r-- | clang/lib/StaticAnalyzer/Checkers/Checkers.td | 18 | ||||
| -rw-r--r-- | clang/lib/StaticAnalyzer/Checkers/ClangSACheckerProvider.cpp | 135 | ||||
| -rw-r--r-- | clang/lib/StaticAnalyzer/Checkers/ClangSACheckerProvider.h | 29 | ||||
| -rw-r--r-- | clang/lib/StaticAnalyzer/Checkers/ClangSACheckers.h | 34 | ||||
| -rw-r--r-- | clang/lib/StaticAnalyzer/Checkers/ExprEngine.cpp | 2 | ||||
| -rw-r--r-- | clang/lib/StaticAnalyzer/Checkers/Makefile | 7 |
7 files changed, 237 insertions, 0 deletions
diff --git a/clang/lib/StaticAnalyzer/Checkers/CMakeLists.txt b/clang/lib/StaticAnalyzer/Checkers/CMakeLists.txt index 7db858dcfb7..c96b42db1ea 100644 --- a/clang/lib/StaticAnalyzer/Checkers/CMakeLists.txt +++ b/clang/lib/StaticAnalyzer/Checkers/CMakeLists.txt @@ -1,3 +1,14 @@ +set(LLVM_TARGET_DEFINITIONS Checkers.td) +tablegen(Checkers.inc + -gen-clang-sa-checkers + -I ${CMAKE_CURRENT_SOURCE_DIR}/../../../include) +add_custom_target(ClangSACheckers + DEPENDS Checkers.inc) + +# So 'Checkers.inc' can be included from the cmake build directory. +# FIXME: Someone more familiar with cmake should enable this for all of LLVM. +set(CMAKE_CXX_FLAGS "${CMAKE_CXX_FLAGS} -I ${CMAKE_CURRENT_BINARY_DIR}") + set(LLVM_USED_LIBS clangBasic clangAST) add_clang_library(clangStaticAnalyzerCheckers @@ -17,6 +28,7 @@ add_clang_library(clangStaticAnalyzerCheckers CheckSecuritySyntaxOnly.cpp CheckSizeofPointer.cpp ChrootChecker.cpp + ClangSACheckerProvider.cpp DeadStoresChecker.cpp DereferenceChecker.cpp DivZeroChecker.cpp diff --git a/clang/lib/StaticAnalyzer/Checkers/Checkers.td b/clang/lib/StaticAnalyzer/Checkers/Checkers.td new file mode 100644 index 00000000000..2a2f3eed0c2 --- /dev/null +++ b/clang/lib/StaticAnalyzer/Checkers/Checkers.td @@ -0,0 +1,18 @@ +//===--- Checkers.td - Static Analyzer Checkers -===-----------------------===// +// +// The LLVM Compiler Infrastructure +// +// This file is distributed under the University of Illinois Open Source +// License. See LICENSE.TXT for details. +// +//===----------------------------------------------------------------------===// + +include "clang/StaticAnalyzer/Checkers/CheckerBase.td" + +def Cocoa : Package<"cocoa">; + +def : Checker<"ObjCSelfInitChecker">, + InPackage<Cocoa>, + Named<"SelfInit">, + HelpText<"Check that 'self' is propely initialized inside an initializer method">, + DescFile<"ObjCSelfInitChecker.cpp">; diff --git a/clang/lib/StaticAnalyzer/Checkers/ClangSACheckerProvider.cpp b/clang/lib/StaticAnalyzer/Checkers/ClangSACheckerProvider.cpp new file mode 100644 index 00000000000..12178fcd8c7 --- /dev/null +++ b/clang/lib/StaticAnalyzer/Checkers/ClangSACheckerProvider.cpp @@ -0,0 +1,135 @@ +//===--- ClangSACheckerProvider.cpp - Clang SA Checkers Provider ----------===// +// +// The LLVM Compiler Infrastructure +// +// This file is distributed under the University of Illinois Open Source +// License. See LICENSE.TXT for details. +// +//===----------------------------------------------------------------------===// +// +// Defines the CheckerProvider for the checkers defined in +// libclangStaticAnalyzerCheckers. +// +//===----------------------------------------------------------------------===// + +#include "ClangSACheckerProvider.h" +#include "ClangSACheckers.h" +#include "clang/StaticAnalyzer/Core/CheckerManager.h" +#include "clang/StaticAnalyzer/Core/CheckerProvider.h" +#include "llvm/ADT/DenseSet.h" + +using namespace clang; +using namespace ento; + +namespace { + +/// \brief Provider for all the checkers in libclangStaticAnalyzerCheckers. +class ClangSACheckerProvider : public CheckerProvider { +public: + virtual void registerCheckers(CheckerManager &checkerMgr, + CheckerOptInfo *checkOpts, unsigned numCheckOpts); +}; + +} + +CheckerProvider *ento::createClangSACheckerProvider() { + return new ClangSACheckerProvider(); +} + +namespace { + +struct StaticCheckerInfoRec { + const char *FullName; + CheckerManager::RegisterFunc RegFunc; + bool Hidden; +}; + +} // end anonymous namespace. + +static const StaticCheckerInfoRec StaticCheckerInfo[] = { +#define GET_CHECKERS +#define CHECKER(FULLNAME,CLASS,DESCFILE,HELPTEXT,HIDDEN) \ + { FULLNAME, register##CLASS, HIDDEN }, +#include "Checkers.inc" + { 0, 0, 0} +#undef CHECKER +#undef GET_CHECKERS +}; + +namespace { + +struct CheckNameOption { + const char *Name; + const short *Members; + const short *SubGroups; +}; + +} // end anonymous namespace. + +#define GET_MEMBER_ARRAYS +#include "Checkers.inc" +#undef GET_MEMBER_ARRAYS + +// The table of check name options, sorted by name for fast binary lookup. +static const CheckNameOption CheckNameTable[] = { +#define GET_CHECKNAME_TABLE +#include "Checkers.inc" +#undef GET_CHECKNAME_TABLE +}; +static const size_t + CheckNameTableSize = sizeof(CheckNameTable) / sizeof(CheckNameTable[0]); + +static bool CheckNameOptionCompare(const CheckNameOption &LHS, + const CheckNameOption &RHS) { + return strcmp(LHS.Name, RHS.Name) < 0; +} + +static void collectCheckers(const CheckNameOption *checkName, + bool enable, + llvm::DenseSet<const StaticCheckerInfoRec *> &checkers, + bool collectHidden) { + if (const short *member = checkName->Members) { + if (enable) { + if (collectHidden || !StaticCheckerInfo[*member].Hidden) + checkers.insert(&StaticCheckerInfo[*member]); + } else { + for (; *member != -1; ++member) + checkers.erase(&StaticCheckerInfo[*member]); + } + } + + // Enable/disable all subgroups along with this one. + if (const short *subGroups = checkName->SubGroups) { + for (; *subGroups != -1; ++subGroups) + collectCheckers(&CheckNameTable[*subGroups], enable, checkers, + /*don't enable hidden in subgroups*/ false); + } +} + +static void collectCheckers(CheckerOptInfo &opt, + llvm::DenseSet<const StaticCheckerInfoRec *> &checkers) { + const char *optName = opt.getName(); + CheckNameOption key = { optName, 0, 0 }; + const CheckNameOption *found = + std::lower_bound(CheckNameTable, CheckNameTable + CheckNameTableSize, key, + CheckNameOptionCompare); + if (found == CheckNameTable + CheckNameTableSize || + strcmp(found->Name, optName) != 0) + return; // Check name not found. + + opt.claim(); + collectCheckers(found, opt.isEnabled(), checkers, /*collectHidden=*/true); +} + +#include "llvm/Support/raw_ostream.h" + +void ClangSACheckerProvider::registerCheckers(CheckerManager &checkerMgr, + CheckerOptInfo *checkOpts, unsigned numCheckOpts) { + llvm::DenseSet<const StaticCheckerInfoRec *> enabledCheckers; + for (unsigned i = 0; i != numCheckOpts; ++i) + collectCheckers(checkOpts[i], enabledCheckers); + for (llvm::DenseSet<const StaticCheckerInfoRec *>::iterator + I = enabledCheckers.begin(), E = enabledCheckers.end(); I != E; ++I) { + checkerMgr.addCheckerRegisterFunction((*I)->RegFunc); + } +} diff --git a/clang/lib/StaticAnalyzer/Checkers/ClangSACheckerProvider.h b/clang/lib/StaticAnalyzer/Checkers/ClangSACheckerProvider.h new file mode 100644 index 00000000000..f6c80119fdc --- /dev/null +++ b/clang/lib/StaticAnalyzer/Checkers/ClangSACheckerProvider.h @@ -0,0 +1,29 @@ +//===--- ClangSACheckerProvider.h - Clang SA Checkers Provider --*- C++ -*-===// +// +// The LLVM Compiler Infrastructure +// +// This file is distributed under the University of Illinois Open Source +// License. See LICENSE.TXT for details. +// +//===----------------------------------------------------------------------===// +// +// Defines the entry point for creating the provider for the checkers defined +// in libclangStaticAnalyzerCheckers. +// +//===----------------------------------------------------------------------===// + +#ifndef LLVM_CLANG_SA_CHECKERS_CLANGSACHECKERPROVIDER_H +#define LLVM_CLANG_SA_CHECKERS_CLANGSACHECKERPROVIDER_H + +namespace clang { + +namespace ento { + class CheckerProvider; + +CheckerProvider *createClangSACheckerProvider(); + +} // end ento namespace + +} // end clang namespace + +#endif diff --git a/clang/lib/StaticAnalyzer/Checkers/ClangSACheckers.h b/clang/lib/StaticAnalyzer/Checkers/ClangSACheckers.h new file mode 100644 index 00000000000..b01b0f4c544 --- /dev/null +++ b/clang/lib/StaticAnalyzer/Checkers/ClangSACheckers.h @@ -0,0 +1,34 @@ +//===--- ClangSACheckers.h - Registration functions for Checkers *- C++ -*-===// +// +// The LLVM Compiler Infrastructure +// +// This file is distributed under the University of Illinois Open Source +// License. See LICENSE.TXT for details. +// +//===----------------------------------------------------------------------===// +// +// Declares the registation functions for the checkers defined in +// libclangStaticAnalyzerCheckers. +// +//===----------------------------------------------------------------------===// + +#ifndef LLVM_CLANG_SA_LIB_CHECKERS_CLANGSACHECKERS_H +#define LLVM_CLANG_SA_LIB_CHECKERS_CLANGSACHECKERS_H + +namespace clang { + +namespace ento { +class ExprEngine; + +#define GET_CHECKERS +#define CHECKER(FULLNAME,CLASS,CXXFILE,HELPTEXT,HIDDEN) \ + void register##CLASS(ExprEngine &Eng); +#include "Checkers.inc" +#undef CHECKER +#undef GET_CHECKERS + +} // end ento namespace + +} // end clang namespace + +#endif diff --git a/clang/lib/StaticAnalyzer/Checkers/ExprEngine.cpp b/clang/lib/StaticAnalyzer/Checkers/ExprEngine.cpp index dea2c280102..26523d368b2 100644 --- a/clang/lib/StaticAnalyzer/Checkers/ExprEngine.cpp +++ b/clang/lib/StaticAnalyzer/Checkers/ExprEngine.cpp @@ -16,6 +16,7 @@ // FIXME: Restructure checker registration. #include "InternalChecks.h" +#include "clang/StaticAnalyzer/Core/CheckerManager.h" #include "clang/StaticAnalyzer/Core/BugReporter/BugType.h" #include "clang/StaticAnalyzer/Core/PathSensitive/AnalysisManager.h" #include "clang/StaticAnalyzer/Core/PathSensitive/ExprEngine.h" @@ -332,6 +333,7 @@ ExprEngine::ExprEngine(AnalysisManager &mgr, TransferFuncs *tf) NSExceptionII(NULL), NSExceptionInstanceRaiseSelectors(NULL), RaiseSel(GetNullarySelector("raise", getContext())), BR(mgr, *this), TF(tf) { + mgr.getCheckerManager()->registerCheckersToEngine(*this); // Register internal checks. RegisterInternalChecks(*this); diff --git a/clang/lib/StaticAnalyzer/Checkers/Makefile b/clang/lib/StaticAnalyzer/Checkers/Makefile index d4de35c1f58..a9a2bebf44b 100644 --- a/clang/lib/StaticAnalyzer/Checkers/Makefile +++ b/clang/lib/StaticAnalyzer/Checkers/Makefile @@ -14,4 +14,11 @@ CLANG_LEVEL := ../../.. LIBRARYNAME := clangStaticAnalyzerCheckers +BUILT_SOURCES = Checkers.inc +TABLEGEN_INC_FILES_COMMON = 1 + include $(CLANG_LEVEL)/Makefile + +$(ObjDir)/Checkers.inc.tmp : Checkers.td $(TBLGEN) $(ObjDir)/.dir + $(Echo) "Building Clang SA Checkers tables with tblgen" + $(Verb) $(TableGen) -gen-clang-sa-checkers -I $(PROJ_SRC_DIR)/$(CLANG_LEVEL)/include -o $(call SYSPATH, $@) $< |

