[Analyzer] Fix for incorrect use of container and iterator checkers

Iterator checkers (and planned container checkers) need the option
aggressive-binary-operation-simplification to be enabled. Without this
option they may cause assertions. To prevent such misuse, this patch adds
a preventive check which issues a warning and denies the registartion of
the checker if this option is disabled.

Differential Revision: https://reviews.llvm.org/D75171
This commit is contained in:
Adam Balogh 2020-03-05 20:09:15 +01:00
parent c9eaed5149
commit afcb77cc88
5 changed files with 36 additions and 1 deletions

View File

@ -344,6 +344,8 @@ def err_analyzer_checker_option_unknown : Error<
"checker '%0' has no option called '%1'">;
def err_analyzer_checker_option_invalid_input : Error<
"invalid input for checker option '%0', that expects %1">;
def err_analyzer_checker_incompatible_analyzer_option : Error<
"checker cannot be enabled with analyzer option '%0' == %1">;
def err_drv_invalid_hvx_length : Error<
"-mhvx-length is not supported without a -mhvx/-mhvx= flag">;

View File

@ -12,6 +12,7 @@
#include "clang/StaticAnalyzer/Checkers/BuiltinCheckerRegistration.h"
#include "clang/AST/DeclTemplate.h"
#include "clang/Driver/DriverDiagnostic.h"
#include "clang/StaticAnalyzer/Core/BugReporter/BugType.h"
#include "clang/StaticAnalyzer/Core/Checker.h"
#include "clang/StaticAnalyzer/Core/PathSensitive/CallEvent.h"
@ -1068,5 +1069,15 @@ void ento::registerContainerModeling(CheckerManager &mgr) {
}
bool ento::shouldRegisterContainerModeling(const CheckerManager &mgr) {
if (!mgr.getLangOpts().CPlusPlus)
return false;
if (!mgr.getAnalyzerOptions().ShouldAggressivelySimplifyBinaryOperation) {
mgr.getASTContext().getDiagnostics().Report(
diag::err_analyzer_checker_incompatible_analyzer_option)
<< "aggressive-binary-operation-simplification" << "false";
return false;
}
return true;
}

View File

@ -0,0 +1,7 @@
// RUN: %clang_analyze_cc1 -std=c++11\
// RUN: -analyzer-checker=core,cplusplus,alpha.cplusplus.ContainerModeling\
// RUN: %s 2>&1 | FileCheck %s
// XFAIL: *
// CHECK: checker cannot be enabled with analyzer option 'aggressive-binary-operation-simplification' == false

View File

@ -0,0 +1,15 @@
// RUN: %clang_analyze_cc1 -std=c++11\
// RUN: -analyzer-checker=core,cplusplus,debug.DebugIteratorModeling,debug.ExprInspection\
// RUN: %s 2>&1 | FileCheck %s
// XFAIL: *
// CHECK: checker cannot be enabled with analyzer option 'aggressive-binary-operation-simplification' == false
#include "Inputs/system-header-simulator-cxx.h"
void clang_analyzer_eval(bool);
void comparison(std::vector<int> &V) {
clang_analyzer_eval(V.begin() == V.end()); // no-crash
}

View File

@ -1,4 +1,4 @@
// RUN: %clang_analyze_cc1 -analyzer-checker=core,alpha -analyzer-max-loop 2 -analyzer-config widen-loops=true -analyzer-output=text -verify -analyzer-config eagerly-assume=false %s
// RUN: %clang_analyze_cc1 -analyzer-checker=core,alpha.core -analyzer-max-loop 2 -analyzer-config widen-loops=true -analyzer-output=text -verify -analyzer-config eagerly-assume=false %s
int *p_a;
int bar();