From da8b32eff0dd4106946dd3454d37e1a1bebe4c4f Mon Sep 17 00:00:00 2001 From: Ignacio Hagopian Date: Tue, 27 Feb 2024 12:16:24 -0300 Subject: [PATCH] core/vm: fix contract creation witness gas charging logic (#389) Signed-off-by: Ignacio Hagopian --- core/vm/evm.go | 19 +++++++++---------- 1 file changed, 9 insertions(+), 10 deletions(-) diff --git a/core/vm/evm.go b/core/vm/evm.go index bcd5248bb72c..782fc6d56740 100644 --- a/core/vm/evm.go +++ b/core/vm/evm.go @@ -519,6 +519,15 @@ func (evm *EVM) create(caller ContractRef, codeAndHash *codeAndHash, gas uint64, } } + if err == nil && evm.chainRules.IsPrague { + if len(ret) > 0 { + touchCodeChunksRangeOnReadAndChargeGas(address.Bytes(), 0, uint64(len(ret)), uint64(len(ret)), evm.Accesses) + } + if !contract.UseGas(evm.Accesses.TouchAndChargeContractCreateCompleted(address.Bytes()[:])) { + err = ErrOutOfGas + } + } + // When an error was returned by the EVM or when setting the creation code // above we revert to the snapshot and consume any gas remaining. Additionally // when we're in homestead this also counts for code storage gas errors. @@ -529,16 +538,6 @@ func (evm *EVM) create(caller ContractRef, codeAndHash *codeAndHash, gas uint64, } } - if err == nil && evm.chainRules.IsPrague { - if len(ret) > 0 { - touchCodeChunksRangeOnReadAndChargeGas(address.Bytes(), 0, uint64(len(ret)), uint64(len(ret)), evm.Accesses) - } - if !contract.UseGas(evm.Accesses.TouchAndChargeContractCreateCompleted(address.Bytes()[:])) { - evm.StateDB.RevertToSnapshot(snapshot) - err = ErrOutOfGas - } - } - if evm.Config.Tracer != nil { if evm.depth == 0 { evm.Config.Tracer.CaptureEnd(ret, gas-contract.Gas, err)