aboutsummaryrefslogtreecommitdiffstats
path: root/blockpool/peers.go
Commit message (Collapse)AuthorAgeFilesLines
* bugfixes for headsection deadlockszelig2015-04-111-7/+15
| | | | | - switchC initialised as closed - move select in setChainInfoFromBlock out of peer lock
* td update from nodezelig2015-04-101-27/+58
| | | | | | | - reorg and simplify AddBlock - introduce nodeCache - TestPeerPromotionByTdOnBlock unskipped and passes - move switchC/idleC channel creation around: solves deadlock (now respects the contract with section process: either can activate or complete at any one time)
* Disabled TD checkobscuren2015-04-091-0/+2
| | | | | @zelig: Temporarily commented out TD check untill the rest of the network has been fixed.
* separate lock for blacklistzelig2015-04-091-3/+6
|
* oops peer unlocked before return - fixes deadlockzelig2015-04-091-0/+1
|
* uncomment future block TD check, add test for skipping TD check on future blockzelig2015-04-091-2/+2
|
* fix deadlock issue in AddBlockzelig2015-04-091-14/+17
| | | | | | - add peer switch channel arg to activateChain - no peer locking within - proper locking in AddBlock - fixes deadlock issue - comment out TD check and skip incorrect TD test again for hotfix
* fix blockpool deadlockzelig2015-04-091-9/+1
| | | | | | - do not break from headsection on error [remove peer after protocol quit will close switchC, until then head block can arrive and block on channel while keeping peers lock causing a deadlock.] - more careful locking in AddBlock
* fix TestPoolStatus test crashing, skip tests failing (due to @obscuren hotfixes)zelig2015-04-091-0/+1
|
* Disabled peer TD check to support suspended blocks (Future blocks)obscuren2015-04-041-2/+2
| | | | | | @zelig When blocks are in the future they'll be cached and processed at a later time. Because of this the returned TD will be much lower than the broadcasted TD.
* proper locking to prevent "parent unknown" INVALID blocks due to race in ↵zelig2015-04-021-5/+4
| | | | peer head info update
* proper locking to prevent close of closed channel crash when multiple mining ↵zelig2015-04-021-3/+7
| | | | peers compete
* bugfix with idle too long triggered after peer switchzelig2015-03-251-4/+5
| | | | | | - reset bestIdleTimer when launching head section process - log chain head events - common.Hash key in activateChain map
* fixed bad unclesobscuren2015-03-241-1/+2
|
* Idle too long error incorrectly triggered even when peer sending new blockszelig2015-03-221-24/+22
| | | | | | | | | - fix status chain map uses common.Hash as key - add badPeers increment to IncorrectTD errors (forgotten) - signal head info update to head section process even if parent hash is not in pool (inserted), so that idle timer can be set to nil - suicideC -> peer.headInfoTimer - quit -> peer.bestIdleTimer - and they are properly set from within getBlockHashes and handleSection
* fix common.Hash conversionzelig2015-03-201-0/+2
|
* improve documentation and move one testzelig2015-03-201-5/+18
|
* check and penalise td misreportingzelig2015-03-201-1/+6
| | | | | | - add ErrIncorrectTD - checkTD called after insertChain successful - fix tests, use blockPoolTester.tds to map block index to TD
* fix missing hexification on IdleTooLong error logzelig2015-03-201-1/+1
|
* use own total difficulty to limit best peerzelig2015-03-201-9/+6
| | | | | | | | | - update blockpool td by subscribing to ChainHeadEvent - if ahead of best peer, demote it - addPeer now take own td as current td - removePeer now take own td as current td - add relevant tests to peers_test - eth: backend now calls blockpool with eth.eventMux and chainManager.Td
* peer suspension to disallow reconnect after disconnect on fatal error for ↵zelig2015-03-201-10/+39
| | | | set period (PeerSuspensionInterval)
* updated blockpoolobscuren2015-03-171-25/+24
|
* Moved ethutil => commonobscuren2015-03-161-3/+3
|
* fix wonky head section loop; correct status countszelig2015-03-061-23/+31
|
* partial fix to idle best peer issuezelig2015-03-041-9/+19
| | | | | | - best peer cannot be idle for more than idleBestPeerTimeout - introduce ErrIdleTooLong fatal error - modify default values
* log when added peer is behind (hash found in blockchain)zelig2015-03-031-0/+1
|
* - fix peer disconnect by adding severity function to errszelig2015-03-031-1/+1
| | | | | | - improve logging - suicide -> removeChain - improved status BlocksInPool calculation
* major rewrite, reorg of blockpool + new featureszelig2015-02-251-0/+536
- blockpool moves to its own package - uses errs pkg for its own coded errors - publicly settable config of params (time intervals and batchsizes) - test helpers in subpackage - optional TD in blocks used now to update peers chain info - major improvement in algorithm - fix fragility and sync/parallelisation bugs - implement status for reporting on sync status (peers/hashes/blocks etc) - several tests added and further corner cases covered