Skip to content

Commit 9ccce65

Browse files
authored
Merge branch 'bitcoin-core:master' into 2025-07-console-clear-history
2 parents 4dd9a04 + 75ed673 commit 9ccce65

Some content is hidden

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

59 files changed

+1348
-377
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 & 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: 3 additions & 3 deletions
Original file line numberDiff line numberDiff line change
@@ -8,13 +8,13 @@ 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"
2020
export CI_LIMIT_STACK_SIZE=1
@@ -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

depends/README.md

Lines changed: 12 additions & 0 deletions
Original file line numberDiff line numberDiff line change
@@ -57,6 +57,18 @@ To build dependencies for the current arch+OS:
5757

5858
gmake
5959

60+
### Alpine
61+
62+
apk add bash build-base cmake curl make patch
63+
64+
Skip the following packages if you don't intend to use the GUI and will build with [`NO_QT=1`](#dependency-options):
65+
66+
apk add bison linux-headers samurai pkgconf python3
67+
68+
To build dependencies for the current arch+OS:
69+
70+
make
71+
6072
## Configuring Bitcoin Core
6173

6274
**When configuring Bitcoin Core, CMake by default will ignore the depends output.** In

depends/funcs.mk

Lines changed: 4 additions & 2 deletions
Original file line numberDiff line numberDiff line change
@@ -8,9 +8,11 @@ $(1)_ar=$$($$($(1)_type)_AR)
88
$(1)_ranlib=$$($$($(1)_type)_RANLIB)
99
$(1)_nm=$$($$($(1)_type)_NM)
1010
$(1)_cflags=$$($$($(1)_type)_CFLAGS) \
11-
$$($$($(1)_type)_$$(release_type)_CFLAGS)
11+
$$($$($(1)_type)_$$(release_type)_CFLAGS) \
12+
-pipe -std=$(C_STANDARD)
1213
$(1)_cxxflags=$$($$($(1)_type)_CXXFLAGS) \
13-
$$($$($(1)_type)_$$(release_type)_CXXFLAGS)
14+
$$($$($(1)_type)_$$(release_type)_CXXFLAGS) \
15+
-pipe -std=$(CXX_STANDARD)
1416
$(1)_ldflags=$$($$($(1)_type)_LDFLAGS) \
1517
$$($$($(1)_type)_$$(release_type)_LDFLAGS) \
1618
-L$$($($(1)_type)_prefix)/lib

depends/hosts/darwin.mk

Lines changed: 2 additions & 2 deletions
Original file line numberDiff line numberDiff line change
@@ -60,8 +60,8 @@ darwin_CXX=$(clangxx_prog) --target=$(host) \
6060
-iwithsysroot/usr/include/c++/v1 \
6161
-iwithsysroot/usr/include -iframeworkwithsysroot/System/Library/Frameworks
6262

63-
darwin_CFLAGS=-pipe -std=$(C_STANDARD) -mmacos-version-min=$(OSX_MIN_VERSION)
64-
darwin_CXXFLAGS=-pipe -std=$(CXX_STANDARD) -mmacos-version-min=$(OSX_MIN_VERSION)
63+
darwin_CFLAGS=-mmacos-version-min=$(OSX_MIN_VERSION)
64+
darwin_CXXFLAGS=-mmacos-version-min=$(OSX_MIN_VERSION)
6565
darwin_LDFLAGS=-Wl,-platform_version,macos,$(OSX_MIN_VERSION),$(OSX_SDK_VERSION)
6666

6767
ifneq ($(build_os),darwin)

depends/hosts/freebsd.mk

Lines changed: 2 additions & 2 deletions
Original file line numberDiff line numberDiff line change
@@ -1,5 +1,5 @@
1-
freebsd_CFLAGS=-pipe -std=$(C_STANDARD)
2-
freebsd_CXXFLAGS=-pipe -std=$(CXX_STANDARD)
1+
freebsd_CFLAGS=
2+
freebsd_CXXFLAGS=
33

44
freebsd_release_CFLAGS=-O2
55
freebsd_release_CXXFLAGS=$(freebsd_release_CFLAGS)

depends/hosts/linux.mk

Lines changed: 2 additions & 2 deletions
Original file line numberDiff line numberDiff line change
@@ -1,5 +1,5 @@
1-
linux_CFLAGS=-pipe -std=$(C_STANDARD)
2-
linux_CXXFLAGS=-pipe -std=$(CXX_STANDARD)
1+
linux_CFLAGS=
2+
linux_CXXFLAGS=
33

44
ifneq ($(LTO),)
55
linux_AR = $(host_toolchain)gcc-ar

0 commit comments

Comments
 (0)