mirror of
https://github.com/ethereum/go-ethereum.git
synced 2026-03-07 11:55:13 +00:00
core/vm: in selfdestruct gas calculation, return early if there isn't enough gas to cover cold account access costs (#33450)
There's no need to perform the subsequent state access on the target if we already know that we are out of gas. This aligns the state access behavior of selfdestruct with EIP-7928
This commit is contained in:
parent
23c3498836
commit
b6fb79cdf9
1 changed files with 4 additions and 0 deletions
|
|
@ -236,6 +236,10 @@ func makeSelfdestructGasFn(refundsEnabled bool) gasFunc {
|
|||
// If the caller cannot afford the cost, this change will be rolled back
|
||||
evm.StateDB.AddAddressToAccessList(address)
|
||||
gas = params.ColdAccountAccessCostEIP2929
|
||||
|
||||
if contract.Gas < gas {
|
||||
return gas, nil
|
||||
}
|
||||
}
|
||||
// if empty and transfers value
|
||||
if evm.StateDB.Empty(address) && evm.StateDB.GetBalance(contract.Address()).Sign() != 0 {
|
||||
|
|
|
|||
Loading…
Reference in a new issue