From 73c8b1294a0b47d57b045d3a60c8609e0cce5b1a Mon Sep 17 00:00:00 2001 From: SChernykh Date: Tue, 7 Sep 2021 12:56:22 +0200 Subject: [PATCH] P2PServer: connect to peers from the event loop thread Better thread safety --- src/p2p_server.cpp | 10 +++++++--- src/p2p_server.h | 1 + 2 files changed, 8 insertions(+), 3 deletions(-) diff --git a/src/p2p_server.cpp b/src/p2p_server.cpp index b3c7c4d..bc74b84 100644 --- a/src/p2p_server.cpp +++ b/src/p2p_server.cpp @@ -41,6 +41,7 @@ P2PServer::P2PServer(p2pool* pool) , m_pool(pool) , m_cache(new BlockCache()) , m_cacheLoaded(false) + , m_initialPeerList(pool->params().m_p2pPeerList) , m_rd{} , m_rng(m_rd()) , m_block(new PoolBlock()) @@ -76,16 +77,14 @@ P2PServer::P2PServer(p2pool* pool) } m_timer.data = this; - err = uv_timer_start(&m_timer, on_timer, 10000, 2000); + err = uv_timer_start(&m_timer, on_timer, 1000, 2000); if (err) { LOGERR(1, "failed to start timer, error " << uv_err_name(err)); panic(); } load_saved_peer_list(); - start_listening(pool->params().m_p2pAddresses); - connect_to_peers(pool->params().m_p2pPeerList); } P2PServer::~P2PServer() @@ -579,6 +578,11 @@ void P2PServer::print_status() void P2PServer::on_timer() { + if (!m_initialPeerList.empty()) { + connect_to_peers(m_initialPeerList); + m_initialPeerList.clear(); + } + flush_cache(); download_missing_blocks(); update_peer_list(); diff --git a/src/p2p_server.h b/src/p2p_server.h index e75bfe5..1b7f36b 100644 --- a/src/p2p_server.h +++ b/src/p2p_server.h @@ -124,6 +124,7 @@ private: p2pool* m_pool; BlockCache* m_cache; bool m_cacheLoaded; + std::string m_initialPeerList; uv_rwlock_t m_cachedBlocksLock; std::unordered_map m_cachedBlocks;