aboutsummaryrefslogtreecommitdiffstats
diff options
context:
space:
mode:
authorPéter Szilágyi <peterke@gmail.com>2015-05-16 01:54:10 +0800
committerPéter Szilágyi <peterke@gmail.com>2015-05-16 01:54:10 +0800
commitf3ae8f50a5dfafa667fbe5e6a6574e69162d5ee6 (patch)
tree0864261e6b3de3294689364ca5c9572d35f45e1e
parent98998534cb0f415fb85826d60607652240022c57 (diff)
downloaddexon-f3ae8f50a5dfafa667fbe5e6a6574e69162d5ee6.tar.gz
dexon-f3ae8f50a5dfafa667fbe5e6a6574e69162d5ee6.tar.zst
dexon-f3ae8f50a5dfafa667fbe5e6a6574e69162d5ee6.zip
eth/downloader: circumvent download race between crosscheck and hashes
-rw-r--r--eth/downloader/downloader.go12
1 files changed, 7 insertions, 5 deletions
diff --git a/eth/downloader/downloader.go b/eth/downloader/downloader.go
index a0a5b20a2..1bc81406c 100644
--- a/eth/downloader/downloader.go
+++ b/eth/downloader/downloader.go
@@ -284,12 +284,14 @@ func (d *Downloader) fetchHashes(p *peer, h common.Hash) error {
}
if !done {
// Try and fetch a random block to verify the hash batch
- cross := inserts[rand.Intn(len(inserts))]
- glog.V(logger.Detail).Infof("Cross checking (%s) with %x", active.id, cross)
-
- d.checks[cross] = time.Now().Add(blockTTL)
- active.getBlocks([]common.Hash{cross})
+ // Skip the last hash as the cross check races with the next hash fetch
+ if len(inserts) > 1 {
+ cross := inserts[rand.Intn(len(inserts)-1)]
+ glog.V(logger.Detail).Infof("Cross checking (%s) with %x", active.id, cross)
+ d.checks[cross] = time.Now().Add(blockTTL)
+ active.getBlocks([]common.Hash{cross})
+ }
// Also fetch a fresh
active.getHashes(head)
continue