aboutsummaryrefslogtreecommitdiffstats
path: root/dex/downloader/downloader.go
diff options
context:
space:
mode:
authorSonic <sonic@dexon.org>2018-12-27 16:25:45 +0800
committerWei-Ning Huang <w@byzantine-lab.io>2019-06-12 17:27:20 +0800
commita7bb33e5dba4f4b24a848c64954bf1659583e5a4 (patch)
tree22c15d0d79007844537575f93aea88f85773cf90 /dex/downloader/downloader.go
parent31e96869300a9b5e12e5eac9f47e6f1985e8894b (diff)
downloadgo-tangerine-a7bb33e5dba4f4b24a848c64954bf1659583e5a4.tar
go-tangerine-a7bb33e5dba4f4b24a848c64954bf1659583e5a4.tar.gz
go-tangerine-a7bb33e5dba4f4b24a848c64954bf1659583e5a4.tar.bz2
go-tangerine-a7bb33e5dba4f4b24a848c64954bf1659583e5a4.tar.lz
go-tangerine-a7bb33e5dba4f4b24a848c64954bf1659583e5a4.tar.xz
go-tangerine-a7bb33e5dba4f4b24a848c64954bf1659583e5a4.tar.zst
go-tangerine-a7bb33e5dba4f4b24a848c64954bf1659583e5a4.zip
dex/downloader: fix bug when syncing (#106)
Since blocks will interleave around round change, we will probably need to verify blocks at previous round.
Diffstat (limited to 'dex/downloader/downloader.go')
-rw-r--r--dex/downloader/downloader.go15
1 files changed, 13 insertions, 2 deletions
diff --git a/dex/downloader/downloader.go b/dex/downloader/downloader.go
index 809fe7e4a..6ff8c122e 100644
--- a/dex/downloader/downloader.go
+++ b/dex/downloader/downloader.go
@@ -480,9 +480,9 @@ func (d *Downloader) syncWithPeer(p *peerConnection, hash common.Hash, number ui
return fmt.Errorf("origin header not exists, number: %d", origin)
}
- // prepare state origin - 2
+ // prepare state origin - 3
d.gov = newGovernance(govState)
- for i := uint64(0); i < 3; i++ {
+ for i := uint64(0); i < 4; i++ {
if originHeader.Round >= i {
h := d.gov.GetRoundHeight(originHeader.Round - i)
s, err := d.lightchain.GetGovStateByNumber(h)
@@ -494,6 +494,17 @@ func (d *Downloader) syncWithPeer(p *peerConnection, hash common.Hash, number ui
}
d.verifierCache = dexCore.NewTSigVerifierCache(d.gov, 5)
+
+ // warm up verifierCache
+ if originHeader.Round > 0 {
+ ok, err := d.verifierCache.Update(originHeader.Round - 1)
+ if err != nil {
+ return err
+ }
+ if !ok {
+ return fmt.Errorf("can not update verifier cache")
+ }
+ }
}
// Initiate the sync using a concurrent header and content retrieval algorithm