diff --git a/src/net.h b/src/net.h index 77aaaac5b14832..c664738e3d8a03 100644 --- a/src/net.h +++ b/src/net.h @@ -990,8 +990,8 @@ class CNode std::vector vAddrToSend; std::unique_ptr m_addr_known{nullptr}; bool fGetAddr{false}; - std::chrono::microseconds m_next_addr_send GUARDED_BY(cs_sendProcessing){0}; - std::chrono::microseconds m_next_local_addr_send GUARDED_BY(cs_sendProcessing){0}; + std::atomic m_next_addr_send{std::chrono::microseconds{0}}; + std::atomic m_next_local_addr_send{std::chrono::microseconds{0}}; // List of block ids we still have announce. // There is no final sorting before sending, as they are always sent immediately diff --git a/src/net_processing.cpp b/src/net_processing.cpp index 7c4ba458c3a620..68478df8d8719b 100644 --- a/src/net_processing.cpp +++ b/src/net_processing.cpp @@ -4085,14 +4085,14 @@ bool PeerManager::SendMessages(CNode* pto) // Address refresh broadcast auto current_time = GetTime(); - if (pto->RelayAddrsWithConn() && !::ChainstateActive().IsInitialBlockDownload() && pto->m_next_local_addr_send < current_time) { + if (pto->RelayAddrsWithConn() && !::ChainstateActive().IsInitialBlockDownload() && pto->m_next_local_addr_send.load` < current_time) { // If we've sent before, clear the bloom filter for the peer, so that our // self-announcement will actually go out. // This might be unnecessary if the bloom filter has already rolled // over since our last self-announcement, but there is only a small // bandwidth cost that we can incur by doing this (which happens // once a day on average). - if (pto->m_next_local_addr_send != std::chrono::microseconds::zero()) { + if (pto->m_next_local_addr_send.load() != std::chrono::microseconds::zero()) { pto->m_addr_known->reset(); } AdvertiseLocal(pto); @@ -4102,7 +4102,7 @@ bool PeerManager::SendMessages(CNode* pto) // // Message: addr // - if (pto->RelayAddrsWithConn() && pto->m_next_addr_send < current_time) { + if (pto->RelayAddrsWithConn() && pto->m_next_addr_send.load() < current_time) { pto->m_next_addr_send = PoissonNextSend(current_time, AVG_ADDRESS_BROADCAST_INTERVAL); std::vector vAddr; vAddr.reserve(pto->vAddrToSend.size());