Skip to content

Commit 6653caf

Browse files
committed
ci: allow libc++ instrumentation other than msan
1 parent 3fe3fdb commit 6653caf

File tree

3 files changed

+20
-20
lines changed

3 files changed

+20
-20
lines changed

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}"
@@ -26,7 +26,7 @@ export BITCOIN_CONFIG="\
2626
-DSANITIZERS=fuzzer,memory \
2727
-DAPPEND_CPPFLAGS='-DBOOST_MULTI_INDEX_ENABLE_SAFE_MODE -U_FORTIFY_SOURCE' \
2828
"
29-
export USE_MEMORY_SANITIZER="true"
29+
export USE_INSTRUMENTED_LIBCPP="MemoryWithOrigins"
3030
export RUN_UNIT_TESTS="false"
3131
export RUN_FUNCTIONAL_TESTS="false"
3232
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/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)