forked from cerc-io/plugeth
eth: fix #1371, double lock during block/txn known set limitation
This commit is contained in:
parent
60454da650
commit
1ae80aaf64
14
eth/peer.go
14
eth/peer.go
@ -94,11 +94,8 @@ func (p *peer) SetTd(td *big.Int) {
|
|||||||
// never be propagated to this particular peer.
|
// never be propagated to this particular peer.
|
||||||
func (p *peer) MarkBlock(hash common.Hash) {
|
func (p *peer) MarkBlock(hash common.Hash) {
|
||||||
// If we reached the memory allowance, drop a previously known block hash
|
// If we reached the memory allowance, drop a previously known block hash
|
||||||
if p.knownBlocks.Size() >= maxKnownBlocks {
|
for p.knownBlocks.Size() >= maxKnownBlocks {
|
||||||
p.knownBlocks.Each(func(item interface{}) bool {
|
p.knownBlocks.Pop()
|
||||||
p.knownBlocks.Remove(item)
|
|
||||||
return p.knownBlocks.Size() >= maxKnownBlocks
|
|
||||||
})
|
|
||||||
}
|
}
|
||||||
p.knownBlocks.Add(hash)
|
p.knownBlocks.Add(hash)
|
||||||
}
|
}
|
||||||
@ -107,11 +104,8 @@ func (p *peer) MarkBlock(hash common.Hash) {
|
|||||||
// will never be propagated to this particular peer.
|
// will never be propagated to this particular peer.
|
||||||
func (p *peer) MarkTransaction(hash common.Hash) {
|
func (p *peer) MarkTransaction(hash common.Hash) {
|
||||||
// If we reached the memory allowance, drop a previously known transaction hash
|
// If we reached the memory allowance, drop a previously known transaction hash
|
||||||
if p.knownTxs.Size() >= maxKnownTxs {
|
for p.knownTxs.Size() >= maxKnownTxs {
|
||||||
p.knownTxs.Each(func(item interface{}) bool {
|
p.knownTxs.Pop()
|
||||||
p.knownTxs.Remove(item)
|
|
||||||
return p.knownTxs.Size() >= maxKnownTxs
|
|
||||||
})
|
|
||||||
}
|
}
|
||||||
p.knownTxs.Add(hash)
|
p.knownTxs.Add(hash)
|
||||||
}
|
}
|
||||||
|
Loading…
Reference in New Issue
Block a user