Skip to content

Commit

Permalink
add debug traces
Browse files Browse the repository at this point in the history
  • Loading branch information
gballet committed Mar 26, 2024
1 parent a774d16 commit 1784337
Show file tree
Hide file tree
Showing 3 changed files with 11 additions and 4 deletions.
2 changes: 2 additions & 0 deletions core/blockchain.go
Original file line number Diff line number Diff line change
Expand Up @@ -1767,6 +1767,8 @@ func (bc *BlockChain) insertChain(chain types.Blocks, setHead bool) (int, error)
// is the fork block and that the conversion needs to be marked at started.
if !bc.stateCache.InTransition() && !bc.stateCache.Transitioned() {
bc.stateCache.StartVerkleTransition(parent.Root, emptyVerkleRoot, bc.Config(), bc.Config().PragueTime, parent.Root)
} else {
log.Debug("skipped initialization")
}
}
if parent.Number.Uint64() == conversionBlock {
Expand Down
5 changes: 5 additions & 0 deletions core/state/database.go
Original file line number Diff line number Diff line change
Expand Up @@ -19,6 +19,7 @@ package state
import (
"errors"
"fmt"
"runtime/debug"

"github.com/ethereum/go-ethereum/common"
"github.com/ethereum/go-ethereum/common/lru"
Expand Down Expand Up @@ -237,6 +238,7 @@ func (db *cachingDB) StartVerkleTransition(originalRoot, translatedRoot common.H
if pragueTime != nil {
chainConfig.PragueTime = pragueTime
}
debug.PrintStack()
}

func (db *cachingDB) ReorgThroughVerkleTransition() {
Expand Down Expand Up @@ -355,6 +357,7 @@ func (db *cachingDB) OpenTrie(root common.Hash) (Trie, error) {
// If the verkle conversion has ended, return a single
// verkle trie.
if db.CurrentTransitionState.ended {
debug.PrintStack()
log.Debug("transition ended, returning a simple verkle tree")
return vkt, nil
}
Expand Down Expand Up @@ -566,6 +569,8 @@ func (db *cachingDB) LoadTransitionState(root common.Hash) {
// as a verkle database.
ts, ok := db.TransitionStatePerRoot[root]
if !ok || ts == nil {
log.Debug("could not find any transition state, starting with a fresh state", "is verkle", db.triedb.IsVerkle())
debug.PrintStack()
// Start with a fresh state
ts = &TransitionState{ended: db.triedb.IsVerkle()}
}
Expand Down
8 changes: 4 additions & 4 deletions eth/catalyst/api.go
Original file line number Diff line number Diff line change
Expand Up @@ -535,10 +535,10 @@ func (api *ConsensusAPI) newPayload(params engine.ExecutableData, versionedHashe
api.eth.BlockChain().StartVerkleTransition(parent.Root, common.Hash{}, api.eth.BlockChain().Config(), nil, parent.Root)
}
}
// Reset db merge state in case of a reorg
if !api.eth.BlockChain().Config().IsPrague(block.Number(), block.Time()) {
api.eth.BlockChain().ReorgThroughVerkleTransition()
}
// // Reset db merge state in case of a reorg
// if !api.eth.BlockChain().Config().IsPrague(block.Number(), block.Time()) {
// api.eth.BlockChain().ReorgThroughVerkleTransition()
// }
// Another cornercase: if the node is in snap sync mode, but the CL client
// tries to make it import a block. That should be denied as pushing something
// into the database directly will conflict with the assumptions of snap sync
Expand Down

0 comments on commit 1784337

Please sign in to comment.