Support validator withdrawals from the beacon chain to the EVM via a "system-level" operation type.
Provide a way for beacon chain withdrawals to enter into the EVM. Extends ethereum/eip-4895 but instead of minting native tokens calls an predefined contract which disperses a non-native tokens.
Name | Value |
---|---|
FORK_TIMESTAMP |
TBD |
WITHDRAWAL_CONTRACT |
TBD |
SYSTEM_SENDER |
0xfffffffffffffffffffffffffffffffffffffffe |
MAX_FAILED_WITHDRAWALS_TO_PROCESS |
4 |
Beginning with the execution timestamp FORK_TIMESTAMP
, execution clients MUST introduce the following extensions to payload validation and processing:
The following sections of ethereum/eip-4895 are implemented un-altered
- System-level operation: withdrawal
- New field in the execution payload: withdrawals
- New field in the execution payload header: withdrawals root
- Execution payload validity
State transition
The withdrawals
in an execution payload are processed after any user-level transactions are applied.
The implementation must construct and execute one system EVM transaction as follows:
sender: SYSTEM_SENDER
max_priority_fee_per_gas: 0
max_fee_per_gas: 0
gas_limit: 30000000
destination: WITHDRAWAL_CONTRACT
amount: 0
payload: PAYLOAD
PAYLOAD
is the ABI encoded arguments for a solidity function with ABI
function executeSystemWithdrawals(
uint256 maxFailedWithdrawalsToProcess,
uint64[] amounts,
address[] addresses
)
Where maxFailedWithdrawalsToProcess
is a network constant equal to MAX_FAILED_WITHDRAWALS_TO_PROCESS
. amounts
is the consecutive collection of each withdrawal.amount
as GWei, and addresses
is the consecutive collection of each withdrawal.address
. WITHDRAWAL_CONTRACT
must assert that amounts
and addresses
are of the same length.
System transactions rules are:
- Gas limit checks are disabled compared to
block.gas_limit - block.gas_used
(ref). - Caller balance and nonce checks are disabled. Nonce for system address is not incremented (ref_1, ref_2).
- Fees are not added (ref)
block.gas_used
is not incremented (ref)- If the transaction reverts, or runs out of the gas, the entire block MUST be considered invalid.
- If no contract is deployed at
WITHDRAWAL_CONTRACT
, ignore this system call and allow the block to be considered valid.
Gnosis Beacon Chain stakes a non-native token (GNO), while Ethereum stakes its native token (ETH). Gnosis Chain native token (xDAI) must only be minted when bridging DAI from Ethereum mainnet, to mantain its 1:1 peg with Ethereum DAI tokens. This introduces the mandatory requirement to at least disable the state transition as defined in EIP-4895.
A withdrawal from the Gnosis Beacon Chain must trigger the release of GNO from an EVM contract. This can potentially be achieved at the consensus level with a system transaction as proposed here. However, since those tokens are already available at the EVM, it is possible to conditionally release them by proving to a contract that a withdrawal was included in a canonical block. Such a strategy would require constant upkeep, and given the expected rate of withdrawals it was deemed to risky and expensive.
Given that a transfer or ERC20 tokens is required, modifying the state directly would restrict the implementation of the withdrawal contract too much. Existing Gnosis Chain execution nodes already perform system level operations against the BlockRewards contract of POSDAO. So general EVM execution is consistent with the status quo.
No issues
TBA