From 44394d9ffd15593f07a9f93809ce63c9b0a4181e Mon Sep 17 00:00:00 2001 From: jangko Date: Sun, 26 Sep 2021 10:45:52 +0700 Subject: [PATCH] fixes nimbus evm tracer, add missing networkParams when constructing chainDB --- nimbus/db/db_chain.nim | 3 +++ nimbus/tracer.nim | 12 ++++++++---- 2 files changed, 11 insertions(+), 4 deletions(-) diff --git a/nimbus/db/db_chain.nim b/nimbus/db/db_chain.nim index 8901fa00a..f732bb377 100644 --- a/nimbus/db/db_chain.nim +++ b/nimbus/db/db_chain.nim @@ -46,6 +46,9 @@ proc newBaseChainDB*( proc `$`*(db: BaseChainDB): string = result = "BaseChainDB" +proc networkParams*(db: BaseChainDB): NetworkParams = + NetworkParams(config: db.config, genesis: db.genesis) + proc exists*(self: BaseChainDB, hash: Hash256): bool = self.db.contains(hash.data) diff --git a/nimbus/tracer.nim b/nimbus/tracer.nim index 9b1181144..fc19e34cb 100644 --- a/nimbus/tracer.nim +++ b/nimbus/tracer.nim @@ -86,7 +86,8 @@ proc traceTransaction*(chainDB: BaseChainDB, header: BlockHeader, memoryDB = newMemoryDB() captureDB = newCaptureDB(chainDB.db, memoryDB) captureTrieDB = trieDB captureDB - captureChainDB = newBaseChainDB(captureTrieDB, false, chainDB.networkId) # prune or not prune? + networkParams = chainDB.networkParams + captureChainDB = newBaseChainDB(captureTrieDB, false, chainDB.networkId, networkParams) # prune or not prune? vmState = newBaseVMState(parent.stateRoot, header, captureChainDB, tracerFlags + {EnableAccount}) var stateDb = vmState.accountDb @@ -153,7 +154,8 @@ proc dumpBlockState*(db: BaseChainDB, header: BlockHeader, body: BlockBody, dump memoryDB = newMemoryDB() captureDB = newCaptureDB(db.db, memoryDB) captureTrieDB = trieDB captureDB - captureChainDB = newBaseChainDB(captureTrieDB, false, db.networkId) + networkParams = db.networkParams + captureChainDB = newBaseChainDB(captureTrieDB, false, db.networkId, networkParams) # we only need stack dump if we want to scan for internal transaction address vmState = newBaseVMState(parent.stateRoot, header, captureChainDB, {EnableTracing, DisableMemory, DisableStorage, EnableAccount}) miner = vmState.coinbase() @@ -210,7 +212,8 @@ proc traceBlock*(chainDB: BaseChainDB, header: BlockHeader, body: BlockBody, tra memoryDB = newMemoryDB() captureDB = newCaptureDB(chainDB.db, memoryDB) captureTrieDB = trieDB captureDB - captureChainDB = newBaseChainDB(captureTrieDB, false, chainDB.networkId) + networkParams = chainDB.networkParams + captureChainDB = newBaseChainDB(captureTrieDB, false, chainDB.networkId, networkParams) vmState = newBaseVMState(parent.stateRoot, header, captureChainDB, tracerFlags + {EnableTracing}) if header.txRoot == BLANK_ROOT_HASH: return newJNull() @@ -243,7 +246,8 @@ proc dumpDebuggingMetaData*(chainDB: BaseChainDB, header: BlockHeader, memoryDB = newMemoryDB() captureDB = newCaptureDB(chainDB.db, memoryDB) captureTrieDB = trieDB captureDB - captureChainDB = newBaseChainDB(captureTrieDB, false, chainDB.networkId) + networkParams = chainDB.networkParams + captureChainDB = newBaseChainDB(captureTrieDB, false, chainDB.networkId, networkParams) bloom = createBloom(vmState.receipts) let blockSummary = %{