Skip to content

Commit 06516aa

Browse files
committed
Merge branch 'bitcoin' into auxpow
2 parents 7af9a4f + 83a2216 commit 06516aa

File tree

105 files changed

+2032
-634
lines changed

Some content is hidden

Large Commits have some content hidden by default. Use the searchbox below for content that may be hidden.

105 files changed

+2032
-634
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_arm.sh

Lines changed: 1 addition & 0 deletions
Original file line numberDiff line numberDiff line change
@@ -16,6 +16,7 @@ export USE_BUSY_BOX=true
1616
export RUN_UNIT_TESTS=true
1717
export RUN_FUNCTIONAL_TESTS=false
1818
export GOAL="install"
19+
export CI_LIMIT_STACK_SIZE=1
1920
# -Wno-psabi is to disable ABI warnings: "note: parameter passing for argument of type ... changed in GCC 7.1"
2021
# This could be removed once the ABI change warning does not show up by default
2122
export BITCOIN_CONFIG="-DREDUCE_EXPORTS=ON -DCMAKE_CXX_FLAGS='-Wno-psabi -Wno-error=maybe-uninitialized'"

ci/test/00_setup_env_mac_native.sh

Lines changed: 1 addition & 1 deletion
Original file line numberDiff line numberDiff line change
@@ -11,7 +11,7 @@ export LC_ALL=C.UTF-8
1111
export PIP_PACKAGES="--break-system-packages zmq"
1212
export GOAL="install deploy"
1313
export CMAKE_GENERATOR="Ninja"
14-
export BITCOIN_CONFIG="-DBUILD_GUI=ON -DWITH_ZMQ=ON -DREDUCE_EXPORTS=ON"
14+
export BITCOIN_CONFIG="-DBUILD_GUI=ON -DWITH_ZMQ=ON -DREDUCE_EXPORTS=ON -DCMAKE_EXE_LINKER_FLAGS='-Wl,-stack_size -Wl,0x80000'"
1515
export CI_OS_NAME="macos"
1616
export NO_DEPENDS=1
1717
export OSX_SDK=""

ci/test/00_setup_env_mac_native_fuzz.sh

Lines changed: 1 addition & 1 deletion
Original file line numberDiff line numberDiff line change
@@ -7,7 +7,7 @@
77
export LC_ALL=C.UTF-8
88

99
export CMAKE_GENERATOR="Ninja"
10-
export BITCOIN_CONFIG="-DBUILD_FOR_FUZZING=ON"
10+
export BITCOIN_CONFIG="-DBUILD_FOR_FUZZING=ON -DCMAKE_EXE_LINKER_FLAGS='-Wl,-stack_size -Wl,0x80000'"
1111
export CI_OS_NAME="macos"
1212
export NO_DEPENDS=1
1313
export OSX_SDK=""

ci/test/00_setup_env_native_asan.sh

Lines changed: 1 addition & 0 deletions
Original file line numberDiff line numberDiff line change
@@ -23,6 +23,7 @@ export APT_LLVM_V="20"
2323
export PACKAGES="systemtap-sdt-dev clang-${APT_LLVM_V} llvm-${APT_LLVM_V} libclang-rt-${APT_LLVM_V}-dev python3-zmq qt6-base-dev qt6-tools-dev qt6-l10n-tools libevent-dev libboost-dev libzmq3-dev libqrencode-dev libsqlite3-dev ${BPFCC_PACKAGE}"
2424
export NO_DEPENDS=1
2525
export GOAL="install"
26+
export CI_LIMIT_STACK_SIZE=1
2627
export BITCOIN_CONFIG="\
2728
-DWITH_USDT=ON -DWITH_ZMQ=ON -DBUILD_GUI=ON \
2829
-DSANITIZERS=address,float-divide-by-zero,integer,undefined \

ci/test/00_setup_env_native_fuzz_with_msan.sh

Lines changed: 2 additions & 3 deletions
Original file line numberDiff line numberDiff line change
@@ -7,13 +7,12 @@
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}"
1414

1515
export CONTAINER_NAME="ci_native_fuzz_msan"
16-
export PACKAGES="ninja-build"
1716
export DEP_OPTS="DEBUG=1 NO_QT=1 CC=clang CXX=clang++ CFLAGS='${MSAN_FLAGS}' CXXFLAGS='${MSAN_AND_LIBCXX_FLAGS}'"
1817
export GOAL="all"
1918
# Setting CMAKE_{C,CXX}_FLAGS_DEBUG flags to an empty string ensures that the flags set in MSAN_FLAGS remain unaltered.
@@ -26,7 +25,7 @@ export BITCOIN_CONFIG="\
2625
-DSANITIZERS=fuzzer,memory \
2726
-DAPPEND_CPPFLAGS='-DBOOST_MULTI_INDEX_ENABLE_SAFE_MODE -U_FORTIFY_SOURCE' \
2827
"
29-
export USE_MEMORY_SANITIZER="true"
28+
export USE_INSTRUMENTED_LIBCPP="MemoryWithOrigins"
3029
export RUN_UNIT_TESTS="false"
3130
export RUN_FUNCTIONAL_TESTS="false"
3231
export RUN_FUZZ_TESTS=true

ci/test/00_setup_env_native_msan.sh

Lines changed: 4 additions & 3 deletions
Original file line numberDiff line numberDiff line change
@@ -8,15 +8,16 @@ 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}"
1515

1616
export CONTAINER_NAME="ci_native_msan"
17-
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 ninja-build"
17+
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"
1818
export DEP_OPTS="DEBUG=1 NO_QT=1 CC=clang CXX=clang++ CFLAGS='${MSAN_FLAGS}' CXXFLAGS='${MSAN_AND_LIBCXX_FLAGS}'"
1919
export GOAL="install"
20+
export CI_LIMIT_STACK_SIZE=1
2021
# Setting CMAKE_{C,CXX}_FLAGS_DEBUG flags to an empty string ensures that the flags set in MSAN_FLAGS remain unaltered.
2122
# _FORTIFY_SOURCE is not compatible with MSAN.
2223
export BITCOIN_CONFIG="\
@@ -26,4 +27,4 @@ export BITCOIN_CONFIG="\
2627
-DSANITIZERS=memory \
2728
-DAPPEND_CPPFLAGS='-U_FORTIFY_SOURCE' \
2829
"
29-
export USE_MEMORY_SANITIZER="true"
30+
export USE_INSTRUMENTED_LIBCPP="MemoryWithOrigins"

ci/test/00_setup_env_native_previous_releases.sh

Lines changed: 1 addition & 0 deletions
Original file line numberDiff line numberDiff line change
@@ -15,6 +15,7 @@ export TEST_RUNNER_EXTRA="--previous-releases --coverage --extended --exclude fe
1515
export RUN_UNIT_TESTS_SEQUENTIAL="true"
1616
export RUN_UNIT_TESTS="false"
1717
export GOAL="install"
18+
export CI_LIMIT_STACK_SIZE=1
1819
export DOWNLOAD_PREVIOUS_RELEASES="true"
1920
export BITCOIN_CONFIG="\
2021
-DWITH_ZMQ=ON -DBUILD_GUI=ON -DREDUCE_EXPORTS=ON \

ci/test/00_setup_env_native_tsan.sh

Lines changed: 7 additions & 3 deletions
Original file line numberDiff line numberDiff line change
@@ -9,8 +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"
17+
export CI_LIMIT_STACK_SIZE=1
1518
export BITCOIN_CONFIG="-DWITH_ZMQ=ON -DSANITIZERS=thread \
16-
-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)