Argyrios Kyrtzidis | 43dee22 | 2011-02-14 18:13:31 +0000 | [diff] [blame] | 1 | //===--- Checkers.td - Static Analyzer Checkers -===-----------------------===// |
| 2 | // |
| 3 | // The LLVM Compiler Infrastructure |
| 4 | // |
| 5 | // This file is distributed under the University of Illinois Open Source |
| 6 | // License. See LICENSE.TXT for details. |
| 7 | // |
| 8 | //===----------------------------------------------------------------------===// |
| 9 | |
| 10 | include "clang/StaticAnalyzer/Checkers/CheckerBase.td" |
| 11 | |
Argyrios Kyrtzidis | a0decc9 | 2011-02-15 21:25:03 +0000 | [diff] [blame] | 12 | //===----------------------------------------------------------------------===// |
| 13 | // Packages. |
| 14 | //===----------------------------------------------------------------------===// |
| 15 | |
Ted Kremenek | 033a07e | 2011-08-03 23:14:55 +0000 | [diff] [blame] | 16 | def Experimental : Package<"experimental">; |
| 17 | |
Argyrios Kyrtzidis | 027a6ab | 2011-02-15 07:42:33 +0000 | [diff] [blame] | 18 | def Core : Package<"core">; |
Ted Kremenek | 5188507 | 2011-03-24 00:28:47 +0000 | [diff] [blame] | 19 | def CoreBuiltin : Package<"builtin">, InPackage<Core>; |
| 20 | def CoreUninitialized : Package<"uninitialized">, InPackage<Core>; |
Ted Kremenek | 0e24471 | 2011-08-04 00:25:50 +0000 | [diff] [blame] | 21 | def CoreExperimental : Package<"core">, InPackage<Experimental>, Hidden; |
Ted Kremenek | 5188507 | 2011-03-24 00:28:47 +0000 | [diff] [blame] | 22 | |
| 23 | def Cplusplus : Package<"cplusplus">; |
Ted Kremenek | 0e24471 | 2011-08-04 00:25:50 +0000 | [diff] [blame] | 24 | def CplusplusExperimental : Package<"cplusplus">, InPackage<Experimental>, Hidden; |
Ted Kremenek | 5188507 | 2011-03-24 00:28:47 +0000 | [diff] [blame] | 25 | |
Ted Kremenek | ade3195 | 2011-03-12 06:14:28 +0000 | [diff] [blame] | 26 | def DeadCode : Package<"deadcode">; |
Ted Kremenek | 0e24471 | 2011-08-04 00:25:50 +0000 | [diff] [blame] | 27 | def DeadCodeExperimental : Package<"deadcode">, InPackage<Experimental>, Hidden; |
Argyrios Kyrtzidis | 027a6ab | 2011-02-15 07:42:33 +0000 | [diff] [blame] | 28 | |
Ted Kremenek | 5188507 | 2011-03-24 00:28:47 +0000 | [diff] [blame] | 29 | def Security : Package <"security">; |
Ted Kremenek | 76a5424 | 2012-01-20 01:44:29 +0000 | [diff] [blame] | 30 | def InsecureAPI : Package<"insecureAPI">, InPackage<Security>; |
Ted Kremenek | 0e24471 | 2011-08-04 00:25:50 +0000 | [diff] [blame] | 31 | def SecurityExperimental : Package<"security">, InPackage<Experimental>, Hidden; |
Anna Zaks | df18c5a | 2011-11-16 19:58:13 +0000 | [diff] [blame] | 32 | def Taint : Package<"taint">, InPackage<SecurityExperimental>, Hidden; |
Argyrios Kyrtzidis | a0decc9 | 2011-02-15 21:25:03 +0000 | [diff] [blame] | 33 | |
Ted Kremenek | 5188507 | 2011-03-24 00:28:47 +0000 | [diff] [blame] | 34 | def Unix : Package<"unix">; |
Ted Kremenek | 0e24471 | 2011-08-04 00:25:50 +0000 | [diff] [blame] | 35 | def UnixExperimental : Package<"unix">, InPackage<Experimental>, Hidden; |
Anna Zaks | bb2a686 | 2012-02-20 21:10:37 +0000 | [diff] [blame] | 36 | def CString : Package<"cstring">, InPackage<Unix>, Hidden; |
| 37 | def CStringExperimental : Package<"cstring">, InPackage<UnixExperimental>, Hidden; |
Argyrios Kyrtzidis | 7dd445e | 2011-02-17 21:39:33 +0000 | [diff] [blame] | 38 | |
Ted Kremenek | 5188507 | 2011-03-24 00:28:47 +0000 | [diff] [blame] | 39 | def OSX : Package<"osx">; |
Ted Kremenek | 0e24471 | 2011-08-04 00:25:50 +0000 | [diff] [blame] | 40 | def OSXExperimental : Package<"osx">, InPackage<Experimental>, Hidden; |
Ted Kremenek | 5188507 | 2011-03-24 00:28:47 +0000 | [diff] [blame] | 41 | def Cocoa : Package<"cocoa">, InPackage<OSX>; |
Ted Kremenek | 0e24471 | 2011-08-04 00:25:50 +0000 | [diff] [blame] | 42 | def CocoaExperimental : Package<"cocoa">, InPackage<OSXExperimental>, Hidden; |
Ted Kremenek | 5188507 | 2011-03-24 00:28:47 +0000 | [diff] [blame] | 43 | def CoreFoundation : Package<"coreFoundation">, InPackage<OSX>; |
Anna Zaks | 52a3888 | 2012-02-04 02:31:57 +0000 | [diff] [blame] | 44 | def Containers : Package<"containers">, InPackage<CoreFoundation>; |
Argyrios Kyrtzidis | a0decc9 | 2011-02-15 21:25:03 +0000 | [diff] [blame] | 45 | |
Argyrios Kyrtzidis | 9fb9474 | 2011-02-17 21:39:24 +0000 | [diff] [blame] | 46 | def LLVM : Package<"llvm">; |
Argyrios Kyrtzidis | 2d67b90 | 2011-02-17 21:39:39 +0000 | [diff] [blame] | 47 | def Debug : Package<"debug">; |
Argyrios Kyrtzidis | 9fb9474 | 2011-02-17 21:39:24 +0000 | [diff] [blame] | 48 | |
Argyrios Kyrtzidis | a0decc9 | 2011-02-15 21:25:03 +0000 | [diff] [blame] | 49 | //===----------------------------------------------------------------------===// |
Ted Kremenek | 5188507 | 2011-03-24 00:28:47 +0000 | [diff] [blame] | 50 | // Core Checkers. |
Argyrios Kyrtzidis | a0decc9 | 2011-02-15 21:25:03 +0000 | [diff] [blame] | 51 | //===----------------------------------------------------------------------===// |
| 52 | |
Ted Kremenek | 5188507 | 2011-03-24 00:28:47 +0000 | [diff] [blame] | 53 | let ParentPackage = Core in { |
| 54 | |
| 55 | def DereferenceChecker : Checker<"NullDereference">, |
| 56 | HelpText<"Check for dereferences of null pointers">, |
| 57 | DescFile<"DereferenceChecker.cpp">; |
| 58 | |
| 59 | def CallAndMessageChecker : Checker<"CallAndMessage">, |
| 60 | HelpText<"Check for logical errors for function calls and Objective-C message expressions (e.g., uninitialized arguments, null function pointers)">, |
| 61 | DescFile<"CallAndMessageChecker.cpp">; |
| 62 | |
| 63 | def AdjustedReturnValueChecker : Checker<"AdjustedReturnValue">, |
| 64 | HelpText<"Check to see if the return value of a function call is different than the caller expects (e.g., from calls through function pointers)">, |
| 65 | DescFile<"AdjustedReturnValueChecker.cpp">; |
| 66 | |
| 67 | def AttrNonNullChecker : Checker<"AttributeNonNull">, |
| 68 | HelpText<"Check for null pointers passed as arguments to a function whose arguments are marked with the 'nonnull' attribute">, |
| 69 | DescFile<"AttrNonNullChecker.cpp">; |
| 70 | |
| 71 | def VLASizeChecker : Checker<"VLASize">, |
| 72 | HelpText<"Check for declarations of VLA of undefined or zero size">, |
| 73 | DescFile<"VLASizeChecker.cpp">; |
| 74 | |
| 75 | def DivZeroChecker : Checker<"DivideZero">, |
| 76 | HelpText<"Check for division by zero">, |
| 77 | DescFile<"DivZeroChecker.cpp">; |
| 78 | |
| 79 | def UndefResultChecker : Checker<"UndefinedBinaryOperatorResult">, |
| 80 | HelpText<"Check for undefined results of binary operators">, |
| 81 | DescFile<"UndefResultChecker.cpp">; |
| 82 | |
| 83 | def StackAddrEscapeChecker : Checker<"StackAddressEscape">, |
| 84 | HelpText<"Check that addresses to stack memory do not escape the function">, |
| 85 | DescFile<"StackAddrEscapeChecker.cpp">; |
| 86 | |
| 87 | } // end "core" |
| 88 | |
| 89 | let ParentPackage = CoreExperimental in { |
| 90 | |
Ryan Govostes | b141b28 | 2012-02-11 16:32:09 +0000 | [diff] [blame] | 91 | def BoolAssignmentChecker : Checker<"BoolAssignment">, |
| 92 | HelpText<"Warn about assigning non-{0,1} values to Boolean variables">, |
| 93 | DescFile<"BoolAssignmentChecker.cpp">; |
| 94 | |
Ted Kremenek | 5188507 | 2011-03-24 00:28:47 +0000 | [diff] [blame] | 95 | def CastSizeChecker : Checker<"CastSize">, |
Ted Kremenek | 5188507 | 2011-03-24 00:28:47 +0000 | [diff] [blame] | 96 | HelpText<"Check when casting a malloc'ed type T, whether the size is a multiple of the size of T">, |
| 97 | DescFile<"CastSizeChecker.cpp">; |
| 98 | |
| 99 | def CastToStructChecker : Checker<"CastToStruct">, |
Ted Kremenek | 5188507 | 2011-03-24 00:28:47 +0000 | [diff] [blame] | 100 | HelpText<"Check for cast from non-struct pointer to struct pointer">, |
| 101 | DescFile<"CastToStructChecker.cpp">; |
| 102 | |
| 103 | def FixedAddressChecker : Checker<"FixedAddr">, |
Ted Kremenek | 5188507 | 2011-03-24 00:28:47 +0000 | [diff] [blame] | 104 | HelpText<"Check for assignment of a fixed address to a pointer">, |
| 105 | DescFile<"FixedAddressChecker.cpp">; |
| 106 | |
| 107 | def PointerArithChecker : Checker<"PointerArithm">, |
Ted Kremenek | 5188507 | 2011-03-24 00:28:47 +0000 | [diff] [blame] | 108 | HelpText<"Check for pointer arithmetic on locations other than array elements">, |
| 109 | DescFile<"PointerArithChecker">; |
| 110 | |
| 111 | def PointerSubChecker : Checker<"PointerSub">, |
Ted Kremenek | 5188507 | 2011-03-24 00:28:47 +0000 | [diff] [blame] | 112 | HelpText<"Check for pointer subtractions on two pointers pointing to different memory chunks">, |
| 113 | DescFile<"PointerSubChecker">; |
| 114 | |
| 115 | def SizeofPointerChecker : Checker<"SizeofPtr">, |
Ted Kremenek | 5188507 | 2011-03-24 00:28:47 +0000 | [diff] [blame] | 116 | HelpText<"Warn about unintended use of sizeof() on pointer expressions">, |
| 117 | DescFile<"CheckSizeofPointer.cpp">; |
| 118 | |
| 119 | } // end "core.experimental" |
| 120 | |
| 121 | //===----------------------------------------------------------------------===// |
| 122 | // Evaluate "builtin" functions. |
| 123 | //===----------------------------------------------------------------------===// |
| 124 | |
| 125 | let ParentPackage = CoreBuiltin in { |
| 126 | |
| 127 | def NoReturnFunctionChecker : Checker<"NoReturnFunctions">, |
| 128 | HelpText<"Evaluate \"panic\" functions that are known to not return to the caller">, |
| 129 | DescFile<"NoReturnFunctionChecker.cpp">; |
| 130 | |
| 131 | def BuiltinFunctionChecker : Checker<"BuiltinFunctions">, |
| 132 | HelpText<"Evaluate compiler builtin functions (e.g., alloca())">, |
| 133 | DescFile<"BuiltinFunctionChecker.cpp">; |
| 134 | |
| 135 | } // end "core.builtin" |
| 136 | |
| 137 | //===----------------------------------------------------------------------===// |
| 138 | // Uninitialized values checkers. |
| 139 | //===----------------------------------------------------------------------===// |
| 140 | |
| 141 | let ParentPackage = CoreUninitialized in { |
| 142 | |
| 143 | def UndefinedArraySubscriptChecker : Checker<"ArraySubscript">, |
| 144 | HelpText<"Check for uninitialized values used as array subscripts">, |
| 145 | DescFile<"UndefinedArraySubscriptChecker.cpp">; |
| 146 | |
| 147 | def UndefinedAssignmentChecker : Checker<"Assign">, |
| 148 | HelpText<"Check for assigning uninitialized values">, |
| 149 | DescFile<"UndefinedAssignmentChecker.cpp">; |
| 150 | |
| 151 | def UndefBranchChecker : Checker<"Branch">, |
| 152 | HelpText<"Check for uninitialized values used as branch conditions">, |
| 153 | DescFile<"UndefBranchChecker.cpp">; |
| 154 | |
| 155 | def UndefCapturedBlockVarChecker : Checker<"CapturedBlockVariable">, |
| 156 | HelpText<"Check for blocks that capture uninitialized values">, |
| 157 | DescFile<"UndefCapturedBlockVarChecker.cpp">; |
| 158 | |
| 159 | def ReturnUndefChecker : Checker<"UndefReturn">, |
| 160 | HelpText<"Check for uninitialized values being returned to the caller">, |
| 161 | DescFile<"ReturnUndefChecker.cpp">; |
| 162 | |
| 163 | } // end "core.uninitialized" |
| 164 | |
| 165 | //===----------------------------------------------------------------------===// |
| 166 | // C++ checkers. |
| 167 | //===----------------------------------------------------------------------===// |
| 168 | |
| 169 | let ParentPackage = CplusplusExperimental in { |
| 170 | |
Ted Kremenek | 5188507 | 2011-03-24 00:28:47 +0000 | [diff] [blame] | 171 | def IteratorsChecker : Checker<"Iterators">, |
Ted Kremenek | 5188507 | 2011-03-24 00:28:47 +0000 | [diff] [blame] | 172 | HelpText<"Check improper uses of STL vector iterators">, |
| 173 | DescFile<"IteratorsChecker.cpp">; |
| 174 | |
Ted Kremenek | de9f253 | 2012-01-03 23:18:57 +0000 | [diff] [blame] | 175 | def VirtualCallChecker : Checker<"VirtualCall">, |
| 176 | HelpText<"Check virtual function calls during construction or destruction">, |
| 177 | DescFile<"VirtualCallChecker.cpp">; |
| 178 | |
Ted Kremenek | 5188507 | 2011-03-24 00:28:47 +0000 | [diff] [blame] | 179 | } // end: "cplusplus.experimental" |
| 180 | |
| 181 | //===----------------------------------------------------------------------===// |
| 182 | // Deadcode checkers. |
| 183 | //===----------------------------------------------------------------------===// |
| 184 | |
| 185 | let ParentPackage = DeadCode in { |
| 186 | |
| 187 | def DeadStoresChecker : Checker<"DeadStores">, |
Ted Kremenek | b803026 | 2011-03-26 00:25:42 +0000 | [diff] [blame] | 188 | HelpText<"Check for values stored to variables that are never read afterwards">, |
Ted Kremenek | 5188507 | 2011-03-24 00:28:47 +0000 | [diff] [blame] | 189 | DescFile<"DeadStoresChecker.cpp">; |
Ted Kremenek | a8180e5 | 2012-01-20 06:00:17 +0000 | [diff] [blame] | 190 | } // end DeadCode |
| 191 | |
| 192 | let ParentPackage = DeadCodeExperimental in { |
Ted Kremenek | 5188507 | 2011-03-24 00:28:47 +0000 | [diff] [blame] | 193 | |
| 194 | def IdempotentOperationChecker : Checker<"IdempotentOperations">, |
| 195 | HelpText<"Warn about idempotent operations">, |
| 196 | DescFile<"IdempotentOperationChecker.cpp">; |
| 197 | |
Ted Kremenek | 5188507 | 2011-03-24 00:28:47 +0000 | [diff] [blame] | 198 | def UnreachableCodeChecker : Checker<"UnreachableCode">, |
Ted Kremenek | 5188507 | 2011-03-24 00:28:47 +0000 | [diff] [blame] | 199 | HelpText<"Check unreachable code">, |
| 200 | DescFile<"UnreachableCodeChecker.cpp">; |
| 201 | |
| 202 | } // end "deadcode.experimental" |
| 203 | |
| 204 | //===----------------------------------------------------------------------===// |
| 205 | // Security checkers. |
| 206 | //===----------------------------------------------------------------------===// |
| 207 | |
Ted Kremenek | 76a5424 | 2012-01-20 01:44:29 +0000 | [diff] [blame] | 208 | let ParentPackage = InsecureAPI in { |
| 209 | def gets : Checker<"gets">, |
| 210 | HelpText<"Warn on uses of the 'gets' function">, |
| 211 | DescFile<"CheckSecuritySyntaxOnly.cpp">; |
| 212 | def getpw : Checker<"getpw">, |
| 213 | HelpText<"Warn on uses of the 'getpw' function">, |
| 214 | DescFile<"CheckSecuritySyntaxOnly.cpp">; |
| 215 | def mktemp : Checker<"mktemp">, |
| 216 | HelpText<"Warn on uses of the 'mktemp' function">, |
| 217 | DescFile<"CheckSecuritySyntaxOnly.cpp">; |
Ted Kremenek | b63d8d8 | 2012-01-20 05:35:06 +0000 | [diff] [blame] | 218 | def mkstemp : Checker<"mkstemp">, |
| 219 | HelpText<"Warn when 'mkstemp' is passed fewer than 6 X's in the format string">, |
| 220 | DescFile<"CheckSecuritySyntaxOnly.cpp">; |
Ted Kremenek | 76a5424 | 2012-01-20 01:44:29 +0000 | [diff] [blame] | 221 | def rand : Checker<"rand">, |
| 222 | HelpText<"Warn on uses of the 'rand', 'random', and related functions">, |
| 223 | DescFile<"CheckSecuritySyntaxOnly.cpp">; |
| 224 | def strcpy : Checker<"strcpy">, |
| 225 | HelpText<"Warn on uses of the 'strcpy' and 'strcat' functions">, |
| 226 | DescFile<"CheckSecuritySyntaxOnly.cpp">; |
| 227 | def vfork : Checker<"vfork">, |
| 228 | HelpText<"Warn on uses of the 'vfork' function">, |
| 229 | DescFile<"CheckSecuritySyntaxOnly.cpp">; |
Ted Kremenek | b63d8d8 | 2012-01-20 05:35:06 +0000 | [diff] [blame] | 230 | def UncheckedReturn : Checker<"UncheckedReturn">, |
| 231 | HelpText<"Warn on uses of functions whose return values must be always checked">, |
| 232 | DescFile<"CheckSecuritySyntaxOnly.cpp">; |
Ted Kremenek | 76a5424 | 2012-01-20 01:44:29 +0000 | [diff] [blame] | 233 | } |
| 234 | let ParentPackage = Security in { |
| 235 | def FloatLoopCounter : Checker<"FloatLoopCounter">, |
| 236 | HelpText<"Warn on using a floating point value as a loop counter (CERT: FLP30-C, FLP30-CPP)">, |
| 237 | DescFile<"CheckSecuritySyntaxOnly.cpp">; |
| 238 | } |
Ted Kremenek | 5188507 | 2011-03-24 00:28:47 +0000 | [diff] [blame] | 239 | |
Ted Kremenek | 76a5424 | 2012-01-20 01:44:29 +0000 | [diff] [blame] | 240 | let ParentPackage = SecurityExperimental in { |
Ted Kremenek | 5188507 | 2011-03-24 00:28:47 +0000 | [diff] [blame] | 241 | |
| 242 | def ArrayBoundChecker : Checker<"ArrayBound">, |
Ted Kremenek | 5188507 | 2011-03-24 00:28:47 +0000 | [diff] [blame] | 243 | HelpText<"Warn about buffer overflows (older checker)">, |
| 244 | DescFile<"ArrayBoundChecker.cpp">; |
| 245 | |
| 246 | def ArrayBoundCheckerV2 : Checker<"ArrayBoundV2">, |
Ted Kremenek | 5188507 | 2011-03-24 00:28:47 +0000 | [diff] [blame] | 247 | HelpText<"Warn about buffer overflows (newer checker)">, |
| 248 | DescFile<"ArrayBoundCheckerV2.cpp">; |
| 249 | |
| 250 | def ReturnPointerRangeChecker : Checker<"ReturnPtrRange">, |
Ted Kremenek | 5188507 | 2011-03-24 00:28:47 +0000 | [diff] [blame] | 251 | HelpText<"Check for an out-of-bound pointer being returned to callers">, |
| 252 | DescFile<"ReturnPointerRangeChecker.cpp">; |
| 253 | |
Ted Kremenek | 17f7bdd | 2011-08-03 20:17:43 +0000 | [diff] [blame] | 254 | def MallocOverflowSecurityChecker : Checker<"MallocOverflow">, |
| 255 | HelpText<"Check for overflows in the arguments to malloc()">, |
| 256 | DescFile<"MallocOverflowSecurityChecker.cpp">; |
| 257 | |
Ted Kremenek | 5188507 | 2011-03-24 00:28:47 +0000 | [diff] [blame] | 258 | } // end "security.experimental" |
| 259 | |
| 260 | //===----------------------------------------------------------------------===// |
Anna Zaks | df18c5a | 2011-11-16 19:58:13 +0000 | [diff] [blame] | 261 | // Taint checkers. |
| 262 | //===----------------------------------------------------------------------===// |
| 263 | |
| 264 | let ParentPackage = Taint in { |
| 265 | |
| 266 | def GenericTaintChecker : Checker<"TaintPropagation">, |
| 267 | HelpText<"Generate taint information used by other checkers">, |
| 268 | DescFile<"GenericTaintChecker.cpp">; |
| 269 | |
| 270 | } // end "experimental.security.taint" |
| 271 | |
| 272 | //===----------------------------------------------------------------------===// |
Ted Kremenek | 5188507 | 2011-03-24 00:28:47 +0000 | [diff] [blame] | 273 | // Unix API checkers. |
| 274 | //===----------------------------------------------------------------------===// |
| 275 | |
| 276 | let ParentPackage = Unix in { |
| 277 | |
| 278 | def UnixAPIChecker : Checker<"API">, |
| 279 | HelpText<"Check calls to various UNIX/Posix functions">, |
| 280 | DescFile<"UnixAPIChecker.cpp">; |
Anna Zaks | bb2a686 | 2012-02-20 21:10:37 +0000 | [diff] [blame] | 281 | |
| 282 | def MallocPessimistic : Checker<"Malloc">, |
| 283 | HelpText<"Check for memory leaks, double free, and use-after-free problems.">, |
| 284 | DescFile<"MallocChecker.cpp">; |
Ted Kremenek | 5188507 | 2011-03-24 00:28:47 +0000 | [diff] [blame] | 285 | |
Anna Zaks | ca11510 | 2012-05-07 23:30:29 +0000 | [diff] [blame] | 286 | def MallocSizeofChecker : Checker<"MallocSizeof">, |
| 287 | HelpText<"Check for dubious malloc arguments involving sizeof">, |
| 288 | DescFile<"MallocSizeofChecker.cpp">; |
| 289 | |
Ted Kremenek | 5188507 | 2011-03-24 00:28:47 +0000 | [diff] [blame] | 290 | } // end "unix" |
| 291 | |
| 292 | let ParentPackage = UnixExperimental in { |
| 293 | |
| 294 | def ChrootChecker : Checker<"Chroot">, |
Ted Kremenek | 5188507 | 2011-03-24 00:28:47 +0000 | [diff] [blame] | 295 | HelpText<"Check improper use of chroot">, |
| 296 | DescFile<"ChrootChecker.cpp">; |
| 297 | |
Anna Zaks | 231361a | 2012-02-08 23:16:52 +0000 | [diff] [blame] | 298 | def MallocOptimistic : Checker<"MallocWithAnnotations">, |
| 299 | HelpText<"Check for memory leaks, double free, and use-after-free problems. Assumes that all user-defined functions which might free a pointer are annotated.">, |
| 300 | DescFile<"MallocChecker.cpp">; |
| 301 | |
Ted Kremenek | 5188507 | 2011-03-24 00:28:47 +0000 | [diff] [blame] | 302 | def PthreadLockChecker : Checker<"PthreadLock">, |
Ted Kremenek | 5188507 | 2011-03-24 00:28:47 +0000 | [diff] [blame] | 303 | HelpText<"Simple lock -> unlock checker">, |
| 304 | DescFile<"PthreadLockChecker.cpp">; |
| 305 | |
| 306 | def StreamChecker : Checker<"Stream">, |
Ted Kremenek | 5188507 | 2011-03-24 00:28:47 +0000 | [diff] [blame] | 307 | HelpText<"Check stream handling functions">, |
| 308 | DescFile<"StreamChecker.cpp">; |
| 309 | |
| 310 | } // end "unix.experimental" |
| 311 | |
Anna Zaks | e00575f | 2012-01-31 19:33:39 +0000 | [diff] [blame] | 312 | let ParentPackage = CString in { |
| 313 | |
Anna Zaks | 5730076 | 2012-02-07 00:56:14 +0000 | [diff] [blame] | 314 | def CStringNullArg : Checker<"NullArg">, |
| 315 | HelpText<"Check for null pointers being passed as arguments to C string functions">, |
| 316 | DescFile<"CStringChecker.cpp">; |
| 317 | |
Anna Zaks | bb2a686 | 2012-02-20 21:10:37 +0000 | [diff] [blame] | 318 | def CStringSyntaxChecker : Checker<"BadSizeArg">, |
| 319 | HelpText<"Check the size argument passed into C string functions for common erroneous patterns">, |
| 320 | DescFile<"CStringSyntaxChecker.cpp">; |
| 321 | } |
| 322 | |
| 323 | let ParentPackage = CStringExperimental in { |
| 324 | |
Anna Zaks | 5730076 | 2012-02-07 00:56:14 +0000 | [diff] [blame] | 325 | def CStringOutOfBounds : Checker<"OutOfBounds">, |
| 326 | HelpText<"Check for out-of-bounds access in string functions">, |
| 327 | DescFile<"CStringChecker.cpp">; |
| 328 | |
| 329 | def CStringBufferOverlap : Checker<"BufferOverlap">, |
| 330 | HelpText<"Checks for overlap in two buffer arguments">, |
| 331 | DescFile<"CStringChecker.cpp">; |
| 332 | |
| 333 | def CStringNotNullTerm : Checker<"NotNullTerminated">, |
| 334 | HelpText<"Check for arguments which are not null-terminating strings">, |
Anna Zaks | e00575f | 2012-01-31 19:33:39 +0000 | [diff] [blame] | 335 | DescFile<"CStringChecker.cpp">; |
Anna Zaks | e00575f | 2012-01-31 19:33:39 +0000 | [diff] [blame] | 336 | } |
| 337 | |
Ted Kremenek | 5188507 | 2011-03-24 00:28:47 +0000 | [diff] [blame] | 338 | //===----------------------------------------------------------------------===// |
| 339 | // Mac OS X, Cocoa, and Core Foundation checkers. |
| 340 | //===----------------------------------------------------------------------===// |
| 341 | |
| 342 | let ParentPackage = OSX in { |
| 343 | |
| 344 | def MacOSXAPIChecker : Checker<"API">, |
| 345 | InPackage<OSX>, |
| 346 | HelpText<"Check for proper uses of various Mac OS X APIs">, |
| 347 | DescFile<"MacOSXAPIChecker.cpp">; |
| 348 | |
| 349 | def OSAtomicChecker : Checker<"AtomicCAS">, |
| 350 | InPackage<OSX>, |
| 351 | HelpText<"Evaluate calls to OSAtomic functions">, |
| 352 | DescFile<"OSAtomicChecker.cpp">; |
| 353 | |
Anna Zaks | b1a1950 | 2011-08-16 20:02:05 +0000 | [diff] [blame] | 354 | def MacOSKeychainAPIChecker : Checker<"SecKeychainAPI">, |
| 355 | InPackage<OSX>, |
Anna Zaks | f57be28 | 2011-08-01 22:40:01 +0000 | [diff] [blame] | 356 | HelpText<"Check for proper uses of Secure Keychain APIs">, |
| 357 | DescFile<"MacOSKeychainAPIChecker.cpp">; |
| 358 | |
Anna Zaks | b1a1950 | 2011-08-16 20:02:05 +0000 | [diff] [blame] | 359 | } // end "macosx" |
Anna Zaks | f57be28 | 2011-08-01 22:40:01 +0000 | [diff] [blame] | 360 | |
Argyrios Kyrtzidis | 027a6ab | 2011-02-15 07:42:33 +0000 | [diff] [blame] | 361 | let ParentPackage = Cocoa in { |
Argyrios Kyrtzidis | 43dee22 | 2011-02-14 18:13:31 +0000 | [diff] [blame] | 362 | |
Argyrios Kyrtzidis | 26c05b1 | 2011-02-15 07:42:38 +0000 | [diff] [blame] | 363 | def ObjCAtSyncChecker : Checker<"AtSync">, |
Argyrios Kyrtzidis | 027a6ab | 2011-02-15 07:42:33 +0000 | [diff] [blame] | 364 | HelpText<"Check for null pointers used as mutexes for @synchronized">, |
| 365 | DescFile<"ObjCAtSyncChecker.cpp">; |
| 366 | |
Argyrios Kyrtzidis | 0b1ba62 | 2011-02-16 01:40:52 +0000 | [diff] [blame] | 367 | def NilArgChecker : Checker<"NilArg">, |
| 368 | HelpText<"Check for prohibited nil arguments to ObjC method calls">, |
| 369 | DescFile<"BasicObjCFoundationChecks.cpp">; |
| 370 | |
| 371 | def ClassReleaseChecker : Checker<"ClassRelease">, |
| 372 | HelpText<"Check for sending 'retain', 'release', or 'autorelease' directly to a Class">, |
| 373 | DescFile<"BasicObjCFoundationChecks.cpp">; |
| 374 | |
Anders Carlsson | 4597b7b | 2011-03-13 20:35:21 +0000 | [diff] [blame] | 375 | def VariadicMethodTypeChecker : Checker<"VariadicMethodTypes">, |
Anna Zaks | de2a6a8 | 2011-11-05 05:20:51 +0000 | [diff] [blame] | 376 | HelpText<"Check for passing non-Objective-C types to variadic methods that expect " |
Anders Carlsson | 4597b7b | 2011-03-13 20:35:21 +0000 | [diff] [blame] | 377 | "only Objective-C types">, |
| 378 | DescFile<"BasicObjCFoundationChecks.cpp">; |
| 379 | |
Ted Kremenek | b8d545c | 2011-02-25 22:19:14 +0000 | [diff] [blame] | 380 | def NSAutoreleasePoolChecker : Checker<"NSAutoreleasePool">, |
Ted Kremenek | 5188507 | 2011-03-24 00:28:47 +0000 | [diff] [blame] | 381 | HelpText<"Warn for suboptimal uses of NSAutoreleasePool in Objective-C GC mode">, |
Argyrios Kyrtzidis | 0b1ba62 | 2011-02-16 01:40:52 +0000 | [diff] [blame] | 382 | DescFile<"NSAutoreleasePoolChecker.cpp">; |
| 383 | |
Ted Kremenek | 5188507 | 2011-03-24 00:28:47 +0000 | [diff] [blame] | 384 | def ObjCMethSigsChecker : Checker<"IncompatibleMethodTypes">, |
Argyrios Kyrtzidis | 7dd445e | 2011-02-17 21:39:33 +0000 | [diff] [blame] | 385 | HelpText<"Warn about Objective-C method signatures with type incompatibilities">, |
| 386 | DescFile<"CheckObjCInstMethSignature.cpp">; |
| 387 | |
| 388 | def ObjCUnusedIvarsChecker : Checker<"UnusedIvars">, |
| 389 | HelpText<"Warn about private ivars that are never used">, |
| 390 | DescFile<"ObjCUnusedIVarsChecker.cpp">; |
Anna Zaks | 52a3888 | 2012-02-04 02:31:57 +0000 | [diff] [blame] | 391 | |
| 392 | def ObjCSelfInitChecker : Checker<"SelfInit">, |
| 393 | HelpText<"Check that 'self' is properly initialized inside an initializer method">, |
| 394 | DescFile<"ObjCSelfInitChecker.cpp">; |
| 395 | |
Argyrios Kyrtzidis | b3d74da | 2011-02-28 17:36:18 +0000 | [diff] [blame] | 396 | def NSErrorChecker : Checker<"NSError">, |
| 397 | HelpText<"Check usage of NSError** parameters">, |
| 398 | DescFile<"NSErrorChecker.cpp">; |
Argyrios Kyrtzidis | 7dd445e | 2011-02-17 21:39:33 +0000 | [diff] [blame] | 399 | |
Jordy Rose | 17a38e2 | 2011-09-02 05:55:19 +0000 | [diff] [blame] | 400 | def RetainCountChecker : Checker<"RetainCount">, |
| 401 | HelpText<"Check for leaks and improper reference count management">, |
| 402 | DescFile<"RetainCountChecker.cpp">; |
| 403 | |
Ted Kremenek | f5d2ef4 | 2011-02-25 22:00:43 +0000 | [diff] [blame] | 404 | } // end "cocoa" |
Argyrios Kyrtzidis | 027a6ab | 2011-02-15 07:42:33 +0000 | [diff] [blame] | 405 | |
Ted Kremenek | 5188507 | 2011-03-24 00:28:47 +0000 | [diff] [blame] | 406 | let ParentPackage = CocoaExperimental in { |
Argyrios Kyrtzidis | 1034870 | 2011-02-28 01:27:07 +0000 | [diff] [blame] | 407 | |
Ted Kremenek | 5188507 | 2011-03-24 00:28:47 +0000 | [diff] [blame] | 408 | def ObjCDeallocChecker : Checker<"Dealloc">, |
Ted Kremenek | 5188507 | 2011-03-24 00:28:47 +0000 | [diff] [blame] | 409 | HelpText<"Warn about Objective-C classes that lack a correct implementation of -dealloc">, |
| 410 | DescFile<"CheckObjCDealloc.cpp">; |
Argyrios Kyrtzidis | b3d74da | 2011-02-28 17:36:18 +0000 | [diff] [blame] | 411 | |
Ted Kremenek | 5188507 | 2011-03-24 00:28:47 +0000 | [diff] [blame] | 412 | } // end "cocoa.experimental" |
Argyrios Kyrtzidis | d84f422 | 2011-02-28 01:28:13 +0000 | [diff] [blame] | 413 | |
Ted Kremenek | 5188507 | 2011-03-24 00:28:47 +0000 | [diff] [blame] | 414 | let ParentPackage = CoreFoundation in { |
Argyrios Kyrtzidis | f029366 | 2011-02-28 01:27:02 +0000 | [diff] [blame] | 415 | |
Argyrios Kyrtzidis | 0b1ba62 | 2011-02-16 01:40:52 +0000 | [diff] [blame] | 416 | def CFNumberCreateChecker : Checker<"CFNumber">, |
Ted Kremenek | f5d2ef4 | 2011-02-25 22:00:43 +0000 | [diff] [blame] | 417 | HelpText<"Check for proper uses of CFNumberCreate">, |
Argyrios Kyrtzidis | 0b1ba62 | 2011-02-16 01:40:52 +0000 | [diff] [blame] | 418 | DescFile<"BasicObjCFoundationChecks.cpp">; |
| 419 | |
| 420 | def CFRetainReleaseChecker : Checker<"CFRetainRelease">, |
Argyrios Kyrtzidis | 0b1ba62 | 2011-02-16 01:40:52 +0000 | [diff] [blame] | 421 | HelpText<"Check for null arguments to CFRetain/CFRelease">, |
| 422 | DescFile<"BasicObjCFoundationChecks.cpp">; |
| 423 | |
Argyrios Kyrtzidis | b3d74da | 2011-02-28 17:36:18 +0000 | [diff] [blame] | 424 | def CFErrorChecker : Checker<"CFError">, |
Argyrios Kyrtzidis | b3d74da | 2011-02-28 17:36:18 +0000 | [diff] [blame] | 425 | HelpText<"Check usage of CFErrorRef* parameters">, |
| 426 | DescFile<"NSErrorChecker.cpp">; |
Ted Kremenek | 5188507 | 2011-03-24 00:28:47 +0000 | [diff] [blame] | 427 | } |
| 428 | |
Anna Zaks | 7fc8003 | 2012-01-30 21:14:16 +0000 | [diff] [blame] | 429 | let ParentPackage = Containers in { |
| 430 | def ObjCContainersASTChecker : Checker<"PointerSizedValues">, |
| 431 | HelpText<"Warns if 'CFArray', 'CFDictionary', 'CFSet' are created with non-pointer-size values">, |
Anna Zaks | 52a3888 | 2012-02-04 02:31:57 +0000 | [diff] [blame] | 432 | DescFile<"ObjCContainersASTChecker.cpp">; |
| 433 | |
| 434 | def ObjCContainersChecker : Checker<"OutOfBounds">, |
Anna Zaks | 5730076 | 2012-02-07 00:56:14 +0000 | [diff] [blame] | 435 | HelpText<"Checks for index out-of-bounds when using 'CFArray' API">, |
Anna Zaks | 52a3888 | 2012-02-04 02:31:57 +0000 | [diff] [blame] | 436 | DescFile<"ObjCContainersChecker.cpp">; |
| 437 | |
Anna Zaks | 7fc8003 | 2012-01-30 21:14:16 +0000 | [diff] [blame] | 438 | } |
Ted Kremenek | 5188507 | 2011-03-24 00:28:47 +0000 | [diff] [blame] | 439 | //===----------------------------------------------------------------------===// |
| 440 | // Checkers for LLVM development. |
| 441 | //===----------------------------------------------------------------------===// |
Argyrios Kyrtzidis | b3d74da | 2011-02-28 17:36:18 +0000 | [diff] [blame] | 442 | |
Argyrios Kyrtzidis | 9fb9474 | 2011-02-17 21:39:24 +0000 | [diff] [blame] | 443 | def LLVMConventionsChecker : Checker<"Conventions">, |
| 444 | InPackage<LLVM>, |
| 445 | HelpText<"Check code for LLVM codebase conventions">, |
| 446 | DescFile<"LLVMConventionsChecker.cpp">; |
| 447 | |
Ted Kremenek | 5188507 | 2011-03-24 00:28:47 +0000 | [diff] [blame] | 448 | //===----------------------------------------------------------------------===// |
| 449 | // Debugging checkers (for analyzer development). |
| 450 | //===----------------------------------------------------------------------===// |
| 451 | |
| 452 | let ParentPackage = Debug in { |
| 453 | |
Ted Kremenek | 58f6f1e | 2011-10-25 00:25:24 +0000 | [diff] [blame] | 454 | def DominatorsTreeDumper : Checker<"DumpDominators">, |
| 455 | HelpText<"Print the dominance tree for a given CFG">, |
| 456 | DescFile<"DebugCheckers.cpp">; |
| 457 | |
Argyrios Kyrtzidis | 2d67b90 | 2011-02-17 21:39:39 +0000 | [diff] [blame] | 458 | def LiveVariablesDumper : Checker<"DumpLiveVars">, |
Argyrios Kyrtzidis | 2d67b90 | 2011-02-17 21:39:39 +0000 | [diff] [blame] | 459 | HelpText<"Print results of live variable analysis">, |
| 460 | DescFile<"DebugCheckers.cpp">; |
| 461 | |
| 462 | def CFGViewer : Checker<"ViewCFG">, |
Argyrios Kyrtzidis | 2d67b90 | 2011-02-17 21:39:39 +0000 | [diff] [blame] | 463 | HelpText<"View Control-Flow Graphs using GraphViz">, |
| 464 | DescFile<"DebugCheckers.cpp">; |
| 465 | |
| 466 | def CFGDumper : Checker<"DumpCFG">, |
Argyrios Kyrtzidis | 2d67b90 | 2011-02-17 21:39:39 +0000 | [diff] [blame] | 467 | HelpText<"Display Control-Flow Graphs">, |
| 468 | DescFile<"DebugCheckers.cpp">; |
| 469 | |
Anna Zaks | 196b8cf | 2012-03-08 00:42:23 +0000 | [diff] [blame] | 470 | def CallGraphViewer : Checker<"ViewCallGraph">, |
| 471 | HelpText<"View Call Graph using GraphViz">, |
| 472 | DescFile<"DebugCheckers.cpp">; |
| 473 | |
| 474 | def CallGraphDumper : Checker<"DumpCallGraph">, |
| 475 | HelpText<"Display Call Graph">, |
| 476 | DescFile<"DebugCheckers.cpp">; |
| 477 | |
Argyrios Kyrtzidis | 58f2e7c | 2011-02-28 01:26:50 +0000 | [diff] [blame] | 478 | def AnalyzerStatsChecker : Checker<"Stats">, |
Argyrios Kyrtzidis | 58f2e7c | 2011-02-28 01:26:50 +0000 | [diff] [blame] | 479 | HelpText<"Emit warnings with analyzer statistics">, |
| 480 | DescFile<"AnalyzerStatsChecker.cpp">; |
| 481 | |
Anna Zaks | a50b7ab | 2011-12-05 18:58:01 +0000 | [diff] [blame] | 482 | def TaintTesterChecker : Checker<"TaintTest">, |
| 483 | HelpText<"Mark tainted symbols as such.">, |
| 484 | DescFile<"TaintTesterChecker.cpp">; |
| 485 | |
Ted Kremenek | 5188507 | 2011-03-24 00:28:47 +0000 | [diff] [blame] | 486 | } // end "debug" |
Argyrios Kyrtzidis | a0decc9 | 2011-02-15 21:25:03 +0000 | [diff] [blame] | 487 | |