2022-09-10 18:00:03 +00:00
|
|
|
package main
|
|
|
|
|
|
|
|
import (
|
|
|
|
"time"
|
|
|
|
|
2022-09-13 13:05:58 +00:00
|
|
|
"github.com/ledgerwatch/erigon-lib/etl"
|
2022-09-10 18:00:03 +00:00
|
|
|
"github.com/ledgerwatch/erigon-lib/kv/mdbx"
|
|
|
|
"github.com/ledgerwatch/erigon/eth/stagedsync/stages"
|
|
|
|
"github.com/ledgerwatch/log/v3"
|
|
|
|
)
|
|
|
|
|
2022-09-13 13:05:58 +00:00
|
|
|
func identityFuncForVerkleTree(k []byte, value []byte, _ etl.CurrentTableReader, next etl.LoadNextFunc) error {
|
|
|
|
return next(k, k, value)
|
2022-09-10 18:00:03 +00:00
|
|
|
}
|
|
|
|
|
2022-09-13 13:05:58 +00:00
|
|
|
/*func readAccountKey(tx kv.RwTx, address []byte) ([]byte, error) {
|
|
|
|
return tx.GetOne(PedersenHashedAccountsLookup, address)
|
|
|
|
}
|
2022-09-10 18:00:03 +00:00
|
|
|
|
2022-09-13 13:05:58 +00:00
|
|
|
func readStorageKey(tx kv.RwTx, address []byte, storageKey []byte) ([]byte, error) {
|
|
|
|
return tx.GetOne(PedersenHashedStorageLookup, append(address, storageKey...))
|
2022-09-10 18:00:03 +00:00
|
|
|
}
|
|
|
|
|
2022-09-13 13:05:58 +00:00
|
|
|
func readCodeKey(tx kv.RwTx, address []byte, index *uint256.Int) ([]byte, error) {
|
2022-09-10 18:00:03 +00:00
|
|
|
lookupKey := make([]byte, 24)
|
|
|
|
copy(lookupKey, address)
|
|
|
|
binary.BigEndian.PutUint32(lookupKey[20:], uint32(index.Uint64()))
|
2022-09-13 13:05:58 +00:00
|
|
|
return tx.GetOne(PedersenHashedCodeLookup, lookupKey)
|
|
|
|
}*/
|
2022-09-10 18:00:03 +00:00
|
|
|
|
|
|
|
func IncrementVerkleTree(cfg optionsCfg) error {
|
|
|
|
start := time.Now()
|
2022-09-21 22:33:48 +00:00
|
|
|
|
2022-09-10 18:00:03 +00:00
|
|
|
db, err := mdbx.Open(cfg.stateDb, log.Root(), true)
|
|
|
|
if err != nil {
|
|
|
|
log.Error("Error while opening database", "err", err.Error())
|
|
|
|
return err
|
|
|
|
}
|
|
|
|
defer db.Close()
|
|
|
|
|
|
|
|
vDb, err := mdbx.Open(cfg.verkleDb, log.Root(), false)
|
|
|
|
if err != nil {
|
|
|
|
log.Error("Error while opening db transaction", "err", err.Error())
|
|
|
|
return err
|
|
|
|
}
|
|
|
|
defer vDb.Close()
|
|
|
|
|
|
|
|
vTx, err := vDb.BeginRw(cfg.ctx)
|
|
|
|
if err != nil {
|
|
|
|
return err
|
|
|
|
}
|
|
|
|
defer vTx.Rollback()
|
|
|
|
|
|
|
|
tx, err := db.BeginRo(cfg.ctx)
|
|
|
|
if err != nil {
|
|
|
|
return err
|
|
|
|
}
|
|
|
|
defer tx.Rollback()
|
|
|
|
if err := initDB(vTx); err != nil {
|
|
|
|
return err
|
|
|
|
}
|
|
|
|
|
2022-09-16 13:11:13 +00:00
|
|
|
from, err := stages.GetStageProgress(vTx, stages.VerkleTrie)
|
|
|
|
if err != nil {
|
|
|
|
return err
|
|
|
|
}
|
|
|
|
|
2022-09-13 13:05:58 +00:00
|
|
|
to, err := stages.GetStageProgress(tx, stages.Execution)
|
2022-09-10 18:00:03 +00:00
|
|
|
if err != nil {
|
|
|
|
return err
|
|
|
|
}
|
2022-09-21 22:33:48 +00:00
|
|
|
verkleWriter := NewVerkleTreeWriter(vTx, cfg.tmpdir)
|
|
|
|
defer verkleWriter.Close()
|
|
|
|
if err := incrementAccount(vTx, tx, cfg, verkleWriter, from, to); err != nil {
|
2022-09-10 18:00:03 +00:00
|
|
|
return err
|
|
|
|
}
|
2022-09-21 22:33:48 +00:00
|
|
|
if err := incrementStorage(vTx, tx, cfg, verkleWriter, from, to); err != nil {
|
2022-09-10 18:00:03 +00:00
|
|
|
return err
|
|
|
|
}
|
2022-09-16 13:11:13 +00:00
|
|
|
if err := stages.SaveStageProgress(vTx, stages.VerkleTrie, to); err != nil {
|
|
|
|
return err
|
|
|
|
}
|
|
|
|
|
2022-09-13 13:05:58 +00:00
|
|
|
log.Info("Finished", "elapesed", time.Since(start))
|
2022-09-10 18:00:03 +00:00
|
|
|
return vTx.Commit()
|
|
|
|
}
|