From: Kefu Chai Date: Sun, 17 Mar 2024 10:42:44 +0000 (+0800) Subject: script/run-make: enable ASan X-Git-Url: http://git-server-git.apps.pok.os.sepia.ceph.com/?a=commitdiff_plain;h=8ac962c698df959da1866d41b04d69c806bb72c0;p=ceph.git script/run-make: enable ASan when performing tests, we should enable sanitizers for detecting potential issues. so, in this change, we enable ASsan, TSan and UBSan. script/run-make.sh is used by our CI job for testing PRs, so enabling these sanitizers helps us to identify issues as early as possible. because ASan cannot be used along with TSan, we prefer using ASan for capturing memory related issue in favor of detecting the multi-threading issues. also, because of https://bugs.llvm.org/show_bug.cgi?id=23272, we cannot enable multiple sanitizers. but we should enable UBSan as well, once we can use a higher version of Clang than Clang-14. with Clang-14, when enabling UBSan, we'd have following FTBFS ``` error: Cannot represent a difference across sections ``` when compiling `src/tools/neorados.cc` Signed-off-by: Kefu Chai --- diff --git a/src/script/run-make.sh b/src/script/run-make.sh index 30ca35ce274..e990a827de5 100755 --- a/src/script/run-make.sh +++ b/src/script/run-make.sh @@ -143,6 +143,7 @@ EOM local cxx_compiler="${discovered_cxx_compiler}" local c_compiler="${discovered_c_compiler}" local cmake_opts + cmake_opts+=" -DWITH_ASAN=ON" cmake_opts+=" -DCMAKE_CXX_COMPILER=$cxx_compiler -DCMAKE_C_COMPILER=$c_compiler" cmake_opts+=" -DENABLE_GIT_VERSION=OFF" cmake_opts+=" -DWITH_GTEST_PARALLEL=ON"