forked from cerc-io/plugeth
		
	eth: update higest block we know during the sync if a higher was found (#16283)
* eth: update higest block we know during the sync if a higher was found * eth: avoid useless sync in fast sync
This commit is contained in:
		
							parent
							
								
									307846d046
								
							
						
					
					
						commit
						77da203547
					
				| @ -1296,6 +1296,14 @@ func (d *Downloader) processHeaders(origin uint64, pivot uint64, td *big.Int) er | |||||||
| 				headers = headers[limit:] | 				headers = headers[limit:] | ||||||
| 				origin += uint64(limit) | 				origin += uint64(limit) | ||||||
| 			} | 			} | ||||||
|  | 
 | ||||||
|  | 			// Update the highest block number we know if a higher one is found.
 | ||||||
|  | 			d.syncStatsLock.Lock() | ||||||
|  | 			if d.syncStatsChainHeight < origin { | ||||||
|  | 				d.syncStatsChainHeight = origin - 1 | ||||||
|  | 			} | ||||||
|  | 			d.syncStatsLock.Unlock() | ||||||
|  | 
 | ||||||
| 			// Signal the content downloaders of the availablility of new tasks
 | 			// Signal the content downloaders of the availablility of new tasks
 | ||||||
| 			for _, ch := range []chan bool{d.bodyWakeCh, d.receiptWakeCh} { | 			for _, ch := range []chan bool{d.bodyWakeCh, d.receiptWakeCh} { | ||||||
| 				select { | 				select { | ||||||
|  | |||||||
| @ -188,6 +188,14 @@ func (pm *ProtocolManager) synchronise(peer *peer) { | |||||||
| 		atomic.StoreUint32(&pm.fastSync, 1) | 		atomic.StoreUint32(&pm.fastSync, 1) | ||||||
| 		mode = downloader.FastSync | 		mode = downloader.FastSync | ||||||
| 	} | 	} | ||||||
|  | 
 | ||||||
|  | 	if mode == downloader.FastSync { | ||||||
|  | 		// Make sure the peer's total difficulty we are synchronizing is higher.
 | ||||||
|  | 		if pm.blockchain.GetTdByHash(pm.blockchain.CurrentFastBlock().Hash()).Cmp(pTd) >= 0 { | ||||||
|  | 			return | ||||||
|  | 		} | ||||||
|  | 	} | ||||||
|  | 
 | ||||||
| 	// Run the sync cycle, and disable fast sync if we've went past the pivot block
 | 	// Run the sync cycle, and disable fast sync if we've went past the pivot block
 | ||||||
| 	if err := pm.downloader.Synchronise(peer.id, pHead, pTd, mode); err != nil { | 	if err := pm.downloader.Synchronise(peer.id, pHead, pTd, mode); err != nil { | ||||||
| 		return | 		return | ||||||
|  | |||||||
		Loading…
	
		Reference in New Issue
	
	Block a user