From 03216e8749041c1f97966ae33248828e295bdf26 Mon Sep 17 00:00:00 2001 From: arkpar Date: Sun, 19 Jul 2015 23:03:37 +0200 Subject: [PATCH] prevent re-downloading of already queued blocks --- libethereum/BlockChainSync.cpp | 10 +++++++++- 1 file changed, 9 insertions(+), 1 deletion(-) diff --git a/libethereum/BlockChainSync.cpp b/libethereum/BlockChainSync.cpp index 0c8f9cc68..6cf84b588 100644 --- a/libethereum/BlockChainSync.cpp +++ b/libethereum/BlockChainSync.cpp @@ -967,7 +967,15 @@ void PV61Sync::completeSubchain(std::shared_ptr _peer, unsigned _n //Done chain-get m_syncingNeededBlocks.clear(); for (auto h = m_completeChainMap.rbegin(); h != m_completeChainMap.rend(); ++h) - m_syncingNeededBlocks.insert(m_syncingNeededBlocks.end(), h->second.hashes.begin(), h->second.hashes.end()); + if (!host().chain().isKnown(h->second.hashes.front()) && !host().chain().isKnown(h->second.hashes.back())) + { + if (host().bq().blockStatus(h->second.hashes.front()) == QueueStatus::Unknown || host().bq().blockStatus(h->second.hashes.back()) == QueueStatus::Unknown) + m_syncingNeededBlocks.insert(m_syncingNeededBlocks.end(), h->second.hashes.begin(), h->second.hashes.end()); + else + for (h256 const& hash: h->second.hashes) + if (!host().chain().isKnown(hash) && host().bq().blockStatus(hash) == QueueStatus::Unknown) + m_syncingNeededBlocks.insert(m_syncingNeededBlocks.end(), hash); + } transition(syncer, SyncState::Blocks); } else