From bf240c7ef87d9c10415d9cd20399cb55b7afe642 Mon Sep 17 00:00:00 2001 From: Sixtysixter <20945591+Sixtysixter@users.noreply.github.com> Date: Mon, 20 May 2024 23:35:33 +0200 Subject: [PATCH 1/3] Added gas_bailout to evm --- silkworm/core/execution/evm.cpp | 5 +++-- silkworm/core/execution/evm.hpp | 3 ++- silkworm/rpc/core/evm_executor.cpp | 2 +- 3 files changed, 6 insertions(+), 4 deletions(-) diff --git a/silkworm/core/execution/evm.cpp b/silkworm/core/execution/evm.cpp index a0169e5396..c9ea9df687 100644 --- a/silkworm/core/execution/evm.cpp +++ b/silkworm/core/execution/evm.cpp @@ -59,11 +59,12 @@ class DelegatingTracer : public evmone::Tracer { IntraBlockState& intra_block_state_; }; -EVM::EVM(const Block& block, IntraBlockState& state, const ChainConfig& config) noexcept +EVM::EVM(const Block& block, IntraBlockState& state, const ChainConfig& config, bool gas_bailout) noexcept : beneficiary{block.header.beneficiary}, block_{block}, state_{state}, config_{config}, + gas_bailout_{gas_bailout}, evm1_{static_cast(evmc_create_evmone())} // NOLINT(cppcoreguidelines-pro-type-static-cast-downcast) {} @@ -203,7 +204,7 @@ evmc::Result EVM::call(const evmc_message& message) noexcept { evmc::Result res{EVMC_SUCCESS, message.gas}; const auto value{intx::be::load(message.value)}; - if (message.kind != EVMC_DELEGATECALL && state_.get_balance(message.sender) < value) { + if (!gas_bailout_ && message.kind != EVMC_DELEGATECALL && state_.get_balance(message.sender) < value) { res.status_code = EVMC_INSUFFICIENT_BALANCE; return res; } diff --git a/silkworm/core/execution/evm.hpp b/silkworm/core/execution/evm.hpp index a0008fe943..c0830aabf4 100644 --- a/silkworm/core/execution/evm.hpp +++ b/silkworm/core/execution/evm.hpp @@ -78,7 +78,7 @@ class EVM { EVM(const EVM&) = delete; EVM& operator=(const EVM&) = delete; - EVM(const Block& block, IntraBlockState& state, const ChainConfig& config) noexcept; + EVM(const Block& block, IntraBlockState& state, const ChainConfig& config, bool gas_bailout = false) noexcept; ~EVM(); @@ -122,6 +122,7 @@ class EVM { const Block& block_; IntraBlockState& state_; const ChainConfig& config_; + bool gas_bailout_; const Transaction* txn_{nullptr}; std::vector block_hashes_{}; EvmTracers tracers_; diff --git a/silkworm/rpc/core/evm_executor.cpp b/silkworm/rpc/core/evm_executor.cpp index 6455cabdd9..33baf9d0ff 100644 --- a/silkworm/rpc/core/evm_executor.cpp +++ b/silkworm/rpc/core/evm_executor.cpp @@ -228,7 +228,7 @@ ExecutionResult EVMExecutor::call( SILK_DEBUG << "EVMExecutor::call: transaction: " << rpc::Transaction{txn}; auto& svc = use_service(workers_); - EVM evm{block, ibs_state_, config_}; + EVM evm{block, ibs_state_, config_, gas_bailout}; evm.analysis_cache = svc.get_analysis_cache(); evm.state_pool = svc.get_object_pool(); evm.beneficiary = rule_set_->get_beneficiary(block.header); From 1f7e4477bb7a8ebfe11640a5758c16740e7e48db Mon Sep 17 00:00:00 2001 From: Sixtysixter <20945591+Sixtysixter@users.noreply.github.com> Date: Wed, 22 May 2024 16:47:30 +0200 Subject: [PATCH 2/3] added test for gas_bailout also to EVM::create --- .github/workflows/rpc-integration-tests.yml | 2 +- silkworm/core/execution/evm.cpp | 2 +- 2 files changed, 2 insertions(+), 2 deletions(-) diff --git a/.github/workflows/rpc-integration-tests.yml b/.github/workflows/rpc-integration-tests.yml index 6709e9c501..7060dd378d 100644 --- a/.github/workflows/rpc-integration-tests.yml +++ b/.github/workflows/rpc-integration-tests.yml @@ -27,7 +27,7 @@ jobs: - name: Checkout RPC Tests Repository & Install Requirements run: | rm -rf ${{runner.workspace}}/rpc-tests - git -c advice.detachedHead=false clone --depth 1 --branch v0.19.0 https://github.com/erigontech/rpc-tests ${{runner.workspace}}/rpc-tests + git -c advice.detachedHead=false clone --depth 1 --branch v0.20.0 https://github.com/erigontech/rpc-tests ${{runner.workspace}}/rpc-tests cd ${{runner.workspace}}/rpc-tests pip3 install -r requirements.txt diff --git a/silkworm/core/execution/evm.cpp b/silkworm/core/execution/evm.cpp index c9ea9df687..05e117065b 100644 --- a/silkworm/core/execution/evm.cpp +++ b/silkworm/core/execution/evm.cpp @@ -100,7 +100,7 @@ evmc::Result EVM::create(const evmc_message& message) noexcept { evmc::Result res{EVMC_SUCCESS, message.gas, 0}; auto value{intx::be::load(message.value)}; - if (state_.get_balance(message.sender) < value) { + if (!gas_bailout_ && state_.get_balance(message.sender) < value) { res.status_code = EVMC_INSUFFICIENT_BALANCE; for (auto tracer : tracers_) { From f6e65affc0bc85133d90289a92a8a86769ade1b2 Mon Sep 17 00:00:00 2001 From: Sixtysixter <20945591+Sixtysixter@users.noreply.github.com> Date: Wed, 22 May 2024 17:26:17 +0200 Subject: [PATCH 3/3] Update rpc-integration-tests version to 0.21.0 --- .github/workflows/rpc-integration-tests.yml | 2 +- 1 file changed, 1 insertion(+), 1 deletion(-) diff --git a/.github/workflows/rpc-integration-tests.yml b/.github/workflows/rpc-integration-tests.yml index 7060dd378d..923b94fab3 100644 --- a/.github/workflows/rpc-integration-tests.yml +++ b/.github/workflows/rpc-integration-tests.yml @@ -27,7 +27,7 @@ jobs: - name: Checkout RPC Tests Repository & Install Requirements run: | rm -rf ${{runner.workspace}}/rpc-tests - git -c advice.detachedHead=false clone --depth 1 --branch v0.20.0 https://github.com/erigontech/rpc-tests ${{runner.workspace}}/rpc-tests + git -c advice.detachedHead=false clone --depth 1 --branch v0.21.0 https://github.com/erigontech/rpc-tests ${{runner.workspace}}/rpc-tests cd ${{runner.workspace}}/rpc-tests pip3 install -r requirements.txt