mirror of
https://github.com/bitcoin/bitcoin.git
synced 2025-01-25 18:53:23 -03:00
build: disable boost multi index safe mode
Disable boost multi index safe mode by default when configuring with --enable-debug. This option can cause transactions to take a long time to be accepted into the mempool under certain conditions; iterator destruction takes O(n) time vs O(1) as they are stored in a singly linked list. See 27586 for more information. Re-enable it on the CI builds which previously had it enabled. Re-enable it on the msan fuzz target so that we have fuzz tasks testing with it enabeld and disabled in this repo.
This commit is contained in:
parent
22139f6e83
commit
59c8944749
4 changed files with 5 additions and 8 deletions
|
@ -12,6 +12,7 @@ export CI_IMAGE_NAME_TAG=ubuntu:20.04
|
||||||
export PACKAGES="cmake python3 llvm clang g++-multilib"
|
export PACKAGES="cmake python3 llvm clang g++-multilib"
|
||||||
export DEP_OPTS="DEBUG=1 MULTIPROCESS=1"
|
export DEP_OPTS="DEBUG=1 MULTIPROCESS=1"
|
||||||
export GOAL="install"
|
export GOAL="install"
|
||||||
export BITCOIN_CONFIG="--enable-debug CC='clang -m32' CXX='clang++ -m32' LDFLAGS='--rtlib=compiler-rt -lgcc_s'"
|
export BITCOIN_CONFIG="--enable-debug CC='clang -m32' CXX='clang++ -m32' \
|
||||||
|
LDFLAGS='--rtlib=compiler-rt -lgcc_s' CPPFLAGS='-DBOOST_MULTI_INDEX_ENABLE_SAFE_MODE'"
|
||||||
export TEST_RUNNER_ENV="BITCOIND=bitcoin-node"
|
export TEST_RUNNER_ENV="BITCOIND=bitcoin-node"
|
||||||
export TEST_RUNNER_EXTRA="--nosandbox"
|
export TEST_RUNNER_EXTRA="--nosandbox"
|
||||||
|
|
|
@ -17,7 +17,7 @@ export PACKAGES="clang-16 llvm-16 libclang-rt-16-dev cmake"
|
||||||
# BDB generates false-positives and will be removed in future
|
# BDB generates false-positives and will be removed in future
|
||||||
export DEP_OPTS="NO_BDB=1 NO_QT=1 CC='clang' CXX='clang++' CFLAGS='${MSAN_FLAGS}' CXXFLAGS='${MSAN_AND_LIBCXX_FLAGS}'"
|
export DEP_OPTS="NO_BDB=1 NO_QT=1 CC='clang' CXX='clang++' CFLAGS='${MSAN_FLAGS}' CXXFLAGS='${MSAN_AND_LIBCXX_FLAGS}'"
|
||||||
export GOAL="install"
|
export GOAL="install"
|
||||||
export BITCOIN_CONFIG="--enable-fuzz --with-sanitizers=fuzzer,memory --disable-hardening --with-asm=no CC=clang CXX=clang++ CFLAGS='${MSAN_FLAGS}' CXXFLAGS='${MSAN_AND_LIBCXX_FLAGS}'"
|
export BITCOIN_CONFIG="--enable-fuzz --with-sanitizers=fuzzer,memory --disable-hardening --with-asm=no CC=clang CXX=clang++ CFLAGS='${MSAN_FLAGS}' CPPFLAGS='-DBOOST_MULTI_INDEX_ENABLE_SAFE_MODE' CXXFLAGS='${MSAN_AND_LIBCXX_FLAGS}'"
|
||||||
export USE_MEMORY_SANITIZER="true"
|
export USE_MEMORY_SANITIZER="true"
|
||||||
export RUN_UNIT_TESTS="false"
|
export RUN_UNIT_TESTS="false"
|
||||||
export RUN_FUNCTIONAL_TESTS="false"
|
export RUN_FUNCTIONAL_TESTS="false"
|
||||||
|
|
|
@ -17,5 +17,5 @@ export RUN_UNIT_TESTS="false"
|
||||||
export GOAL="install"
|
export GOAL="install"
|
||||||
export NO_WERROR=1 # -Werror=maybe-uninitialized
|
export NO_WERROR=1 # -Werror=maybe-uninitialized
|
||||||
export DOWNLOAD_PREVIOUS_RELEASES="true"
|
export DOWNLOAD_PREVIOUS_RELEASES="true"
|
||||||
export BITCOIN_CONFIG="--enable-zmq --with-libs=no --with-gui=qt5 --enable-reduce-exports \
|
export BITCOIN_CONFIG="--enable-zmq --with-libs=no --with-gui=qt5 --enable-reduce-exports --enable-debug \
|
||||||
--enable-debug CFLAGS=\"-g0 -O2 -funsigned-char\" CXXFLAGS=\"-g0 -O2 -funsigned-char\""
|
CFLAGS=\"-g0 -O2 -funsigned-char\" CPPFLAGS='-DBOOST_MULTI_INDEX_ENABLE_SAFE_MODE' CXXFLAGS=\"-g0 -O2 -funsigned-char\""
|
||||||
|
|
|
@ -1491,10 +1491,6 @@ if test "$use_boost" = "yes"; then
|
||||||
AX_CHECK_PREPROC_FLAG([-DBOOST_NO_CXX98_FUNCTION_BASE], [BOOST_CPPFLAGS="$BOOST_CPPFLAGS -DBOOST_NO_CXX98_FUNCTION_BASE"], [], [$CXXFLAG_WERROR],
|
AX_CHECK_PREPROC_FLAG([-DBOOST_NO_CXX98_FUNCTION_BASE], [BOOST_CPPFLAGS="$BOOST_CPPFLAGS -DBOOST_NO_CXX98_FUNCTION_BASE"], [], [$CXXFLAG_WERROR],
|
||||||
[AC_LANG_PROGRAM([[#include <boost/config.hpp>]])])
|
[AC_LANG_PROGRAM([[#include <boost/config.hpp>]])])
|
||||||
|
|
||||||
if test "$enable_debug" = "yes" || test "$enable_fuzz" = "yes"; then
|
|
||||||
BOOST_CPPFLAGS="$BOOST_CPPFLAGS -DBOOST_MULTI_INDEX_ENABLE_SAFE_MODE"
|
|
||||||
fi
|
|
||||||
|
|
||||||
if test "$suppress_external_warnings" != "no"; then
|
if test "$suppress_external_warnings" != "no"; then
|
||||||
BOOST_CPPFLAGS=SUPPRESS_WARNINGS($BOOST_CPPFLAGS)
|
BOOST_CPPFLAGS=SUPPRESS_WARNINGS($BOOST_CPPFLAGS)
|
||||||
fi
|
fi
|
||||||
|
|
Loading…
Add table
Reference in a new issue