Skip to content

Commit aef2dbb

Browse files
committed
Merge bitcoin/bitcoin#33099: ci: allow for any libc++ intrumentation & use it for TSAN
7aa5b67 ci: remove DEBUG_LOCKORDER from TSAN job (fanquake) b09af2c ci: instrument libc++ in TSAN job (fanquake) 6653caf ci: allow libc++ instrumentation other than msan (fanquake) Pull request description: Allow for instrumenting libc++ with a sanitizer other than MemoryWithOrigins. Would also close #33087, as with the extra instrumentation, the issue from bitcoin/bitcoin#32862 (comment) is avoided (also see bitcoin/bitcoin#33081), and we can drop `DEBUG_LOCKORDER`. ACKs for top commit: maflcko: re-ACK 7aa5b67 🦀 dergoegge: utACK 7aa5b67 Tree-SHA512: 95f123e37da5e81d571244e4b1cd7658107676f1ea763ff16e5b69f4dfadb88236a577bb2ee52230ff542872c1da151c88fc50aba0f32540e765080120cec55e
2 parents 8283af1 + 7aa5b67 commit aef2dbb

File tree

5 files changed

+27
-24
lines changed

5 files changed

+27
-24
lines changed

.cirrus.yml

Lines changed: 1 addition & 1 deletion
Original file line numberDiff line numberDiff line change
@@ -143,7 +143,7 @@ task:
143143
FILE_ENV: "./ci/test/00_setup_env_native_previous_releases.sh"
144144

145145
task:
146-
name: 'TSan, depends, gui'
146+
name: 'TSan, depends, no gui'
147147
<< : *GLOBAL_TASK_TEMPLATE
148148
persistent_worker:
149149
labels:

ci/test/00_setup_env_native_fuzz_with_msan.sh

Lines changed: 2 additions & 2 deletions
Original file line numberDiff line numberDiff line change
@@ -7,7 +7,7 @@
77
export LC_ALL=C.UTF-8
88

99
export CI_IMAGE_NAME_TAG="mirror.gcr.io/ubuntu:24.04"
10-
LIBCXX_DIR="/msan/cxx_build/"
10+
LIBCXX_DIR="/cxx_build/"
1111
export MSAN_FLAGS="-fsanitize=memory -fsanitize-memory-track-origins=2 -fno-omit-frame-pointer -g -O1 -fno-optimize-sibling-calls"
1212
LIBCXX_FLAGS="-nostdinc++ -nostdlib++ -isystem ${LIBCXX_DIR}include/c++/v1 -L${LIBCXX_DIR}lib -Wl,-rpath,${LIBCXX_DIR}lib -lc++ -lc++abi -lpthread -Wno-unused-command-line-argument"
1313
export MSAN_AND_LIBCXX_FLAGS="${MSAN_FLAGS} ${LIBCXX_FLAGS}"
@@ -25,7 +25,7 @@ export BITCOIN_CONFIG="\
2525
-DSANITIZERS=fuzzer,memory \
2626
-DAPPEND_CPPFLAGS='-DBOOST_MULTI_INDEX_ENABLE_SAFE_MODE -U_FORTIFY_SOURCE' \
2727
"
28-
export USE_MEMORY_SANITIZER="true"
28+
export USE_INSTRUMENTED_LIBCPP="MemoryWithOrigins"
2929
export RUN_UNIT_TESTS="false"
3030
export RUN_FUNCTIONAL_TESTS="false"
3131
export RUN_FUZZ_TESTS=true

ci/test/00_setup_env_native_msan.sh

Lines changed: 2 additions & 2 deletions
Original file line numberDiff line numberDiff line change
@@ -8,7 +8,7 @@ export LC_ALL=C.UTF-8
88

99
export CI_IMAGE_NAME_TAG="mirror.gcr.io/ubuntu:24.04"
1010
export APT_LLVM_V="20"
11-
LIBCXX_DIR="/msan/cxx_build/"
11+
LIBCXX_DIR="/cxx_build/"
1212
export MSAN_FLAGS="-fsanitize=memory -fsanitize-memory-track-origins=2 -fno-omit-frame-pointer -g -O1 -fno-optimize-sibling-calls"
1313
LIBCXX_FLAGS="-nostdinc++ -nostdlib++ -isystem ${LIBCXX_DIR}include/c++/v1 -L${LIBCXX_DIR}lib -Wl,-rpath,${LIBCXX_DIR}lib -lc++ -lc++abi -lpthread -Wno-unused-command-line-argument"
1414
export MSAN_AND_LIBCXX_FLAGS="${MSAN_FLAGS} ${LIBCXX_FLAGS}"
@@ -27,4 +27,4 @@ export BITCOIN_CONFIG="\
2727
-DSANITIZERS=memory \
2828
-DAPPEND_CPPFLAGS='-U_FORTIFY_SOURCE' \
2929
"
30-
export USE_MEMORY_SANITIZER="true"
30+
export USE_INSTRUMENTED_LIBCPP="MemoryWithOrigins"

ci/test/00_setup_env_native_tsan.sh

Lines changed: 6 additions & 3 deletions
Original file line numberDiff line numberDiff line change
@@ -9,9 +9,12 @@ export LC_ALL=C.UTF-8
99
export CONTAINER_NAME=ci_native_tsan
1010
export CI_IMAGE_NAME_TAG="mirror.gcr.io/ubuntu:24.04"
1111
export APT_LLVM_V="20"
12-
export PACKAGES="clang-${APT_LLVM_V} llvm-${APT_LLVM_V} libclang-rt-${APT_LLVM_V}-dev libc++abi-${APT_LLVM_V}-dev libc++-${APT_LLVM_V}-dev python3-zmq"
13-
export DEP_OPTS="CC=clang CXX='clang++ -stdlib=libc++'"
12+
LIBCXX_DIR="/cxx_build/"
13+
LIBCXX_FLAGS="-fsanitize=thread -nostdinc++ -nostdlib++ -isystem ${LIBCXX_DIR}include/c++/v1 -L${LIBCXX_DIR}lib -Wl,-rpath,${LIBCXX_DIR}lib -lc++ -lc++abi -lpthread -Wno-unused-command-line-argument"
14+
export PACKAGES="clang-${APT_LLVM_V} llvm-${APT_LLVM_V} llvm-${APT_LLVM_V}-dev libclang-${APT_LLVM_V}-dev libclang-rt-${APT_LLVM_V}-dev python3-zmq"
15+
export DEP_OPTS="CC=clang CXX=clang++ CXXFLAGS='${LIBCXX_FLAGS}' NO_QT=1"
1416
export GOAL="install"
1517
export CI_LIMIT_STACK_SIZE=1
1618
export BITCOIN_CONFIG="-DWITH_ZMQ=ON -DSANITIZERS=thread \
17-
-DAPPEND_CPPFLAGS='-DARENA_DEBUG -DDEBUG_LOCKORDER -DDEBUG_LOCKCONTENTION -D_LIBCPP_REMOVE_TRANSITIVE_INCLUDES'"
19+
-DAPPEND_CPPFLAGS='-DARENA_DEBUG -DDEBUG_LOCKCONTENTION -D_LIBCPP_REMOVE_TRANSITIVE_INCLUDES'"
20+
export USE_INSTRUMENTED_LIBCPP="Thread"

ci/test/01_base_install.sh

Lines changed: 16 additions & 16 deletions
Original file line numberDiff line numberDiff line change
@@ -55,45 +55,45 @@ if [ -n "$PIP_PACKAGES" ]; then
5555
${CI_RETRY_EXE} pip3 install --user $PIP_PACKAGES
5656
fi
5757

58-
if [[ ${USE_MEMORY_SANITIZER} == "true" ]]; then
58+
if [[ -n "${USE_INSTRUMENTED_LIBCPP}" ]]; then
5959
if [ -n "${APT_LLVM_V}" ]; then
60-
${CI_RETRY_EXE} git clone --depth=1 https://github.com/llvm/llvm-project -b "llvmorg-$( clang --version | sed --silent 's@.*clang version \([0-9.]*\).*@\1@p' )" /msan/llvm-project
60+
${CI_RETRY_EXE} git clone --depth=1 https://github.com/llvm/llvm-project -b "llvmorg-$( clang --version | sed --silent 's@.*clang version \([0-9.]*\).*@\1@p' )" /llvm-project
6161
else
62-
${CI_RETRY_EXE} git clone --depth=1 https://github.com/llvm/llvm-project -b "llvmorg-20.1.8" /msan/llvm-project
62+
${CI_RETRY_EXE} git clone --depth=1 https://github.com/llvm/llvm-project -b "llvmorg-20.1.8" /llvm-project
6363

64-
cmake -G Ninja -B /msan/clang_build/ \
64+
cmake -G Ninja -B /clang_build/ \
6565
-DLLVM_ENABLE_PROJECTS="clang" \
6666
-DCMAKE_BUILD_TYPE=Release \
6767
-DLLVM_TARGETS_TO_BUILD=Native \
6868
-DLLVM_ENABLE_RUNTIMES="compiler-rt;libcxx;libcxxabi;libunwind" \
69-
-S /msan/llvm-project/llvm
69+
-S /llvm-project/llvm
7070

71-
ninja -C /msan/clang_build/ "$MAKEJOBS"
72-
ninja -C /msan/clang_build/ install-runtimes
71+
ninja -C /clang_build/ "$MAKEJOBS"
72+
ninja -C /clang_build/ install-runtimes
7373

74-
update-alternatives --install /usr/bin/clang++ clang++ /msan/clang_build/bin/clang++ 100
75-
update-alternatives --install /usr/bin/clang clang /msan/clang_build/bin/clang 100
76-
update-alternatives --install /usr/bin/llvm-symbolizer llvm-symbolizer /msan/clang_build/bin/llvm-symbolizer 100
74+
update-alternatives --install /usr/bin/clang++ clang++ /clang_build/bin/clang++ 100
75+
update-alternatives --install /usr/bin/clang clang /clang_build/bin/clang 100
76+
update-alternatives --install /usr/bin/llvm-symbolizer llvm-symbolizer /clang_build/bin/llvm-symbolizer 100
7777
fi
7878

79-
cmake -G Ninja -B /msan/cxx_build/ \
79+
cmake -G Ninja -B /cxx_build/ \
8080
-DLLVM_ENABLE_RUNTIMES="libcxx;libcxxabi;libunwind" \
8181
-DCMAKE_BUILD_TYPE=Release \
82-
-DLLVM_USE_SANITIZER=MemoryWithOrigins \
82+
-DLLVM_USE_SANITIZER="${USE_INSTRUMENTED_LIBCPP}" \
8383
-DCMAKE_C_COMPILER=clang \
8484
-DCMAKE_CXX_COMPILER=clang++ \
8585
-DLLVM_TARGETS_TO_BUILD=Native \
8686
-DLLVM_ENABLE_PER_TARGET_RUNTIME_DIR=OFF \
8787
-DLIBCXXABI_USE_LLVM_UNWINDER=OFF \
8888
-DLIBCXX_ABI_DEFINES="_LIBCPP_ABI_BOUNDED_ITERATORS;_LIBCPP_ABI_BOUNDED_ITERATORS_IN_STD_ARRAY;_LIBCPP_ABI_BOUNDED_ITERATORS_IN_STRING;_LIBCPP_ABI_BOUNDED_ITERATORS_IN_VECTOR;_LIBCPP_ABI_BOUNDED_UNIQUE_PTR" \
8989
-DLIBCXX_HARDENING_MODE=debug \
90-
-S /msan/llvm-project/runtimes
90+
-S /llvm-project/runtimes
9191

92-
ninja -C /msan/cxx_build/ "$MAKEJOBS"
92+
ninja -C /cxx_build/ "$MAKEJOBS"
9393

9494
# Clear no longer needed source folder
95-
du -sh /msan/llvm-project
96-
rm -rf /msan/llvm-project
95+
du -sh /llvm-project
96+
rm -rf /llvm-project
9797
fi
9898

9999
if [[ "${RUN_TIDY}" == "true" ]]; then

0 commit comments

Comments
 (0)