mirror of
https://github.com/capstone-engine/llvm-capstone.git
synced 2025-04-03 05:32:24 +00:00
[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:
parent
c9eaed5149
commit
afcb77cc88
@ -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">;
|
||||
|
@ -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;
|
||||
}
|
||||
|
@ -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
|
@ -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
|
||||
}
|
@ -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();
|
||||
|
Loading…
x
Reference in New Issue
Block a user