Commit
This commit does not belong to any branch on this repository, and may belong to a fork outside of the repository.
fix: no need to relay quorum commitment in case of block undo
It fixes potentiall deadlock: Assertion failed: detected inconsistent lock order for 'peer.m_tx_relay->m_tx_inventory_mutex' in net_processing.cpp:971 (in thread 'httpworker.0'), details in debug log. Posix Signal: Aborted 0#: (0x5BE0A9B78F04) stl_vector.h:115 - std::_Vector_base<unsigned long, std::allocator<unsigned long> >::_Vector_impl_data::_M_copy_data(std::_Vector_base<unsigned long, std::allocator<unsigned long> >::_Vector_impl_data const&) 1#: (0x5BE0A9B78F04) stl_vector.h:127 - std::_Vector_base<unsigned long, std::allocator<unsigned long> >::_Vector_impl_data::_M_swap_data(std::_Vector_base<unsigned long, std::allocator<unsigned long> >::_Vector_impl_data&) 2#: (0x5BE0A9B78F04) stl_vector.h:1959 - std::vector<unsigned long, std::allocator<unsigned long> >::_M_move_assign(std::vector<unsigned long, std::allocator<unsigned long> >&&, std::integral_constant<bool, true>) 3#: (0x5BE0A9B78F04) stl_vector.h:768 - std::vector<unsigned long, std::allocator<unsigned long> >::operator=(std::vector<unsigned long, std::allocator<unsigned long> >&&) 4#: (0x5BE0A9B78F04) stacktraces.cpp:777 - HandlePosixSignal 5#: (0x733859C42990) libc_sigaction.c - ??? 6#: (0x733859C99A1B) pthread_kill.c:44 - __pthread_kill_implementation 7#: (0x733859C99A1B) pthread_kill.c:78 - __pthread_kill_internal 8#: (0x733859C99A1B) pthread_kill.c:89 - __GI___pthread_kill 9#: (0x733859C428E6) raise.c:27 - __GI_raise 10#: (0x733859C268B7) abort.c:81 - __GI_abort 11#: (0x5BE0A9B7EA06) basic_string.h:390 - std::__cxx11::basic_string<char, std::char_traits<char>, std::allocator<char> >::_M_check_length(unsigned long, unsigned long, char const*) const 12#: (0x5BE0A9B7EA06) basic_string.h:1461 - std::__cxx11::basic_string<char, std::char_traits<char>, std::allocator<char> >::append(char const*) 13#: (0x5BE0A9B7EA06) basic_string.h:1365 - std::__cxx11::basic_string<char, std::char_traits<char>, std::allocator<char> >::operator+=(char const*) 14#: (0x5BE0A9B7EA06) sync.cpp:114 - potential_deadlock_detected 15#: (0x5BE0A9B8548E) sync.cpp:188 - push_lock<std::recursive_mutex> 16#: (0x5BE0A9B8548E) sync.cpp:212 - void EnterCritical<std::recursive_mutex>(char const*, char const*, int, std::recursive_mutex*, bool) 17#: (0x5BE0A935C582) unique_lock.h:150 - std::unique_lock<std::recursive_mutex>::try_lock() 18#: (0x5BE0A935C582) sync.h:162 - UniqueLock<AnnotatedMixin<std::recursive_mutex>, std::unique_lock<std::recursive_mutex> >::Enter(char const*, char const*, int) 19#: (0x5BE0A935C582) sync.h:183 - UniqueLock<AnnotatedMixin<std::recursive_mutex>, std::unique_lock<std::recursive_mutex> >::UniqueLock(AnnotatedMixin<std::recursive_mutex>&, char const*, char const*, int, bool) 20#: (0x5BE0A9487A92) net_processing.cpp:972 - PushInv 21#: (0x5BE0A94896E5) shared_ptr_base.h:1070 - std::__shared_count<(__gnu_cxx::_Lock_policy)2>::~__shared_count() 22#: (0x5BE0A94896E5) shared_ptr_base.h:1524 - ~__shared_ptr 23#: (0x5BE0A94896E5) shared_ptr.h:175 - ~shared_ptr 24#: (0x5BE0A94896E5) net_processing.cpp:2276 - operator() 25#: (0x5BE0A94896E5) net.h:1051 - ForEachNode<CConnman::CFullyConnectedOnly, (anonymous namespace)::PeerManagerImpl::RelayInv(CInv&, int)::<lambda(CNode*)>&> 26#: (0x5BE0A94896E5) net.h:1058 - ForEachNode<(anonymous namespace)::PeerManagerImpl::RelayInv(CInv&, int)::<lambda(CNode*)> > 27#: (0x5BE0A94896E5) net_processing.cpp:2269 - RelayInv 28#: (0x5BE0A98B7C03) blockprocessor.cpp:683 - llmq::CQuorumBlockProcessor::AddMineableCommitment(llmq::CFinalCommitment const&) 29#: (0x5BE0A98BE2E1) blockprocessor.cpp:338 - llmq::CQuorumBlockProcessor::UndoBlock(CBlock const&, gsl::not_null<CBlockIndex const*>) 30#: (0x5BE0A9809EA9) specialtxman.cpp:264 - CSpecialTxProcessor::UndoSpecialTxsInBlock(CBlock const&, CBlockIndex const*, std::optional<MNListUpdates>&) 31#: (0x5BE0A96FFB84) validation.cpp:1693 - CChainState::DisconnectBlock(CBlock const&, CBlockIndex const*, CCoinsViewCache&) 32#: (0x5BE0A9701481) validation.cpp:2726 - CChainState::DisconnectTip(BlockValidationState&, DisconnectedBlockTransactions*)
- Loading branch information