mirror of
https://github.com/google/benchmark.git
synced 2025-01-13 21:30:14 +08:00
Fix ICC compiler warnings (#358)
fixes #354 The build fails with ICC17 because of warnings and Werror. What is the correct solution to fix it? Should a patch disable Werror for ICC (or maybe all non known compilers) disable the false postive warnings for all files. This could be done using: add_cxx_compiler_flag(-wd2102) #ICC17u2: Many false positives for Wstrict-aliasing add_cxx_compiler_flag(-wd2259) #ICC17u2: non-pointer conversion from "long" to "int" may lose significant bits (even for explicit static cast, sleep.cc(44)) add_cxx_compiler_flag(-wd654) #ICC17u2: overloaded virtual function "benchmark::Fixture::SetUp" is only partially overridden (because of deprecated overload) disable warnings at file level or some other granularity
This commit is contained in:
parent
f5ff6d0e0d
commit
9b92ed76a8
@ -92,8 +92,13 @@ else()
|
|||||||
add_cxx_compiler_flag(-Wzero-as-null-pointer-constant)
|
add_cxx_compiler_flag(-Wzero-as-null-pointer-constant)
|
||||||
endif()
|
endif()
|
||||||
if (HAVE_CXX_FLAG_FSTRICT_ALIASING)
|
if (HAVE_CXX_FLAG_FSTRICT_ALIASING)
|
||||||
add_cxx_compiler_flag(-Wstrict-aliasing)
|
if (NOT CMAKE_CXX_COMPILER_ID STREQUAL "Intel") #ICC17u2: Many false positives for Wstrict-aliasing
|
||||||
|
add_cxx_compiler_flag(-Wstrict-aliasing)
|
||||||
|
endif()
|
||||||
endif()
|
endif()
|
||||||
|
# ICC17u2: overloaded virtual function "benchmark::Fixture::SetUp" is only partially overridden
|
||||||
|
# (because of deprecated overload)
|
||||||
|
add_cxx_compiler_flag(-wd654)
|
||||||
add_cxx_compiler_flag(-Wthread-safety)
|
add_cxx_compiler_flag(-Wthread-safety)
|
||||||
if (HAVE_CXX_FLAG_WTHREAD_SAFETY)
|
if (HAVE_CXX_FLAG_WTHREAD_SAFETY)
|
||||||
cxx_feature_check(THREAD_SAFETY_ATTRIBUTES)
|
cxx_feature_check(THREAD_SAFETY_ATTRIBUTES)
|
||||||
|
@ -643,6 +643,7 @@ The following minimum versions are strongly recommended build the library:
|
|||||||
* GCC 4.8
|
* GCC 4.8
|
||||||
* Clang 3.4
|
* Clang 3.4
|
||||||
* Visual Studio 2013
|
* Visual Studio 2013
|
||||||
|
* Intel 2015 Update 1
|
||||||
|
|
||||||
Anything older *may* work.
|
Anything older *may* work.
|
||||||
|
|
||||||
|
@ -150,7 +150,7 @@ static void BM_LongTest(benchmark::State& state) {
|
|||||||
BENCHMARK(BM_LongTest)->Range(1 << 16, 1 << 28);
|
BENCHMARK(BM_LongTest)->Range(1 << 16, 1 << 28);
|
||||||
|
|
||||||
static void BM_ParallelMemset(benchmark::State& state) {
|
static void BM_ParallelMemset(benchmark::State& state) {
|
||||||
int size = state.range(0) / sizeof(int);
|
int size = state.range(0) / static_cast<int>(sizeof(int));
|
||||||
int thread_size = size / state.threads;
|
int thread_size = size / state.threads;
|
||||||
int from = thread_size * state.thread_index;
|
int from = thread_size * state.thread_index;
|
||||||
int to = from + thread_size;
|
int to = from + thread_size;
|
||||||
|
@ -31,7 +31,7 @@ TestCaseList& GetTestCaseList(TestCaseID ID) {
|
|||||||
|
|
||||||
SubMap& GetSubstitutions() {
|
SubMap& GetSubstitutions() {
|
||||||
// Don't use 'dec_re' from header because it may not yet be initialized.
|
// Don't use 'dec_re' from header because it may not yet be initialized.
|
||||||
static std::string dec_re = "[0-9]*[.]?[0-9]+([eE][-+][0-9]+)?";
|
static std::string safe_dec_re = "[0-9]*[.]?[0-9]+([eE][-+][0-9]+)?";
|
||||||
static SubMap map = {
|
static SubMap map = {
|
||||||
{"%float", "[0-9]*[.]?[0-9]+([eE][-+][0-9]+)?"},
|
{"%float", "[0-9]*[.]?[0-9]+([eE][-+][0-9]+)?"},
|
||||||
{"%int", "[ ]*[0-9]+"},
|
{"%int", "[ ]*[0-9]+"},
|
||||||
@ -39,13 +39,13 @@ SubMap& GetSubstitutions() {
|
|||||||
{"%time", "[ ]*[0-9]{1,5} ns"},
|
{"%time", "[ ]*[0-9]{1,5} ns"},
|
||||||
{"%console_report", "[ ]*[0-9]{1,5} ns [ ]*[0-9]{1,5} ns [ ]*[0-9]+"},
|
{"%console_report", "[ ]*[0-9]{1,5} ns [ ]*[0-9]{1,5} ns [ ]*[0-9]+"},
|
||||||
{"%console_us_report", "[ ]*[0-9] us [ ]*[0-9] us [ ]*[0-9]+"},
|
{"%console_us_report", "[ ]*[0-9] us [ ]*[0-9] us [ ]*[0-9]+"},
|
||||||
{"%csv_report", "[0-9]+," + dec_re + "," + dec_re + ",ns,,,,,"},
|
{"%csv_report", "[0-9]+," + safe_dec_re + "," + safe_dec_re + ",ns,,,,,"},
|
||||||
{"%csv_us_report", "[0-9]+," + dec_re + "," + dec_re + ",us,,,,,"},
|
{"%csv_us_report", "[0-9]+," + safe_dec_re + "," + safe_dec_re + ",us,,,,,"},
|
||||||
{"%csv_bytes_report",
|
{"%csv_bytes_report",
|
||||||
"[0-9]+," + dec_re + "," + dec_re + ",ns," + dec_re + ",,,,"},
|
"[0-9]+," + safe_dec_re + "," + safe_dec_re + ",ns," + safe_dec_re + ",,,,"},
|
||||||
{"%csv_items_report",
|
{"%csv_items_report",
|
||||||
"[0-9]+," + dec_re + "," + dec_re + ",ns,," + dec_re + ",,,"},
|
"[0-9]+," + safe_dec_re + "," + safe_dec_re + ",ns,," + safe_dec_re + ",,,"},
|
||||||
{"%csv_label_report_begin", "[0-9]+," + dec_re + "," + dec_re + ",ns,,,"},
|
{"%csv_label_report_begin", "[0-9]+," + safe_dec_re + "," + safe_dec_re + ",ns,,,"},
|
||||||
{"%csv_label_report_end", ",,"}};
|
{"%csv_label_report_end", ",,"}};
|
||||||
return map;
|
return map;
|
||||||
}
|
}
|
||||||
|
Loading…
Reference in New Issue
Block a user