erigon-pulse/core/state/cached_writer.go
ledgerwatch 5ea590c18e
State cache switching writes to reads during commit (#1368)
* State cache init

* More code

* Fix lint

* More tests

* More tests

* More tests

* Fix test

* Transformations

* remove writeQueue, before fixing the tests

* Fix tests

* Add more tests, incarnation to the code items

* Fix lint

* Fix lint

* Remove shards prototype, add incarnation to the state reader code

* Clean up and replace cache in call_traces stage

* fix flaky test

* Save changes

* Readers to use addrHash, writes - addresses

* Fix lint

* Fix lint

* More accurate tracking of size

* Optimise for smaller write batches

* Attempt to integrate state cache into Execution stage

* cacheSize to default flags

* Print correct cache sizes and batch sizes

* cacheSize in the integration

* Fix tests

* Fix lint

* Remove print

* Fix exec stage

* Fix test

* Refresh sequence on write

* No double increment

* heap.Remove

* Try to fix alignment

* Refactoring, adding hashItems

* More changes

* Fix compile errors

* Fix lint

* Wrapping cached reader

* Wrap writer into cached writer

* Turn state cache off by default

* Fix plain state writer

* Fix for code/storage mixup

* Fix tests

* Fix clique test

* Better fix for the tests

* Add test and fix some more

* Fix compile error|

* More functions

* Fixes

* Fix for the tests

* sepatate DeletedFlag and AbsentFlag

* Minor fixes

* Test refactoring

* More changes

* Fix some tests

* More test fixes

* More test fixes

* Fix lint

* Move blockchain_test to be able to use stagedsync

* More fixes

* Fixes and cleanup

* Fix tests in turbo/stages

* Fix lint

* Fix lint

* Intemediate

* Fix tests

* Intemediate

* More fixes

* Compilation fixes

* More fixes

* Fix compile errors

* More test fixes

* More fixes

* More test fixes

* Fix compile error

* Fixes

* Fix

* Fix

* More fixes

* Fixes

* More fixes and cleanup

* Further fix

* Check gas used and bloom with header

Co-authored-by: Alexey Sharp <alexeysharp@Alexeys-iMac.local>
2020-12-08 09:44:29 +00:00

73 lines
2.2 KiB
Go

package state
import (
"context"
"github.com/holiman/uint256"
"github.com/ledgerwatch/turbo-geth/common"
"github.com/ledgerwatch/turbo-geth/core/types/accounts"
"github.com/ledgerwatch/turbo-geth/turbo/shards"
)
// CachedWriter is a wrapper for an instance of type StateWriter
type CachedWriter struct {
w WriterWithChangeSets
cache *shards.StateCache
}
// NewCachedWriter wraps a given state writer into a cached writer
func NewCachedWriter(w WriterWithChangeSets, cache *shards.StateCache) *CachedWriter {
return &CachedWriter{w: w, cache: cache}
}
func (cw *CachedWriter) UpdateAccountData(ctx context.Context, address common.Address, original, account *accounts.Account) error {
if err := cw.w.UpdateAccountData(ctx, address, original, account); err != nil {
return err
}
cw.cache.SetAccountWrite(address.Bytes(), account)
return nil
}
func (cw *CachedWriter) UpdateAccountCode(address common.Address, incarnation uint64, codeHash common.Hash, code []byte) error {
if err := cw.w.UpdateAccountCode(address, incarnation, codeHash, code); err != nil {
return err
}
cw.cache.SetCodeWrite(address.Bytes(), incarnation, code)
return nil
}
func (cw *CachedWriter) DeleteAccount(ctx context.Context, address common.Address, original *accounts.Account) error {
if err := cw.w.DeleteAccount(ctx, address, original); err != nil {
return err
}
cw.cache.SetAccountDelete(address.Bytes())
return nil
}
func (cw *CachedWriter) WriteAccountStorage(ctx context.Context, address common.Address, incarnation uint64, key *common.Hash, original, value *uint256.Int) error {
if err := cw.w.WriteAccountStorage(ctx, address, incarnation, key, original, value); err != nil {
return err
}
if *original == *value {
return nil
}
if value.IsZero() {
cw.cache.SetStorageDelete(address.Bytes(), incarnation, key.Bytes())
} else {
cw.cache.SetStorageWrite(address.Bytes(), incarnation, key.Bytes(), value.Bytes())
}
return nil
}
func (cw *CachedWriter) CreateContract(address common.Address) error {
return cw.w.CreateContract(address)
}
func (cw *CachedWriter) WriteChangeSets() error {
return cw.w.WriteChangeSets()
}
func (cw *CachedWriter) WriteHistory() error {
return cw.w.WriteHistory()
}