Drop some TSan suppressions #19983
pull hebasto wants to merge 1 commits into bitcoin:master from hebasto:200920-supp changing 1 files +0 −6-
hebasto commented at 2:35 pm on September 20, 2020: memberIt seems possible now to drop some TSan suppressions.
-
DrahtBot added the label Wallet on Sep 20, 2020
-
hebasto force-pushed on Sep 20, 2020
-
practicalswift commented at 3:36 pm on September 20, 2020: contributor
Concept ACK
Great to see
deadlock:UpdateTip
go :) -
hebasto marked this as ready for review on Sep 20, 2020
-
hebasto commented at 5:28 pm on September 20, 2020: member
Some more CI TSan builds:
-
DrahtBot commented at 6:45 pm on September 20, 2020: member
The following sections might be updated with supplementary metadata relevant to reviewers and maintainers.
Conflicts
No conflicts as of last run.
-
hebasto force-pushed on Sep 21, 2020
-
DrahtBot added the label Needs rebase on Nov 12, 2020
-
hebasto force-pushed on Nov 14, 2020
-
hebasto commented at 6:36 pm on November 14, 2020: memberRebased 49c3a5287d74d3739724d9f7f6c7cff3ec398330 -> 730e5ffc2e9f86fded9283543c0e8dc0759d6c6f (pr19983.02 -> pr19983.03) due to the conflict with #20285.
-
DrahtBot removed the label Needs rebase on Nov 14, 2020
-
hebasto force-pushed on Nov 15, 2020
-
DrahtBot added the label Needs rebase on Nov 25, 2020
-
hebasto force-pushed on Nov 28, 2020
-
hebasto force-pushed on Nov 28, 2020
-
hebasto commented at 8:10 pm on November 28, 2020: memberRebased 71518e39d8da6b55e0ad04acc0b6781290573425 -> 27752af19a701702e94fbf721a4ba2d2c0a7d0ea (pr19983.04 -> pr19983.06) due to the conflict with #19337.
-
DrahtBot removed the label Needs rebase on Nov 28, 2020
-
hebasto force-pushed on Dec 3, 2020
-
DrahtBot added the label Needs rebase on Dec 8, 2020
-
hebasto force-pushed on Dec 10, 2020
-
hebasto commented at 6:51 pm on December 10, 2020: memberRebased 3c2e969172cbb2796441eb218e5102a19a1bfd5d -> 89952ae75cc1f0c2e7ec225bbef074f411e3e327 (pr19983.07 -> pr19983.08) due to the conflict with #19425.
-
DrahtBot removed the label Needs rebase on Dec 10, 2020
-
hebasto force-pushed on Dec 11, 2020
-
hebasto commented at 7:39 am on December 11, 2020: memberRebased 89952ae75cc1f0c2e7ec225bbef074f411e3e327 -> b0b6092874f717f3156c043e803600938c7ff571 (pr19983.08 -> pr19983.09) due to the conflict with #19982.
-
practicalswift commented at 2:56 pm on December 11, 2020: contributorcr ACK b0b6092874f717f3156c043e803600938c7ff571: patch looks correct and doesn’t touch any non-test code
-
DrahtBot added the label Needs rebase on Dec 21, 2020
-
hebasto force-pushed on Dec 22, 2020
-
hebasto commented at 8:32 am on December 22, 2020: memberRebased b0b6092874f717f3156c043e803600938c7ff571 -> a17f69f57e42e08ca95469a9997ec1f49fe2bcf9 (pr19983.09 -> pr19983.10) due to the conflict with #20683.
-
in test/functional/test_framework/test_node.py:311 in a17f69f57e outdated
307@@ -308,7 +308,7 @@ def get_wallet_rpc(self, wallet_name): 308 def version_is_at_least(self, ver): 309 return self.version is None or self.version >= ver 310 311- def stop_node(self, expected_stderr='', *, wait=0, wait_until_stopped=True): 312+ def stop_node(self, expected_stderr='', ignored_stderr='', *, wait=0, wait_until_stopped=True):
MarcoFalke commented at 9:58 am on December 22, 2020:0 def stop_node(self, expected_stderr='', *, ignored_stderr='', wait=0, wait_until_stopped=True):
DrahtBot removed the label Needs rebase on Dec 22, 2020hebasto force-pushed on Dec 22, 2020hebasto commented at 10:45 am on December 22, 2020: memberUpdated a17f69f57e42e08ca95469a9997ec1f49fe2bcf9 -> 354d2cba44747ca34b6833e0f58901394a03ae49 (pr19983.10 -> pr19983.11, diff):
- addressed @MarcoFalke’s comment
practicalswift commented at 10:52 am on December 22, 2020: contributorcr ACK 354d2cba44747ca34b6833e0f58901394a03ae49: patch looks correct and doesn’t touch any non-test codeUpdate TSan suppressions 3e1571285fin test/functional/feature_maxuploadtarget.py:165 in 354d2cba44 outdated
160@@ -161,6 +161,9 @@ def run_test(self): 161 assert_equal(len(peer_info), 1) # node is still connected 162 assert_equal(peer_info[0]['permissions'], ['download']) 163 164+ # Ignore non-critical TSan warnings. 165+ self.stop_node(0, ignored_stderr="WARNING: too long mutex cycle found")
MarcoFalke commented at 1:57 pm on December 22, 2020:I can’t reproduce this locally. How often did you have to run this test?
I am running with:
0diff --git a/test/sanitizer_suppressions/tsan b/test/sanitizer_suppressions/tsan 1index 986e09605..020f3da9b 100644 2--- a/test/sanitizer_suppressions/tsan 3+++ b/test/sanitizer_suppressions/tsan 4@@ -29,12 +29,7 @@ race:zmq::* 5 race:bitcoin-qt 6 # deadlock (TODO fix) 7 deadlock:CConnman::ForNode 8-deadlock:CConnman::GetNodeStats 9 deadlock:CChainState::ConnectTip 10-deadlock:UpdateTip 11- 12-# WalletBatch (unidentified deadlock) 13-deadlock:WalletBatch 14 15 # Intentional deadlock in tests 16 deadlock:TestPotentialDeadLockDetected
hebasto commented at 2:06 pm on December 22, 2020:I can’t reproduce this locally.
What is
-stdlib
compiled against?
MarcoFalke commented at 2:15 pm on December 22, 2020:I used./ci/test/00_setup_env_native_tsan.sh
to compile
hebasto commented at 3:19 pm on December 22, 2020:Indeed. On master (df127ecede804ecb0a70bf45cbca73af3c3e7761) with your patch I have no “WARNING: too long mutex cycle found” from the thread sanitizer when running
test/functional/feature_maxuploadtarget.py
. Maybe the reason is the updated clang?Instead, the skipping
-DDEBUG_LOCKORDER
fromCPPFLAGS
causes another warning even on master w/o your patch:0$ test/functional/feature_maxuploadtarget.py 12020-12-22T15:02:39.792000Z TestFramework (INFO): Initializing test directory /tmp/bitcoin_func_test_731auno_ 22020-12-22T15:02:57.821000Z TestFramework (INFO): Peer 0 disconnected after downloading old block too many times 32020-12-22T15:03:42.603000Z TestFramework (INFO): Peer 1 able to repeatedly download new block 42020-12-22T15:03:42.712000Z TestFramework (INFO): Peer 1 disconnected after trying to download old block 52020-12-22T15:03:42.712000Z TestFramework (INFO): Advancing system time on node to clear counters... 62020-12-22T15:03:42.867000Z TestFramework (INFO): Peer 2 able to download old block 72020-12-22T15:03:42.873000Z TestFramework (INFO): Restarting node 0 with download permission and 1MB maxuploadtarget 82020-12-22T15:03:45.050000Z TestFramework (INFO): Peer still connected after trying to download old block (download permission) 92020-12-22T15:03:45.103000Z TestFramework (INFO): Stopping nodes 10Traceback (most recent call last): 11 File "test/functional/feature_maxuploadtarget.py", line 166, in <module> 12 MaxUploadTest().main() 13 File "/home/hebasto/code/gh/bitcoin/test/functional/test_framework/test_framework.py", line 149, in main 14 exit_code = self.shutdown() 15 File "/home/hebasto/code/gh/bitcoin/test/functional/test_framework/test_framework.py", line 278, in shutdown 16 self.stop_nodes() 17 File "/home/hebasto/code/gh/bitcoin/test/functional/test_framework/test_framework.py", line 525, in stop_nodes 18 node.stop_node(wait=wait, wait_until_stopped=False) 19 File "/home/hebasto/code/gh/bitcoin/test/functional/test_framework/test_node.py", line 333, in stop_node 20 raise AssertionError("Unexpected stderr {} != {}".format(stderr, expected_stderr)) 21AssertionError: Unexpected stderr ================== 22WARNING: ThreadSanitizer: double lock of a mutex (pid=365627) 23 [#0](/bitcoin-bitcoin/0/) pthread_mutex_lock <null> (bitcoind+0xa8cf6) 24 [#1](/bitcoin-bitcoin/1/) std::__1::mutex::lock() <null> (libc++.so.1+0x83505) 25 [#2](/bitcoin-bitcoin/2/) CConnman::ThreadSocketHandler() /home/hebasto/code/gh/bitcoin/src/net.cpp:1542:9 (bitcoind+0x1780d4) 26 [#3](/bitcoin-bitcoin/3/) decltype(*(std::__1::forward<CConnman*&>(fp0)).*fp()) std::__1::__invoke<void (CConnman::*&)(), CConnman*&, void>(void (CConnman::*&)(), CConnman*&) /usr/lib/llvm-10/bin/../include/c++/v1/type_traits:3480:1 (bitcoind+0x1a325a) 27 [#4](/bitcoin-bitcoin/4/) std::__1::__bind_return<void (CConnman::*)(), std::__1::tuple<CConnman*>, std::__1::tuple<>, __is_valid_bind_return<void (CConnman::*)(), std::__1::tuple<CConnman*>, std::__1::tuple<> >::value>::type std::__1::__apply_functor<void (CConnman::*)(), std::__1::tuple<CConnman*>, 0ul, std::__1::tuple<> >(void (CConnman::*&)(), std::__1::tuple<CConnman*>&, std::__1::__tuple_indices<0ul>, std::__1::tuple<>&&) /usr/lib/llvm-10/bin/../include/c++/v1/functional:2770:12 (bitcoind+0x1a325a) 28 [#5](/bitcoin-bitcoin/5/) std::__1::__bind_return<void (CConnman::*)(), std::__1::tuple<CConnman*>, std::__1::tuple<>, __is_valid_bind_return<void (CConnman::*)(), std::__1::tuple<CConnman*>, std::__1::tuple<> >::value>::type std::__1::__bind<void (CConnman::*)(), CConnman*>::operator()<>() /usr/lib/llvm-10/bin/../include/c++/v1/functional:2803:20 (bitcoind+0x1a325a) 29 [#6](/bitcoin-bitcoin/6/) decltype(std::__1::forward<std::__1::__bind<void (CConnman::*)(), CConnman*>&>(fp)()) std::__1::__invoke<std::__1::__bind<void (CConnman::*)(), CConnman*>&>(std::__1::__bind<void (CConnman::*)(), CConnman*>&) /usr/lib/llvm-10/bin/../include/c++/v1/type_traits:3539:1 (bitcoind+0x1a325a) 30 [#7](/bitcoin-bitcoin/7/) void std::__1::__invoke_void_return_wrapper<void>::__call<std::__1::__bind<void (CConnman::*)(), CConnman*>&>(std::__1::__bind<void (CConnman::*)(), CConnman*>&) /usr/lib/llvm-10/bin/../include/c++/v1/__functional_base:348:9 (bitcoind+0x1a325a) 31 [#8](/bitcoin-bitcoin/8/) std::__1::__function::__alloc_func<std::__1::__bind<void (CConnman::*)(), CConnman*>, std::__1::allocator<std::__1::__bind<void (CConnman::*)(), CConnman*> >, void ()>::operator()() /usr/lib/llvm-10/bin/../include/c++/v1/functional:1540:16 (bitcoind+0x1a325a) 32 [#9](/bitcoin-bitcoin/9/) std::__1::__function::__func<std::__1::__bind<void (CConnman::*)(), CConnman*>, std::__1::allocator<std::__1::__bind<void (CConnman::*)(), CConnman*> >, void ()>::operator()() /usr/lib/llvm-10/bin/../include/c++/v1/functional:1714:12 (bitcoind+0x1a325a) 33 [#10](/bitcoin-bitcoin/10/) std::__1::__function::__value_func<void ()>::operator()() const /usr/lib/llvm-10/bin/../include/c++/v1/functional:1867:16 (bitcoind+0x148cfe) 34 [#11](/bitcoin-bitcoin/11/) std::__1::function<void ()>::operator()() const /usr/lib/llvm-10/bin/../include/c++/v1/functional:2473:12 (bitcoind+0x148cfe) 35 [#12](/bitcoin-bitcoin/12/) void TraceThread<std::__1::function<void ()> >(char const*, std::__1::function<void ()>) /home/hebasto/code/gh/bitcoin/src/./util/system.h:438:9 (bitcoind+0x148cfe) 36 [#13](/bitcoin-bitcoin/13/) decltype(std::__1::forward<void (*)(char const*, std::__1::function<void ()>)>(fp)(std::__1::forward<char const*>(fp0), std::__1::forward<std::__1::function<void ()> >(fp0))) std::__1::__invoke<void (*)(char const*, std::__1::function<void ()>), char const*, std::__1::function<void ()> >(void (*&&)(char const*, std::__1::function<void ()>), char const*&&, std::__1::function<void ()>&&) /usr/lib/llvm-10/bin/../include/c++/v1/type_traits:3539:1 (bitcoind+0x1a342c) 37 [#14](/bitcoin-bitcoin/14/) void std::__1::__thread_execute<std::__1::unique_ptr<std::__1::__thread_struct, std::__1::default_delete<std::__1::__thread_struct> >, void (*)(char const*, std::__1::function<void ()>), char const*, std::__1::function<void ()>, 2ul, 3ul>(std::__1::tuple<std::__1::unique_ptr<std::__1::__thread_struct, std::__1::default_delete<std::__1::__thread_struct> >, void (*)(char const*, std::__1::function<void ()>), char const*, std::__1::function<void ()> >&, std::__1::__tuple_indices<2ul, 3ul>) /usr/lib/llvm-10/bin/../include/c++/v1/thread:273:5 (bitcoind+0x1a342c) 38 [#15](/bitcoin-bitcoin/15/) void* std::__1::__thread_proxy<std::__1::tuple<std::__1::unique_ptr<std::__1::__thread_struct, std::__1::default_delete<std::__1::__thread_struct> >, void (*)(char const*, std::__1::function<void ()>), char const*, std::__1::function<void ()> > >(void*) /usr/lib/llvm-10/bin/../include/c++/v1/thread:284:5 (bitcoind+0x1a342c) 39 40 Location is heap block of size 328920 at 0x7f3445476000 allocated by main thread: 41 [#0](/bitcoin-bitcoin/0/) operator new(unsigned long) <null> (bitcoind+0x11883b) 42 [#1](/bitcoin-bitcoin/1/) std::__1::__unique_if<CConnman>::__unique_single std::__1::make_unique<CConnman, unsigned long, unsigned long, bool>(unsigned long&&, unsigned long&&, bool&&) /usr/lib/llvm-10/bin/../include/c++/v1/memory:3028:28 (bitcoind+0x134039) 43 [#2](/bitcoin-bitcoin/2/) std::__1::unique_ptr<CConnman, std::__1::default_delete<CConnman> > MakeUnique<CConnman, unsigned long, unsigned long, bool>(unsigned long&&, unsigned long&&, bool&&) /home/hebasto/code/gh/bitcoin/src/./util/memory.h:17:12 (bitcoind+0x134039) 44 [#3](/bitcoin-bitcoin/3/) AppInitMain(util::Ref const&, NodeContext&, interfaces::BlockAndHeaderTipInfo*) /home/hebasto/code/gh/bitcoin/src/init.cpp:1386:20 (bitcoind+0x134039) 45 [#4](/bitcoin-bitcoin/4/) AppInit(int, char**) /home/hebasto/code/gh/bitcoin/src/bitcoind.cpp:133:43 (bitcoind+0x11b773) 46 [#5](/bitcoin-bitcoin/5/) main /home/hebasto/code/gh/bitcoin/src/bitcoind.cpp:161:13 (bitcoind+0x11b773) 47 48 Mutex M132842 (0x7f34454c63f8) created at: 49 [#0](/bitcoin-bitcoin/0/) pthread_mutex_lock <null> (bitcoind+0xa8cf6) 50 [#1](/bitcoin-bitcoin/1/) std::__1::mutex::lock() <null> (libc++.so.1+0x83505) 51 [#2](/bitcoin-bitcoin/2/) AppInitMain(util::Ref const&, NodeContext&, interfaces::BlockAndHeaderTipInfo*) /home/hebasto/code/gh/bitcoin/src/init.cpp:1981:24 (bitcoind+0x13d0a3) 52 [#3](/bitcoin-bitcoin/3/) AppInit(int, char**) /home/hebasto/code/gh/bitcoin/src/bitcoind.cpp:133:43 (bitcoind+0x11b773) 53 [#4](/bitcoin-bitcoin/4/) main /home/hebasto/code/gh/bitcoin/src/bitcoind.cpp:161:13 (bitcoind+0x11b773) 54 55SUMMARY: ThreadSanitizer: double lock of a mutex (/home/hebasto/code/gh/bitcoin/src/bitcoind+0xa8cf6) in pthread_mutex_lock 56================== != 57[node 0] Cleaning up leftover process
hebasto commented at 3:19 pm on December 22, 2020:Going to update this PR after more tests.
hebasto force-pushed on Dec 22, 2020hebasto commented at 6:28 pm on December 22, 2020: memberUpdated 354d2cba44747ca34b6833e0f58901394a03ae49 -> 3e1571285f4a0edf59d51bbdeee028be3038b6dc (pr19983.11 -> pr19983.12):
- addressed @MarcoFalke’s comment
- rebased on top of the #20745
in test/sanitizer_suppressions/tsan:39 in 3e1571285f
34-deadlock:CConnman::GetNodeStats 35 deadlock:CChainState::ConnectTip 36-deadlock:UpdateTip 37- 38-# WalletBatch (unidentified deadlock) 39-deadlock:WalletBatch
MarcoFalke commented at 6:45 pm on December 22, 2020:What are the steps to verify this patch? Note that the deadlocks are intermittent, so there is no way to run the tests and reproduce them or not reproduce them reliably.
hebasto commented at 6:48 pm on December 22, 2020:TSan searches for potential deadlocks, i.e., it verifies consistency of lock ordering in the code, right?
hebasto commented at 6:50 pm on December 22, 2020:
MarcoFalke commented at 7:02 pm on December 22, 2020:The lock order graph is generated at runtime and is not deterministic. It depends on the code paths that are executed, and our tests exercise different code paths in each run.
hebasto commented at 7:13 pm on December 22, 2020:What are the steps to verify this patch?
I don’t know (besides tracking code changes since these suppressions were introduced).
Having a smaller set of suppressions is better, though. If this patch appears wrong in the next year, it could be reverted :)
MarcoFalke commented at 8:55 pm on December 22, 2020: memberIf this patch appears wrong in the next year, it could be reverted :)
Ok, fair enough. Let’s give it a try.
MarcoFalke merged this on Dec 22, 2020MarcoFalke closed this on Dec 22, 2020
sidhujag referenced this in commit d51adb2fa9 on Dec 23, 2020hebasto deleted the branch on Dec 23, 2020DrahtBot locked this on Feb 15, 2022
github-metadata-mirror
This is a metadata mirror of the GitHub repository bitcoin/bitcoin. This site is not affiliated with GitHub. Content is generated from a GitHub metadata backup.
generated: 2025-01-21 09:12 UTC
This site is hosted by @0xB10C
More mirrored repositories can be found on mirror.b10c.me