|
|
@ -385,10 +385,11 @@ void FindNextBlocksToDownload(NodeId nodeid, unsigned int count, std::vector<CBl
|
|
|
|
|
|
|
|
|
|
|
|
std::vector<CBlockIndex*> vToFetch;
|
|
|
|
std::vector<CBlockIndex*> vToFetch;
|
|
|
|
CBlockIndex *pindexWalk = state->pindexLastCommonBlock;
|
|
|
|
CBlockIndex *pindexWalk = state->pindexLastCommonBlock;
|
|
|
|
// Never fetch further than the best block we know the peer has, or more than BLOCK_DOWNLOAD_WINDOW + 1 beyond our
|
|
|
|
// Never fetch further than the best block we know the peer has, or more than BLOCK_DOWNLOAD_WINDOW + 1 beyond the last
|
|
|
|
// current tip. The +1 is so we can detect stalling, namely if we would be able to download that next block if the
|
|
|
|
// linked block we have in common with this peer. The +1 is so we can detect stalling, namely if we would be able to
|
|
|
|
// window were 1 larger.
|
|
|
|
// download that next block if the window were 1 larger.
|
|
|
|
int nMaxHeight = std::min<int>(state->pindexBestKnownBlock->nHeight, chainActive.Height() + BLOCK_DOWNLOAD_WINDOW + 1);
|
|
|
|
int nWindowEnd = state->pindexLastCommonBlock->nHeight + BLOCK_DOWNLOAD_WINDOW;
|
|
|
|
|
|
|
|
int nMaxHeight = std::min<int>(state->pindexBestKnownBlock->nHeight, nWindowEnd + 1);
|
|
|
|
NodeId waitingfor = -1;
|
|
|
|
NodeId waitingfor = -1;
|
|
|
|
while (pindexWalk->nHeight < nMaxHeight) {
|
|
|
|
while (pindexWalk->nHeight < nMaxHeight) {
|
|
|
|
// Read up to 128 (or more, if more blocks than that are needed) successors of pindexWalk (towards
|
|
|
|
// Read up to 128 (or more, if more blocks than that are needed) successors of pindexWalk (towards
|
|
|
@ -411,7 +412,7 @@ void FindNextBlocksToDownload(NodeId nodeid, unsigned int count, std::vector<CBl
|
|
|
|
state->pindexLastCommonBlock = pindex;
|
|
|
|
state->pindexLastCommonBlock = pindex;
|
|
|
|
} else if (mapBlocksInFlight.count(pindex->GetBlockHash()) == 0) {
|
|
|
|
} else if (mapBlocksInFlight.count(pindex->GetBlockHash()) == 0) {
|
|
|
|
// The block is not already downloaded, and not yet in flight.
|
|
|
|
// The block is not already downloaded, and not yet in flight.
|
|
|
|
if (pindex->nHeight > chainActive.Height() + (int)BLOCK_DOWNLOAD_WINDOW) {
|
|
|
|
if (pindex->nHeight > nWindowEnd) {
|
|
|
|
// We reached the end of the window.
|
|
|
|
// We reached the end of the window.
|
|
|
|
if (vBlocks.size() == 0 && waitingfor != nodeid) {
|
|
|
|
if (vBlocks.size() == 0 && waitingfor != nodeid) {
|
|
|
|
// We aren't able to fetch anything, but we would be if the download window was one larger.
|
|
|
|
// We aren't able to fetch anything, but we would be if the download window was one larger.
|
|
|
|