From 4c765516ba903c3670b8cad83e23fcc9dd2c3df6 Mon Sep 17 00:00:00 2001 From: "alex.sharov" Date: Sat, 21 Aug 2021 08:49:05 +0700 Subject: [PATCH] save --- txpool/pool.go | 3 ++- 1 file changed, 2 insertions(+), 1 deletion(-) diff --git a/txpool/pool.go b/txpool/pool.go index a1dce3cb6..ffdf541a9 100644 --- a/txpool/pool.go +++ b/txpool/pool.go @@ -185,6 +185,8 @@ func (sc *SendersCache) onNewTxs(coreDBTx kv.Tx, newTxs TxSlots) error { func (sc *SendersCache) onNewBlock(coreDBTx kv.Tx, stateChanges map[string]senderInfo, unwindTxs, minedTxs TxSlots, blockHeight uint64) error { //TODO: if see non-continuous block heigh - drop cache and reload from db sc.blockHeight.Store(blockHeight) + + //`loadSenders` goes by network to core - and it must be outside of SendersCache lock. But other methods must be locked sc.mergeStateChanges(stateChanges, unwindTxs, minedTxs) toLoad := sc.setTxSenderID(unwindTxs) diff, err := loadSenders(coreDBTx, toLoad) @@ -312,7 +314,6 @@ type TxPool struct { // fields for transaction propagation recentlyConnectedPeers *recentlyConnectedPeers newTxs chan Hashes - //lastTxPropagationTimestamp time.Time } func New(newTxs chan Hashes, db kv.RwDB) (*TxPool, error) {