mirror of
https://github.com/bitcoin/bitcoin.git
synced 2025-08-29 00:09:58 +02:00
ci: allow libc++ instrumentation other than msan
This commit is contained in:
@@ -7,7 +7,7 @@
|
|||||||
export LC_ALL=C.UTF-8
|
export LC_ALL=C.UTF-8
|
||||||
|
|
||||||
export CI_IMAGE_NAME_TAG="mirror.gcr.io/ubuntu:24.04"
|
export CI_IMAGE_NAME_TAG="mirror.gcr.io/ubuntu:24.04"
|
||||||
LIBCXX_DIR="/msan/cxx_build/"
|
LIBCXX_DIR="/cxx_build/"
|
||||||
export MSAN_FLAGS="-fsanitize=memory -fsanitize-memory-track-origins=2 -fno-omit-frame-pointer -g -O1 -fno-optimize-sibling-calls"
|
export MSAN_FLAGS="-fsanitize=memory -fsanitize-memory-track-origins=2 -fno-omit-frame-pointer -g -O1 -fno-optimize-sibling-calls"
|
||||||
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"
|
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"
|
||||||
export MSAN_AND_LIBCXX_FLAGS="${MSAN_FLAGS} ${LIBCXX_FLAGS}"
|
export MSAN_AND_LIBCXX_FLAGS="${MSAN_FLAGS} ${LIBCXX_FLAGS}"
|
||||||
@@ -26,7 +26,7 @@ export BITCOIN_CONFIG="\
|
|||||||
-DSANITIZERS=fuzzer,memory \
|
-DSANITIZERS=fuzzer,memory \
|
||||||
-DAPPEND_CPPFLAGS='-DBOOST_MULTI_INDEX_ENABLE_SAFE_MODE -U_FORTIFY_SOURCE' \
|
-DAPPEND_CPPFLAGS='-DBOOST_MULTI_INDEX_ENABLE_SAFE_MODE -U_FORTIFY_SOURCE' \
|
||||||
"
|
"
|
||||||
export USE_MEMORY_SANITIZER="true"
|
export USE_INSTRUMENTED_LIBCPP="MemoryWithOrigins"
|
||||||
export RUN_UNIT_TESTS="false"
|
export RUN_UNIT_TESTS="false"
|
||||||
export RUN_FUNCTIONAL_TESTS="false"
|
export RUN_FUNCTIONAL_TESTS="false"
|
||||||
export RUN_FUZZ_TESTS=true
|
export RUN_FUZZ_TESTS=true
|
||||||
|
@@ -8,7 +8,7 @@ export LC_ALL=C.UTF-8
|
|||||||
|
|
||||||
export CI_IMAGE_NAME_TAG="mirror.gcr.io/ubuntu:24.04"
|
export CI_IMAGE_NAME_TAG="mirror.gcr.io/ubuntu:24.04"
|
||||||
export APT_LLVM_V="20"
|
export APT_LLVM_V="20"
|
||||||
LIBCXX_DIR="/msan/cxx_build/"
|
LIBCXX_DIR="/cxx_build/"
|
||||||
export MSAN_FLAGS="-fsanitize=memory -fsanitize-memory-track-origins=2 -fno-omit-frame-pointer -g -O1 -fno-optimize-sibling-calls"
|
export MSAN_FLAGS="-fsanitize=memory -fsanitize-memory-track-origins=2 -fno-omit-frame-pointer -g -O1 -fno-optimize-sibling-calls"
|
||||||
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"
|
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"
|
||||||
export MSAN_AND_LIBCXX_FLAGS="${MSAN_FLAGS} ${LIBCXX_FLAGS}"
|
export MSAN_AND_LIBCXX_FLAGS="${MSAN_FLAGS} ${LIBCXX_FLAGS}"
|
||||||
@@ -27,4 +27,4 @@ export BITCOIN_CONFIG="\
|
|||||||
-DSANITIZERS=memory \
|
-DSANITIZERS=memory \
|
||||||
-DAPPEND_CPPFLAGS='-U_FORTIFY_SOURCE' \
|
-DAPPEND_CPPFLAGS='-U_FORTIFY_SOURCE' \
|
||||||
"
|
"
|
||||||
export USE_MEMORY_SANITIZER="true"
|
export USE_INSTRUMENTED_LIBCPP="MemoryWithOrigins"
|
||||||
|
@@ -55,31 +55,31 @@ if [ -n "$PIP_PACKAGES" ]; then
|
|||||||
${CI_RETRY_EXE} pip3 install --user $PIP_PACKAGES
|
${CI_RETRY_EXE} pip3 install --user $PIP_PACKAGES
|
||||||
fi
|
fi
|
||||||
|
|
||||||
if [[ ${USE_MEMORY_SANITIZER} == "true" ]]; then
|
if [[ -n "${USE_INSTRUMENTED_LIBCPP}" ]]; then
|
||||||
if [ -n "${APT_LLVM_V}" ]; then
|
if [ -n "${APT_LLVM_V}" ]; then
|
||||||
${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
|
${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
|
||||||
else
|
else
|
||||||
${CI_RETRY_EXE} git clone --depth=1 https://github.com/llvm/llvm-project -b "llvmorg-20.1.8" /msan/llvm-project
|
${CI_RETRY_EXE} git clone --depth=1 https://github.com/llvm/llvm-project -b "llvmorg-20.1.8" /llvm-project
|
||||||
|
|
||||||
cmake -G Ninja -B /msan/clang_build/ \
|
cmake -G Ninja -B /clang_build/ \
|
||||||
-DLLVM_ENABLE_PROJECTS="clang" \
|
-DLLVM_ENABLE_PROJECTS="clang" \
|
||||||
-DCMAKE_BUILD_TYPE=Release \
|
-DCMAKE_BUILD_TYPE=Release \
|
||||||
-DLLVM_TARGETS_TO_BUILD=Native \
|
-DLLVM_TARGETS_TO_BUILD=Native \
|
||||||
-DLLVM_ENABLE_RUNTIMES="compiler-rt;libcxx;libcxxabi;libunwind" \
|
-DLLVM_ENABLE_RUNTIMES="compiler-rt;libcxx;libcxxabi;libunwind" \
|
||||||
-S /msan/llvm-project/llvm
|
-S /llvm-project/llvm
|
||||||
|
|
||||||
ninja -C /msan/clang_build/ "$MAKEJOBS"
|
ninja -C /clang_build/ "$MAKEJOBS"
|
||||||
ninja -C /msan/clang_build/ install-runtimes
|
ninja -C /clang_build/ install-runtimes
|
||||||
|
|
||||||
update-alternatives --install /usr/bin/clang++ clang++ /msan/clang_build/bin/clang++ 100
|
update-alternatives --install /usr/bin/clang++ clang++ /clang_build/bin/clang++ 100
|
||||||
update-alternatives --install /usr/bin/clang clang /msan/clang_build/bin/clang 100
|
update-alternatives --install /usr/bin/clang clang /clang_build/bin/clang 100
|
||||||
update-alternatives --install /usr/bin/llvm-symbolizer llvm-symbolizer /msan/clang_build/bin/llvm-symbolizer 100
|
update-alternatives --install /usr/bin/llvm-symbolizer llvm-symbolizer /clang_build/bin/llvm-symbolizer 100
|
||||||
fi
|
fi
|
||||||
|
|
||||||
cmake -G Ninja -B /msan/cxx_build/ \
|
cmake -G Ninja -B /cxx_build/ \
|
||||||
-DLLVM_ENABLE_RUNTIMES="libcxx;libcxxabi;libunwind" \
|
-DLLVM_ENABLE_RUNTIMES="libcxx;libcxxabi;libunwind" \
|
||||||
-DCMAKE_BUILD_TYPE=Release \
|
-DCMAKE_BUILD_TYPE=Release \
|
||||||
-DLLVM_USE_SANITIZER=MemoryWithOrigins \
|
-DLLVM_USE_SANITIZER="${USE_INSTRUMENTED_LIBCPP}" \
|
||||||
-DCMAKE_C_COMPILER=clang \
|
-DCMAKE_C_COMPILER=clang \
|
||||||
-DCMAKE_CXX_COMPILER=clang++ \
|
-DCMAKE_CXX_COMPILER=clang++ \
|
||||||
-DLLVM_TARGETS_TO_BUILD=Native \
|
-DLLVM_TARGETS_TO_BUILD=Native \
|
||||||
@@ -87,13 +87,13 @@ if [[ ${USE_MEMORY_SANITIZER} == "true" ]]; then
|
|||||||
-DLIBCXXABI_USE_LLVM_UNWINDER=OFF \
|
-DLIBCXXABI_USE_LLVM_UNWINDER=OFF \
|
||||||
-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" \
|
-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" \
|
||||||
-DLIBCXX_HARDENING_MODE=debug \
|
-DLIBCXX_HARDENING_MODE=debug \
|
||||||
-S /msan/llvm-project/runtimes
|
-S /llvm-project/runtimes
|
||||||
|
|
||||||
ninja -C /msan/cxx_build/ "$MAKEJOBS"
|
ninja -C /cxx_build/ "$MAKEJOBS"
|
||||||
|
|
||||||
# Clear no longer needed source folder
|
# Clear no longer needed source folder
|
||||||
du -sh /msan/llvm-project
|
du -sh /llvm-project
|
||||||
rm -rf /msan/llvm-project
|
rm -rf /llvm-project
|
||||||
fi
|
fi
|
||||||
|
|
||||||
if [[ "${RUN_TIDY}" == "true" ]]; then
|
if [[ "${RUN_TIDY}" == "true" ]]; then
|
||||||
|
Reference in New Issue
Block a user