From 3d58393b4cdc626d4c72041bfca09a61cb3c8b39 Mon Sep 17 00:00:00 2001 From: Jacek Sieka Date: Fri, 13 Dec 2024 05:53:41 +0100 Subject: [PATCH] Offload signature checking to taskpools (#2927) MIME-Version: 1.0 Content-Type: text/plain; charset=UTF-8 Content-Transfer-Encoding: 8bit In block processing, depending on the complexity of a transaction and hotness of caches etc, signature checking can actually make up the majority of time needed to process a transaction (60% observed in some randomly sampled block ranges). Fortunately, this is a task that trivially can be offloaded to a task pool similar to how nimbus-eth2 does it. This PR introduces taskpools in the most simple way possible, by performing signature checking concurrently with other TX processing, assigning a taskpool task per TX effectively. With this little trick, we're in gigagas land 🎉 on my laptop! ``` INF 2024-12-10 21:05:35.170+01:00 Imported blocks blockNumber=3874817 b... mgps=1222.707 ... ``` Tests don't use the taskpool for now because it needs manual cleanup and we don't have a good mechanism in place. Future PR:s should address this by creating a common shutdown sequence that also closes and cleans up other resources like the DB. Co-authored-by: andri lim --- .../nodocker/consensus/consensus_sim.nim | 1 + .../nodocker/engine/engine_env.nim | 1 + hive_integration/nodocker/engine/node.nim | 2 +- .../nodocker/graphql/graphql_sim.nim | 3 +- hive_integration/nodocker/pyspec/test_env.nim | 2 +- hive_integration/nodocker/rpc/test_env.nim | 5 +- nimbus/common/common.nim | 15 +++- nimbus/config.nim | 6 ++ nimbus/core/chain/persist_blocks.nim | 1 + nimbus/core/executor/process_block.nim | 81 +++++++++++++++---- nimbus/nimbus_execution_client.nim | 18 ++++- tests/macro_assembler.nim | 2 +- tests/persistBlockTestGen.nim | 2 +- tests/test_blockchain_json.nim | 2 +- tests/test_coredb.nim | 1 + tests/test_engine_api.nim | 1 + tests/test_evm_support.nim | 1 + tests/test_forked_chain.nim | 1 + tests/test_forkid.nim | 2 +- tests/test_generalstate_json.nim | 2 +- tests/test_genesis.nim | 16 ++-- tests/test_graphql.nim | 2 +- tests/test_ledger.nim | 2 +- tests/test_persistblock_json.nim | 2 +- tests/test_precompiles.nim | 2 +- tests/test_rpc.nim | 2 +- tests/test_tracer_json.nim | 2 +- tests/test_txpool/setup.nim | 2 +- tests/test_txpool2.nim | 2 +- tests/tracerTestGen.nim | 2 +- tools/evmstate/evmstate.nim | 2 +- tools/t8n/transition.nim | 6 +- vendor/nim-taskpools | 2 +- 33 files changed, 142 insertions(+), 51 deletions(-) diff --git a/hive_integration/nodocker/consensus/consensus_sim.nim b/hive_integration/nodocker/consensus/consensus_sim.nim index aa63cc165..3f492e724 100644 --- a/hive_integration/nodocker/consensus/consensus_sim.nim +++ b/hive_integration/nodocker/consensus/consensus_sim.nim @@ -23,6 +23,7 @@ proc processChainData(cd: ChainData): TestStatus = let networkId = NetworkId(cd.params.config.chainId) com = CommonRef.new(newCoreDbRef DefaultDbMemory, + Taskpool.new(), networkId, cd.params ) diff --git a/hive_integration/nodocker/engine/engine_env.nim b/hive_integration/nodocker/engine/engine_env.nim index eaef107a4..00fc71b47 100644 --- a/hive_integration/nodocker/engine/engine_env.nim +++ b/hive_integration/nodocker/engine/engine_env.nim @@ -59,6 +59,7 @@ const proc makeCom*(conf: NimbusConf): CommonRef = CommonRef.new( newCoreDbRef DefaultDbMemory, + Taskpool.new(), conf.networkId, conf.networkParams ) diff --git a/hive_integration/nodocker/engine/node.nim b/hive_integration/nodocker/engine/node.nim index cb7f806e3..9485988ec 100644 --- a/hive_integration/nodocker/engine/node.nim +++ b/hive_integration/nodocker/engine/node.nim @@ -54,7 +54,7 @@ proc processBlock( if header.parentBeaconBlockRoot.isSome: ? vmState.processBeaconBlockRoot(header.parentBeaconBlockRoot.get) - ? processTransactions(vmState, header, blk.transactions) + ? processTransactions(vmState, header, blk.transactions, taskpool = com.taskpool) if com.isShanghaiOrLater(header.timestamp): for withdrawal in blk.withdrawals.get: diff --git a/hive_integration/nodocker/graphql/graphql_sim.nim b/hive_integration/nodocker/graphql/graphql_sim.nim index 41fb9619d..d0f3f0b87 100644 --- a/hive_integration/nodocker/graphql/graphql_sim.nim +++ b/hive_integration/nodocker/graphql/graphql_sim.nim @@ -79,7 +79,8 @@ proc main() = ethCtx = newEthContext() ethNode = setupEthNode(conf, ethCtx, eth) com = CommonRef.new(newCoreDbRef DefaultDbMemory, - conf.networkId, + Taskpool.new(), + conf.networkId, conf.networkParams ) diff --git a/hive_integration/nodocker/pyspec/test_env.nim b/hive_integration/nodocker/pyspec/test_env.nim index c6f308d08..7d61c42b5 100644 --- a/hive_integration/nodocker/pyspec/test_env.nim +++ b/hive_integration/nodocker/pyspec/test_env.nim @@ -38,7 +38,7 @@ proc setupELClient*(conf: ChainConfig, node: JsonNode): TestEnv = let memDB = newCoreDbRef DefaultDbMemory genesisHeader = node.genesisHeader - com = CommonRef.new(memDB, conf) + com = CommonRef.new(memDB, Taskpool.new(), conf) stateDB = LedgerRef.init(memDB) chain = newForkedChain(com, genesisHeader) diff --git a/hive_integration/nodocker/rpc/test_env.nim b/hive_integration/nodocker/rpc/test_env.nim index 4019b1620..c8cab0468 100644 --- a/hive_integration/nodocker/rpc/test_env.nim +++ b/hive_integration/nodocker/rpc/test_env.nim @@ -46,11 +46,11 @@ proc manageAccounts(ctx: EthContext, conf: NimbusConf) = proc setupRpcServer(ctx: EthContext, com: CommonRef, ethNode: EthereumNode, txPool: TxPoolRef, conf: NimbusConf, chain: ForkedChainRef): RpcServer = - let + let rpcServer = newRpcHttpServer([initTAddress(conf.httpAddress, conf.httpPort)]) serverApi = newServerAPI(chain, txPool) - + setupCommonRpc(ethNode, conf, rpcServer) setupServerAPI(serverApi, rpcServer, ctx) @@ -80,6 +80,7 @@ proc setupEnv*(): TestEnv = ethCtx = newEthContext() ethNode = setupEthNode(conf, ethCtx, eth) com = CommonRef.new(newCoreDbRef DefaultDbMemory, + Taskpool.new(), conf.networkId, conf.networkParams ) diff --git a/nimbus/common/common.nim b/nimbus/common/common.nim index b80d398fd..0bb3dd8d8 100644 --- a/nimbus/common/common.nim +++ b/nimbus/common/common.nim @@ -15,7 +15,8 @@ import ../db/[core_db, ledger, storage_types], ../utils/[utils, ec_recover], ".."/[constants, errors, version], - "."/[chain_config, evmforks, genesis, hardforks] + "."/[chain_config, evmforks, genesis, hardforks], + taskpools export chain_config, @@ -25,7 +26,8 @@ export evmforks, hardforks, genesis, - utils + utils, + taskpools type SyncProgress = object @@ -100,6 +102,9 @@ type gasLimit: uint64 ## Desired gas limit when building a block + taskpool*: Taskpool + ## Shared task pool for offloading computation to other threads + # ------------------------------------------------------------------------------ # Forward declarations # ------------------------------------------------------------------------------ @@ -168,6 +173,7 @@ proc initializeDb(com: CommonRef) = proc init(com : CommonRef, db : CoreDbRef, + taskpool : Taskpool, networkId : NetworkId, config : ChainConfig, genesis : Genesis, @@ -184,6 +190,7 @@ proc init(com : CommonRef, com.pruneHistory= pruneHistory com.pos = CasperRef.new com.extraData = ShortClientId + com.taskpool = taskpool com.gasLimit = DEFAULT_GAS_LIMIT # com.forkIdCalculator and com.genesisHash are set @@ -227,6 +234,7 @@ proc isBlockAfterTtd(com: CommonRef, header: Header): bool = proc new*( _: type CommonRef; db: CoreDbRef; + taskpool: Taskpool; networkId: NetworkId = MainNet; params = networkParams(MainNet); pruneHistory = false; @@ -237,6 +245,7 @@ proc new*( new(result) result.init( db, + taskpool, networkId, params.config, params.genesis, @@ -245,6 +254,7 @@ proc new*( proc new*( _: type CommonRef; db: CoreDbRef; + taskpool: Taskpool; config: ChainConfig; networkId: NetworkId = MainNet; pruneHistory = false; @@ -255,6 +265,7 @@ proc new*( new(result) result.init( db, + taskpool, networkId, config, nil, diff --git a/nimbus/config.nim b/nimbus/config.nim index 004c2462e..52be52b98 100644 --- a/nimbus/config.nim +++ b/nimbus/config.nim @@ -363,6 +363,12 @@ type defaultValueDesc: $ClientId name: "agent-string" .}: string + numThreads* {. + separator: "\pPERFORMANCE OPTIONS", + defaultValue: 0, + desc: "Number of worker threads (\"0\" = use as many threads as there are CPU cores available)" + name: "num-threads" .}: int + beaconChunkSize* {. hidden desc: "Number of blocks per database transaction for beacon sync" diff --git a/nimbus/core/chain/persist_blocks.nim b/nimbus/core/chain/persist_blocks.nim index 179c841b1..cafdbdac3 100644 --- a/nimbus/core/chain/persist_blocks.nim +++ b/nimbus/core/chain/persist_blocks.nim @@ -149,6 +149,7 @@ proc persistBlocksImpl( skipValidation, skipReceipts = skipValidation and NoPersistReceipts in flags, skipUncles = NoPersistUncles in flags, + taskpool = c.com.taskpool, ) let blockHash = header.blockHash() diff --git a/nimbus/core/executor/process_block.nim b/nimbus/core/executor/process_block.nim index dae78b5be..262b40a15 100644 --- a/nimbus/core/executor/process_block.nim +++ b/nimbus/core/executor/process_block.nim @@ -8,6 +8,8 @@ # at your option. This file may not be copied, modified, or distributed except # according to those terms. +{.push raises: [], gcsafe.} + import ../../common/common, ../../utils/utils, @@ -21,11 +23,50 @@ import ./calculate_reward, ./executor_helpers, ./process_transaction, - eth/common/transaction_utils, + eth/common/[keys, transaction_utils], chronicles, - results + results, + taskpools -{.push raises: [].} +template withSender(txs: openArray[Transaction], body: untyped) = + # Execute transactions offloading the signature checking to the task pool if + # it's available + if taskpool == nil: + for txIndex {.inject.}, tx {.inject.} in txs: + let sender {.inject.} = tx.recoverSender().valueOr(default(Address)) + body + else: + type Entry = (Signature, Hash32, Flowvar[Address]) + + proc recoverTask(e: ptr Entry): Address {.nimcall.} = + let pk = recover(e[][0], SkMessage(e[][1].data)) + if pk.isOk(): + pk[].to(Address) + else: + default(Address) + + var entries = newSeq[Entry](txs.len) + + # Prepare signature recovery tasks for each transaction - for simplicity, + # we use `default(Address)` to signal sig check failure + for i, e in entries.mpairs(): + e[0] = txs[i].signature().valueOr(default(Signature)) + e[1] = txs[i].rlpHashForSigning(txs[i].isEip155) + let a = addr e + # Spawning the task here allows it to start early, while we still haven't + # hashed subsequent txs + e[2] = taskpool.spawn recoverTask(a) + + for txIndex {.inject.}, e in entries.mpairs(): + template tx(): untyped = + txs[txIndex] + + # Sync blocks until the sender is available from the task pool - as soon + # as we have it, we can process this transaction while the senders of the + # other transactions are being computed + let sender {.inject.} = sync(e[2]) + + body # Factored this out of procBlkPreamble so that it can be used directly for # stateless execution of specific transactions. @@ -34,15 +75,17 @@ proc processTransactions*( header: Header, transactions: seq[Transaction], skipReceipts = false, - collectLogs = false + collectLogs = false, + taskpool: Taskpool = nil, ): Result[void, string] = vmState.receipts.setLen(if skipReceipts: 0 else: transactions.len) vmState.cumulativeGasUsed = 0 vmState.allLogs = @[] - for txIndex, tx in transactions: - let sender = tx.recoverSender().valueOr: + withSender(transactions): + if sender == default(Address): return err("Could not get sender for tx with index " & $(txIndex)) + let rc = vmState.processTransaction(tx, sender, header) if rc.isErr: return err("Error processing tx with index " & $(txIndex) & ":" & rc.error) @@ -60,7 +103,10 @@ proc processTransactions*( ok() proc procBlkPreamble( - vmState: BaseVMState, blk: Block, skipValidation, skipReceipts, skipUncles: bool + vmState: BaseVMState, + blk: Block, + skipValidation, skipReceipts, skipUncles: bool, + taskpool: Taskpool, ): Result[void, string] = template header(): Header = blk.header @@ -97,7 +143,9 @@ proc procBlkPreamble( return err("Transactions missing from body") let collectLogs = header.requestsHash.isSome and not skipValidation - ?processTransactions(vmState, header, blk.transactions, skipReceipts, collectLogs) + ?processTransactions( + vmState, header, blk.transactions, skipReceipts, collectLogs, taskpool + ) elif blk.transactions.len > 0: return err("Transactions in block with empty txRoot") @@ -150,7 +198,8 @@ proc procBlkEpilogue( # large ranges of blocks, implicitly limiting its size using the gas limit db.persist( clearEmptyAccount = vmState.com.isSpuriousOrLater(header.number), - clearCache = true) + clearCache = true, + ) var withdrawalReqs: seq[byte] @@ -173,17 +222,15 @@ proc procBlkEpilogue( expected = header.stateRoot, actual = stateRoot, arrivedFrom = vmState.parent.stateRoot - return err("stateRoot mismatch, expect: " & - $header.stateRoot & ", got: " & $stateRoot) + return + err("stateRoot mismatch, expect: " & $header.stateRoot & ", got: " & $stateRoot) if not skipReceipts: let bloom = createBloom(vmState.receipts) if header.logsBloom != bloom: debug "wrong logsBloom in block", - blockNumber = header.number, - actual = bloom, - expected = header.logsBloom + blockNumber = header.number, actual = bloom, expected = header.logsBloom return err("bloom mismatch") let receiptsRoot = calcReceiptsRoot(vmState.receipts) @@ -199,7 +246,8 @@ proc procBlkEpilogue( if header.requestsHash.isSome: let - depositReqs = ?parseDepositLogs(vmState.allLogs, vmState.com.depositContractAddress) + depositReqs = + ?parseDepositLogs(vmState.allLogs, vmState.com.depositContractAddress) requestsHash = calcRequestsHash(depositReqs, withdrawalReqs, consolidationReqs) if header.requestsHash.get != requestsHash: @@ -223,9 +271,10 @@ proc processBlock*( skipValidation: bool = false, skipReceipts: bool = false, skipUncles: bool = false, + taskpool: Taskpool = nil, ): Result[void, string] = ## Generalised function to processes `blk` for any network. - ?vmState.procBlkPreamble(blk, skipValidation, skipReceipts, skipUncles) + ?vmState.procBlkPreamble(blk, skipValidation, skipReceipts, skipUncles, taskpool) # EIP-3675: no reward for miner in POA/POS if not vmState.com.proofOfStake(blk.header): diff --git a/nimbus/nimbus_execution_client.nim b/nimbus/nimbus_execution_client.nim index 5a975199b..8544106d2 100644 --- a/nimbus/nimbus_execution_client.nim +++ b/nimbus/nimbus_execution_client.nim @@ -11,7 +11,7 @@ import ../nimbus/compile_info import - std/[os, strutils, net], + std/[os, osproc, strutils, net], chronicles, eth/net/nat, metrics, @@ -217,8 +217,24 @@ proc run(nimbus: NimbusNode, conf: NimbusConf) = preventLoadingDataDirForTheWrongNetwork(coreDB, conf) setupMetrics(nimbus, conf) + let taskpool = + try: + if conf.numThreads < 0: + fatal "The number of threads --num-threads cannot be negative." + quit 1 + elif conf.numThreads == 0: + Taskpool.new(numThreads = min(countProcessors(), 16)) + else: + Taskpool.new(numThreads = conf.numThreads) + except CatchableError as e: + fatal "Cannot start taskpool", err = e.msg + quit 1 + + info "Threadpool started", numThreads = taskpool.numThreads + let com = CommonRef.new( db = coreDB, + taskpool = taskpool, pruneHistory = (conf.chainDbMode == AriPrune), networkId = conf.networkId, params = conf.networkParams) diff --git a/tests/macro_assembler.nim b/tests/macro_assembler.nim index feb32287b..25ec65a86 100644 --- a/tests/macro_assembler.nim +++ b/tests/macro_assembler.nim @@ -265,7 +265,7 @@ proc initVMEnv*(network: string): BaseVMState = cdb = DefaultDbMemory.newCoreDbRef() com = CommonRef.new( cdb, - conf, + nil, conf, conf.chainId.NetworkId) parent = Header(stateRoot: EMPTY_ROOT_HASH) parentHash = rlpHash(parent) diff --git a/tests/persistBlockTestGen.nim b/tests/persistBlockTestGen.nim index 9717f8bc3..81726345f 100644 --- a/tests/persistBlockTestGen.nim +++ b/tests/persistBlockTestGen.nim @@ -57,7 +57,7 @@ proc main() {.used.} = var conf = makeConfig() let db = newCoreDbRef( DefaultDbPersistent, string conf.dataDir, DbOptions.init()) - let com = CommonRef.new(db) + let com = CommonRef.new(db, nil) com.dumpTest(97) com.dumpTest(98) # no uncles and no tx diff --git a/tests/test_blockchain_json.nim b/tests/test_blockchain_json.nim index d2be00399..3427d02c5 100644 --- a/tests/test_blockchain_json.nim +++ b/tests/test_blockchain_json.nim @@ -69,7 +69,7 @@ proc executeCase(node: JsonNode): bool = memDB = newCoreDbRef DefaultDbMemory stateDB = LedgerRef.init(memDB) config = getChainConfig(env.network) - com = CommonRef.new(memDB, config) + com = CommonRef.new(memDB, nil, config) setupStateDB(env.pre, stateDB) stateDB.persist() diff --git a/tests/test_coredb.nim b/tests/test_coredb.nim index 86eb0a151..bb835f3fa 100644 --- a/tests/test_coredb.nim +++ b/tests/test_coredb.nim @@ -181,6 +181,7 @@ proc initRunnerDB( result = CommonRef.new( db = coreDB, + taskpool = nil, networkId = networkId, params = params, pruneHistory = pruneHistory) diff --git a/tests/test_engine_api.nim b/tests/test_engine_api.nim index b3c3c6010..371527977 100644 --- a/tests/test_engine_api.nim +++ b/tests/test_engine_api.nim @@ -61,6 +61,7 @@ proc setupConfig(genesisFile: string): NimbusConf = proc setupCom(conf: NimbusConf): CommonRef = CommonRef.new( newCoreDbRef DefaultDbMemory, + nil, conf.networkId, conf.networkParams ) diff --git a/tests/test_evm_support.nim b/tests/test_evm_support.nim index 1c3a2e0da..ab191372a 100644 --- a/tests/test_evm_support.nim +++ b/tests/test_evm_support.nim @@ -347,6 +347,7 @@ proc runTestOverflow() = let com = CommonRef.new( newCoreDbRef(DefaultDbMemory), + nil, config = chainConfigForNetwork(MainNet) ) diff --git a/tests/test_forked_chain.nim b/tests/test_forked_chain.nim index 5a46773d3..997bf0d2b 100644 --- a/tests/test_forked_chain.nim +++ b/tests/test_forked_chain.nim @@ -37,6 +37,7 @@ proc setupEnv(): TestEnv = proc newCom(env: TestEnv): CommonRef = CommonRef.new( newCoreDbRef DefaultDbMemory, + nil, env.conf.networkId, env.conf.networkParams ) diff --git a/tests/test_forkid.nim b/tests/test_forkid.nim index adb47ee86..06efc6e5d 100644 --- a/tests/test_forkid.nim +++ b/tests/test_forkid.nim @@ -72,7 +72,7 @@ template runTest(network: untyped, name: string) = test name: var params = networkParams(network) - com = CommonRef.new(newCoreDbRef DefaultDbMemory, network, params) + com = CommonRef.new(newCoreDbRef DefaultDbMemory, nil, network, params) for i, x in `network IDs`: let id = com.forkId(x.number, x.time) diff --git a/tests/test_generalstate_json.nim b/tests/test_generalstate_json.nim index afa470921..1d32676d8 100644 --- a/tests/test_generalstate_json.nim +++ b/tests/test_generalstate_json.nim @@ -77,7 +77,7 @@ proc dumpDebugData(ctx: TestCtx, vmState: BaseVMState, gasUsed: GasInt, success: proc testFixtureIndexes(ctx: var TestCtx, testStatusIMPL: var TestStatus) = let - com = CommonRef.new(newCoreDbRef DefaultDbMemory, ctx.chainConfig) + com = CommonRef.new(newCoreDbRef DefaultDbMemory, nil, ctx.chainConfig) parent = Header(stateRoot: emptyRoot) tracer = if ctx.trace: newLegacyTracer({}) diff --git a/tests/test_genesis.nim b/tests/test_genesis.nim index ae2c28108..e1e6fba68 100644 --- a/tests/test_genesis.nim +++ b/tests/test_genesis.nim @@ -27,11 +27,11 @@ proc findFilePath(file: string): string = return path proc makeGenesis(networkId: NetworkId): Header = - let com = CommonRef.new(newCoreDbRef DefaultDbMemory, params = networkParams(networkId)) + let com = CommonRef.new(newCoreDbRef DefaultDbMemory, taskpool = nil, params = networkParams(networkId)) com.genesisHeader proc proofOfStake(params: NetworkParams): bool = - let com = CommonRef.new(newCoreDbRef DefaultDbMemory, + let com = CommonRef.new(newCoreDbRef DefaultDbMemory, taskpool = nil, networkId = params.config.chainId.NetworkId, params = params) let header = com.genesisHeader @@ -66,7 +66,7 @@ proc customGenesisTest() = test "Devnet4.json (aka Kintsugi in all but chainId)": var cg: NetworkParams check loadNetworkParams("devnet4.json".findFilePath, cg) - let com = CommonRef.new(newCoreDbRef DefaultDbMemory, params = cg) + let com = CommonRef.new(newCoreDbRef DefaultDbMemory, taskpool = nil, params = cg) let stateRoot = hash32"3b84f313bfd49c03cc94729ade2e0de220688f813c0c895a99bd46ecc9f45e1e" let genesisHash = hash32"a28d8d73e087a01d09d8cb806f60863652f30b6b6dfa4e0157501ff07d422399" check com.genesisHeader.stateRoot == stateRoot @@ -76,7 +76,7 @@ proc customGenesisTest() = test "Devnet5.json (aka Kiln in all but chainId and TTD)": var cg: NetworkParams check loadNetworkParams("devnet5.json".findFilePath, cg) - let com = CommonRef.new(newCoreDbRef DefaultDbMemory, params = cg) + let com = CommonRef.new(newCoreDbRef DefaultDbMemory, taskpool = nil, params = cg) let stateRoot = hash32"52e628c7f35996ba5a0402d02b34535993c89ff7fc4c430b2763ada8554bee62" let genesisHash = hash32"51c7fe41be669f69c45c33a56982cbde405313342d9e2b00d7c91a7b284dd4f8" check com.genesisHeader.stateRoot == stateRoot @@ -86,7 +86,7 @@ proc customGenesisTest() = test "Mainnet shadow fork 1": var cg: NetworkParams check loadNetworkParams("mainshadow1.json".findFilePath, cg) - let com = CommonRef.new(newCoreDbRef DefaultDbMemory, params = cg) + let com = CommonRef.new(newCoreDbRef DefaultDbMemory, taskpool = nil, params = cg) let stateRoot = hash32"d7f8974fb5ac78d9ac099b9ad5018bedc2ce0a72dad1827a1709da30580f0544" let genesisHash = hash32"d4e56740f876aef8c010b86a40d5f56745a118d0906a34e69aec8c0db1cb8fa3" let ttd = "46_089_003_871_917_200_000_000".parse(UInt256) @@ -99,7 +99,7 @@ proc customGenesisTest() = # parse using geth format should produce the same result with nimbus format var cg: NetworkParams check loadNetworkParams("geth_mainshadow1.json".findFilePath, cg) - let com = CommonRef.new(newCoreDbRef DefaultDbMemory, params = cg) + let com = CommonRef.new(newCoreDbRef DefaultDbMemory, taskpool = nil, params = cg) let stateRoot = hash32"d7f8974fb5ac78d9ac099b9ad5018bedc2ce0a72dad1827a1709da30580f0544" let genesisHash = hash32"d4e56740f876aef8c010b86a40d5f56745a118d0906a34e69aec8c0db1cb8fa3" let ttd = "46_089_003_871_917_200_000_000".parse(UInt256) @@ -114,7 +114,7 @@ proc customGenesisTest() = test "Holesky": var cg: NetworkParams check loadNetworkParams("holesky.json".findFilePath, cg) - let com = CommonRef.new(newCoreDbRef DefaultDbMemory, params = cg) + let com = CommonRef.new(newCoreDbRef DefaultDbMemory, taskpool = nil, params = cg) let stateRoot = hash32"69D8C9D72F6FA4AD42D4702B433707212F90DB395EB54DC20BC85DE253788783" let genesisHash = hash32"b5f7f912443c940f21fd611f12828d75b534364ed9e95ca4e307729a4661bde4" check com.genesisHeader.stateRoot == stateRoot @@ -125,7 +125,7 @@ proc customGenesisTest() = # parse using geth format should produce the same result with nimbus format var cg: NetworkParams check loadNetworkParams("geth_holesky.json".findFilePath, cg) - let com = CommonRef.new(newCoreDbRef DefaultDbMemory, params = cg) + let com = CommonRef.new(newCoreDbRef DefaultDbMemory, taskpool = nil, params = cg) let stateRoot = hash32"69D8C9D72F6FA4AD42D4702B433707212F90DB395EB54DC20BC85DE253788783" let genesisHash = hash32"b5f7f912443c940f21fd611f12828d75b534364ed9e95ca4e307729a4661bde4" check com.genesisHeader.stateRoot == stateRoot diff --git a/tests/test_graphql.nim b/tests/test_graphql.nim index ef1a026ad..acf03c27d 100644 --- a/tests/test_graphql.nim +++ b/tests/test_graphql.nim @@ -69,7 +69,7 @@ proc setupChain(): CommonRef = ) let com = CommonRef.new( - newCoreDbRef DefaultDbMemory, + newCoreDbRef DefaultDbMemory, nil, CustomNet, customNetwork ) diff --git a/tests/test_ledger.nim b/tests/test_ledger.nim index 40cc9e51a..1901162e4 100644 --- a/tests/test_ledger.nim +++ b/tests/test_ledger.nim @@ -97,7 +97,7 @@ proc initEnv(): TestEnv = let com = CommonRef.new( - newCoreDbRef DefaultDbMemory, + newCoreDbRef DefaultDbMemory, nil, conf.networkId, conf.networkParams ) diff --git a/tests/test_persistblock_json.nim b/tests/test_persistblock_json.nim index 1eba2b040..cbbb69e5b 100644 --- a/tests/test_persistblock_json.nim +++ b/tests/test_persistblock_json.nim @@ -19,7 +19,7 @@ proc testFixture(node: JsonNode, testStatusIMPL: var TestStatus) = blockNumber = UInt256.fromHex(node["blockNumber"].getStr()) memoryDB = newCoreDbRef DefaultDbMemory config = chainConfigForNetwork(MainNet) - com = CommonRef.new(memoryDB, config) + com = CommonRef.new(memoryDB, nil, config) state = node["state"] for k, v in state: diff --git a/tests/test_precompiles.nim b/tests/test_precompiles.nim index 7d8926fc6..208655b0a 100644 --- a/tests/test_precompiles.nim +++ b/tests/test_precompiles.nim @@ -71,7 +71,7 @@ proc testFixture(fixtures: JsonNode, testStatusIMPL: var TestStatus) = conf = getChainConfig(parseFork(fixtures["fork"].getStr)) data = fixtures["data"] privateKey = PrivateKey.fromHex("7a28b5ba57c53603b0b07b56bba752f7784bf506fa95edc395f5cf6c7514fe9d")[] - com = CommonRef.new(newCoreDbRef DefaultDbMemory, config = conf) + com = CommonRef.new(newCoreDbRef DefaultDbMemory, nil, config = conf) vmState = BaseVMState.new( Header(number: 1'u64, stateRoot: emptyRlpHash), Header(), diff --git a/tests/test_rpc.nim b/tests/test_rpc.nim index 4cadef1ea..b1e592171 100644 --- a/tests/test_rpc.nim +++ b/tests/test_rpc.nim @@ -222,7 +222,7 @@ proc rpcMain*() = ctx = newEthContext() ethNode = setupEthNode(conf, ctx, eth) com = CommonRef.new( - newCoreDbRef DefaultDbMemory, + newCoreDbRef DefaultDbMemory, nil, conf.networkId, conf.networkParams ) diff --git a/tests/test_tracer_json.nim b/tests/test_tracer_json.nim index 3676456de..bab93cb1d 100644 --- a/tests/test_tracer_json.nim +++ b/tests/test_tracer_json.nim @@ -130,7 +130,7 @@ proc testFixtureImpl(node: JsonNode, testStatusIMPL: var TestStatus, memoryDB: C var blockNumberHex = node["blockNumber"].getStr() blockNumber = parseHexInt(blockNumberHex).uint64 - com = CommonRef.new(memoryDB, chainConfigForNetwork(MainNet)) + com = CommonRef.new(memoryDB, nil, chainConfigForNetwork(MainNet)) state = node["state"] receipts = node["receipts"] diff --git a/tests/test_txpool/setup.nim b/tests/test_txpool/setup.nim index 84c2a3571..a9b5bfff0 100644 --- a/tests/test_txpool/setup.nim +++ b/tests/test_txpool/setup.nim @@ -92,7 +92,7 @@ proc setupTxPool*(getStatus: proc(): TxItemStatus): (CommonRef, TxPoolRef, int) txEnv.fillGenesis(conf.networkParams) let com = CommonRef.new( - newCoreDbRef DefaultDbMemory, + newCoreDbRef DefaultDbMemory, nil, conf.networkId, conf.networkParams ) diff --git a/tests/test_txpool2.nim b/tests/test_txpool2.nim index b652731cf..3db5be1a1 100644 --- a/tests/test_txpool2.nim +++ b/tests/test_txpool2.nim @@ -124,7 +124,7 @@ proc initEnv(envFork: HardFork): TestEnv = let com = - CommonRef.new(newCoreDbRef DefaultDbMemory, conf.networkId, conf.networkParams) + CommonRef.new(newCoreDbRef DefaultDbMemory, nil, conf.networkId, conf.networkParams) chain = newForkedChain(com, com.genesisHeader) result = TestEnv( diff --git a/tests/tracerTestGen.nim b/tests/tracerTestGen.nim index e75ff62d7..bbd61e843 100644 --- a/tests/tracerTestGen.nim +++ b/tests/tracerTestGen.nim @@ -56,7 +56,7 @@ proc main() {.used.} = var conf = makeConfig() let db = newCoreDbRef( DefaultDbPersistent, string conf.dataDir, DbOptions.init()) - let com = CommonRef.new(db) + let com = CommonRef.new(db, nil) com.dumpTest(97) com.dumpTest(46147) diff --git a/tools/evmstate/evmstate.nim b/tools/evmstate/evmstate.nim index dbc8725a2..376bdef75 100644 --- a/tools/evmstate/evmstate.nim +++ b/tools/evmstate/evmstate.nim @@ -105,7 +105,7 @@ proc writeRootHashToStderr(stateRoot: Hash32) = proc runExecution(ctx: var StateContext, conf: StateConf, pre: JsonNode): StateResult = let - com = CommonRef.new(newCoreDbRef DefaultDbMemory, ctx.chainConfig) + com = CommonRef.new(newCoreDbRef DefaultDbMemory, nil, ctx.chainConfig) stream = newFileStream(stderr) tracer = if conf.jsonEnabled: newJsonTracer(stream, ctx.tracerFlags, conf.pretty) diff --git a/tools/t8n/transition.nim b/tools/t8n/transition.nim index 978b7801f..66a2e19aa 100644 --- a/tools/t8n/transition.nim +++ b/tools/t8n/transition.nim @@ -349,11 +349,11 @@ proc exec(ctx: TransContext, excessBlobGas = ctx.env.currentExcessBlobGas elif ctx.env.parentExcessBlobGas.isSome and ctx.env.parentBlobGasUsed.isSome: excessBlobGas = Opt.some calcExcessBlobGas(vmState.parent) - + if excessBlobGas.isSome: result.result.blobGasUsed = Opt.some vmState.blobGasUsed result.result.currentExcessBlobGas = excessBlobGas - + if vmState.com.isPragueOrLater(ctx.env.currentTimestamp): var allLogs: seq[Log] for rec in result.result.receipts: @@ -469,7 +469,7 @@ proc transitionAction*(ctx: var TransContext, conf: T8NConf) = config.depositContractAddress = ctx.env.depositContractAddress config.chainId = conf.stateChainId.ChainId - let com = CommonRef.new(newCoreDbRef DefaultDbMemory, config) + let com = CommonRef.new(newCoreDbRef DefaultDbMemory, Taskpool.new(), config) # Sanity check, to not `panic` in state_transition if com.isLondonOrLater(ctx.env.currentNumber): diff --git a/vendor/nim-taskpools b/vendor/nim-taskpools index d4c43137c..f0b386933 160000 --- a/vendor/nim-taskpools +++ b/vendor/nim-taskpools @@ -1 +1 @@ -Subproject commit d4c43137c0590cb47f893a66ca8cb027fa6c217e +Subproject commit f0b386933ffea89098bc232359f8524393c2c1ef