From e26055190ea2ac64d094b270366eb5f78576e17f Mon Sep 17 00:00:00 2001 From: Roman Khimov Date: Tue, 18 Oct 2022 18:30:52 +0300 Subject: [PATCH] network: check inv against currently processed transactions Sometimes we already have it, but it's not yet processed, so we can save on getdata request. It only affects very high-speed networks like 4-1 scenario and it doesn't affect it a lot, but still we can do it. --- pkg/network/server.go | 9 +++++++-- 1 file changed, 7 insertions(+), 2 deletions(-) diff --git a/pkg/network/server.go b/pkg/network/server.go index 57aa06ffe..ee5fc746c 100644 --- a/pkg/network/server.go +++ b/pkg/network/server.go @@ -111,7 +111,7 @@ type ( txCallback func(*transaction.Transaction) txCbEnabled atomic.Bool - txInLock sync.Mutex + txInLock sync.RWMutex txin chan *transaction.Transaction txInMap map[util.Uint256]struct{} @@ -760,7 +760,12 @@ func (s *Server) handlePong(p Peer, pong *payload.Ping) error { func (s *Server) handleInvCmd(p Peer, inv *payload.Inventory) error { var reqHashes = inv.Hashes[:0] var typExists = map[payload.InventoryType]func(util.Uint256) bool{ - payload.TXType: s.mempool.ContainsKey, + payload.TXType: func(h util.Uint256) bool { + s.txInLock.RLock() + _, ok := s.txInMap[h] + s.txInLock.RUnlock() + return ok || s.mempool.ContainsKey(h) + }, payload.BlockType: s.chain.HasBlock, payload.ExtensibleType: func(h util.Uint256) bool { cp := s.extensiblePool.Get(h)