C checkers |
CERT C Secure Coding Standard |
ARRAY_VS_SINGLETON |
VOID Do not allow loops to iterate beyond the end of an array |
ASSERT_SIDE_EFFECT |
EXP31-C. Avoid side effects in assertions |
ASSERT_SIDE_EFFECT |
MSC11-C. Incorporate diagnostic tests using assertions |
BAD_COMPARE |
MSC02-C. Avoid errors of omission |
BAD_ALLOC_STRLEN |
MEM35-C. Allocate sufficient memory for an object |
BAD_COMPARE |
MSC02-C. Avoid errors of omission |
BAD_FREE |
MEM34-C. Only free memory allocated dynamically |
CHAR_IO |
FIO34-C. Use int to capture the return value of character IO functions |
CHECKED_RETURN |
FIO33-C. Detect and handle input output errors resulting in undefined behavior |
CHECKED_RETURN |
FIO04-C. Detect and handle input and output errors |
CHECKED_RETURN |
EXP12-C. Do not ignore values returned by functions |
CHECKED_RETURN |
MEM32-C. Detect and handle memory allocation errors |
CONSTANT_EXPRESSION_RESULT |
EXP17-C. Do not perform bitwise operations in conditional expressions |
DEADCODE |
MSC07-C. Detect and remove dead code |
EVALUATION_ORDER |
EXP10-C. Do not depend on the order of evaluation of subexpressions or the order in which side effects take place |
EVALUATION_ORDER |
EXP30-C. Do not depend on order of evaluation between sequence points |
FORWARD_NULL |
EXP34-C. Do not dereference null pointers |
INFINITE_LOOP |
VOID Beware of infinite loops |
MISRA_CAST |
INT31-C. Ensure that integer conversions do not result in lost or misinterpreted data |
MISRA_CAST |
FLP34-C. Ensure that floating point conversions are within range of the new type |
MISSING_BREAK |
MSC17-C. Finish every set of statements associated with a case label with a break statement |
MISSING_RETURN |
MSC02-C. Avoid errors of omission |
NEGATIVE_RETURNS |
INT31-C. Ensure that integer conversions do not result in lost or misinterpreted data |
NEGATIVE_RETURNS |
VOID Guarantee that array indices are within the valid range |
NEGATIVE_RETURNS |
ARR32-C. Ensure size arguments for variable length arrays are in a valid range |
NEGATIVE_RETURNS |
VOID Do not allow loops to iterate beyond the end of an array |
NO_EFFECT |
MSC12-C. Detect and remove code that has no effect |
NULL_RETURNS |
EXP34-C. Do not dereference null pointers |
OVERRUN_DYNAMIC |
VOID Do not allow loops to iterate beyond the end of an array |
OVERRUN_DYNAMIC |
STR35-C. Do not copy data from an unbounded source to a fixed-length array |
OVERRUN_STATIC |
VOID Do not allow loops to iterate beyond the end of an array |
OVERRUN_STATIC |
STR35-C. Do not copy data from an unbounded source to a fixed-length array |
RESOURCE_LEAK |
MEM31-C. Free dynamically allocated memory exactly once |
RETURN_LOCAL |
DCL30-C. Declare objects with appropriate storage durations |
REVERSE_INULL |
EXP34-C. Do not dereference null pointers |
REVERSE_NEGATIVE |
ARR32-C. Ensure size arguments for variable length arrays are in a valid range |
REVERSE_NEGATIVE |
INT31-C. Ensure that integer conversions do not result in lost or misinterpreted data |
STACK_USE |
MEM05-C. Avoid large stack allocations |
SIZECHECK |
MEM35-C. Allocate sufficient memory for an object |
UNINIT |
EXP33-C. Do not reference uninitialized memory |
UNUSED_VALUE |
MSC13-C. Detect and remove unused values |
USE_AFTER_FREE |
MEM00-C. Allocate and free memory in the same module, at the same level of abstraction |
USE_AFTER_FREE |
MEM01-C. Store a new value in pointers immediately after free() |
USE_AFTER_FREE |
MEM30-C. Do not access freed memory |
USE_AFTER_FREE |
MEM31-C. Free dynamically allocated memory exactly once |
VARARGS |
No equivalent |