diff --git a/pkg/core/blockchain.go b/pkg/core/blockchain.go index 719af0115..896751e38 100644 --- a/pkg/core/blockchain.go +++ b/pkg/core/blockchain.go @@ -904,6 +904,8 @@ func (bc *Blockchain) GetStateSyncModule() blockchainer.StateSync { func (bc *Blockchain) storeBlock(block *block.Block, txpool *mempool.Pool) error { var ( cache = bc.dao.GetWrapped() + blockCache = bc.dao.GetWrapped() + aerCache = bc.dao.GetWrapped() appExecResults = make([]*state.AppExecResult, 0, 2+len(block.Transactions)) aerchan = make(chan *state.AppExecResult, len(block.Transactions)/8) // Tested 8 and 4 with no practical difference, but feel free to test more and tune. aerdone = make(chan error) @@ -911,7 +913,7 @@ func (bc *Blockchain) storeBlock(block *block.Block, txpool *mempool.Pool) error ) go func() { var ( - kvcache = cache.GetWrapped() + kvcache = blockCache writeBuf = io.NewBufBinWriter() ) if err := kvcache.StoreAsBlock(block, writeBuf); err != nil { @@ -960,15 +962,11 @@ func (bc *Blockchain) storeBlock(block *block.Block, txpool *mempool.Pool) error writeBuf.Reset() } } - _, err := kvcache.Persist() - if err != nil { - blockdone <- err - } close(blockdone) }() go func() { var ( - kvcache = cache.GetWrapped() + kvcache = aerCache writeBuf = io.NewBufBinWriter() err error appendBlock bool @@ -1010,11 +1008,6 @@ func (bc *Blockchain) storeBlock(block *block.Block, txpool *mempool.Pool) error return } } - - _, err = kvcache.Persist() - if err != nil { - aerdone <- err - } close(aerdone) }() aer, err := bc.runPersist(bc.contracts.GetPersistScript(), block, cache, trigger.OnPersist) @@ -1129,6 +1122,16 @@ func (bc *Blockchain) storeBlock(block *block.Block, txpool *mempool.Pool) error } bc.lock.Lock() + _, err = blockCache.Persist() + if err != nil { + bc.lock.Unlock() + return err + } + _, err = aerCache.Persist() + if err != nil { + bc.lock.Unlock() + return err + } _, err = cache.Persist() if err != nil { bc.lock.Unlock() diff --git a/pkg/core/native/native_neo.go b/pkg/core/native/native_neo.go index 133870c54..9df6e468b 100644 --- a/pkg/core/native/native_neo.go +++ b/pkg/core/native/native_neo.go @@ -434,7 +434,7 @@ func (n *NEO) balanceFromBytes(si *state.StorageItem) (*big.Int, error) { } func (n *NEO) distributeGas(ic *interop.Context, h util.Uint160, acc *state.NEOBalance) error { - if ic.Block == nil || ic.Block.Index == 0 { + if ic.Block == nil || ic.Block.Index == 0 || ic.Block.Index == acc.BalanceHeight { return nil } gen, err := n.calculateBonus(ic.DAO, acc.VoteTo, &acc.Balance, acc.BalanceHeight, ic.Block.Index)