EIP6110 meta update

This commit is contained in:
Hsiao-Wei Wang 2024-03-06 14:00:55 +08:00 committed by Alex Stokes
parent d2c69fe3cf
commit 9c4e1db821
No known key found for this signature in database
4 changed files with 42 additions and 38 deletions

View File

@ -26,10 +26,10 @@ Features are researched and developed in parallel, and then consolidated into se
### In-development Specifications ### In-development Specifications
| Code Name or Topic | Specs | Notes | | Code Name or Topic | Specs | Notes |
| - | - | - | | - | - | - |
| Electra | <ul><li>Core</li><ul><li>[Beacon Chain changes](specs/electra/beacon-chain.md)</li><li>[EIP-6110 fork](specs/electra/fork.md)</li></ul><li>Additions</li><ul><li>[Honest validator guide changes](specs/electra/validator.md)</li></ul></ul> |
| Sharding (outdated) | <ul><li>Core</li><ul><li>[Beacon Chain changes](specs/_features/sharding/beacon-chain.md)</li></ul><li>Additions</li><ul><li>[P2P networking](specs/_features/sharding/p2p-interface.md)</li></ul></ul> | | Sharding (outdated) | <ul><li>Core</li><ul><li>[Beacon Chain changes](specs/_features/sharding/beacon-chain.md)</li></ul><li>Additions</li><ul><li>[P2P networking](specs/_features/sharding/p2p-interface.md)</li></ul></ul> |
| Custody Game (outdated) | <ul><li>Core</li><ul><li>[Beacon Chain changes](specs/_features/custody_game/beacon-chain.md)</li></ul><li>Additions</li><ul><li>[Honest validator guide changes](specs/_features/custody_game/validator.md)</li></ul></ul> | Dependent on sharding | | Custody Game (outdated) | <ul><li>Core</li><ul><li>[Beacon Chain changes](specs/_features/custody_game/beacon-chain.md)</li></ul><li>Additions</li><ul><li>[Honest validator guide changes](specs/_features/custody_game/validator.md)</li></ul></ul> | Dependent on sharding |
| Data Availability Sampling (outdated) | <ul><li>Core</li><ul><li>[Core types and functions](specs/_features/das/das-core.md)</li><li>[Fork choice changes](specs/_features/das/fork-choice.md)</li></ul><li>Additions</li><ul><li>[P2P Networking](specs/_features/das/p2p-interface.md)</li><li>[Sampling process](specs/_features/das/sampling.md)</li></ul></ul> | <ul><li> Dependent on sharding</li><li>[Technical explainer](https://hackmd.io/@HWeNw8hNRimMm2m2GH56Cw/B1YJPGkpD)</li></ul> | | Data Availability Sampling (outdated) | <ul><li>Core</li><ul><li>[Core types and functions](specs/_features/das/das-core.md)</li><li>[Fork choice changes](specs/_features/das/fork-choice.md)</li></ul><li>Additions</li><ul><li>[P2P Networking](specs/_features/das/p2p-interface.md)</li><li>[Sampling process](specs/_features/das/sampling.md)</li></ul></ul> | <ul><li> Dependent on sharding</li><li>[Technical explainer](https://hackmd.io/@HWeNw8hNRimMm2m2GH56Cw/B1YJPGkpD)</li></ul> |
| EIP-6110 | <ul><li>Core</li><ul><li>[Beacon Chain changes](specs/_features/electra//beacon-chain.md)</li><li>[EIP-6110 fork](specs/_features/electra/fork.md)</li></ul><li>Additions</li><ul><li>[Honest validator guide changes](specs/_features/electra/validator.md)</li></ul></ul> |
### Accompanying documents can be found in [specs](specs) and include: ### Accompanying documents can be found in [specs](specs) and include:

View File

@ -1,4 +1,6 @@
# EIP-6110 -- The Beacon Chain # Electra -- The Beacon Chain
**Notice**: This document is a work-in-progress for researchers and implementers.
## Table of contents ## Table of contents
@ -30,10 +32,8 @@
## Introduction ## Introduction
This is the beacon chain specification of in-protocol deposits processing mechanism. Electra is a consensus-layer upgrade containing a number of features. Including:
This mechanism relies on the changes proposed by [EIP-6110](http://eips.ethereum.org/EIPS/eip-6110). * [EIP-6110](https://eips.ethereum.org/EIPS/eip-6110): Supply validator deposits on chain
*Note:* This specification is built upon [Deneb](../../deneb/beacon-chain.md) and is under active development.
## Constants ## Constants
@ -41,9 +41,9 @@ The following values are (non-configurable) constants used throughout the specif
### Misc ### Misc
| Name | Value | | Name | Value | Description |
| - | - | | - | - | - |
| `UNSET_DEPOSIT_RECEIPTS_START_INDEX` | `uint64(2**64 - 1)` | | `UNSET_DEPOSIT_RECEIPTS_START_INDEX` | `uint64(2**64 - 1)` | *[New in Electra:EIP6110]* |
## Preset ## Preset
@ -51,7 +51,7 @@ The following values are (non-configurable) constants used throughout the specif
| Name | Value | Description | | Name | Value | Description |
| - | - | - | | - | - | - |
| `MAX_DEPOSIT_RECEIPTS_PER_PAYLOAD` | `uint64(2**13)` (= 8,192) | Maximum number of deposit receipts allowed in each payload | | `MAX_DEPOSIT_RECEIPTS_PER_PAYLOAD` | `uint64(2**13)` (= 8,192) | *[New in Electra:EIP6110]* Maximum number of deposit receipts allowed in each payload |
## Containers ## Containers
@ -59,6 +59,8 @@ The following values are (non-configurable) constants used throughout the specif
#### `DepositReceipt` #### `DepositReceipt`
*Note*: The container is new in EIP6110.
```python ```python
class DepositReceipt(Container): class DepositReceipt(Container):
pubkey: BLSPubkey pubkey: BLSPubkey
@ -93,7 +95,7 @@ class ExecutionPayload(Container):
withdrawals: List[Withdrawal, MAX_WITHDRAWALS_PER_PAYLOAD] withdrawals: List[Withdrawal, MAX_WITHDRAWALS_PER_PAYLOAD]
blob_gas_used: uint64 blob_gas_used: uint64
excess_blob_gas: uint64 excess_blob_gas: uint64
deposit_receipts: List[DepositReceipt, MAX_DEPOSIT_RECEIPTS_PER_PAYLOAD] # [New in EIP6110] deposit_receipts: List[DepositReceipt, MAX_DEPOSIT_RECEIPTS_PER_PAYLOAD] # [New in Electra:EIP6110]
``` ```
#### `ExecutionPayloadHeader` #### `ExecutionPayloadHeader`
@ -119,7 +121,7 @@ class ExecutionPayloadHeader(Container):
withdrawals_root: Root withdrawals_root: Root
blob_gas_used: uint64 blob_gas_used: uint64
excess_blob_gas: uint64 excess_blob_gas: uint64
deposit_receipts_root: Root # [New in EIP6110] deposit_receipts_root: Root # [New in Electra:EIP6110]
``` ```
#### `BeaconState` #### `BeaconState`
@ -161,13 +163,13 @@ class BeaconState(Container):
current_sync_committee: SyncCommittee current_sync_committee: SyncCommittee
next_sync_committee: SyncCommittee next_sync_committee: SyncCommittee
# Execution # Execution
latest_execution_payload_header: ExecutionPayloadHeader # [Modified in EIP6110] latest_execution_payload_header: ExecutionPayloadHeader # [Modified in Electra:EIP6110]
# Withdrawals # Withdrawals
next_withdrawal_index: WithdrawalIndex next_withdrawal_index: WithdrawalIndex
next_withdrawal_validator_index: ValidatorIndex next_withdrawal_validator_index: ValidatorIndex
# Deep history valid from Capella onwards # Deep history valid from Capella onwards
historical_summaries: List[HistoricalSummary, HISTORICAL_ROOTS_LIMIT] historical_summaries: List[HistoricalSummary, HISTORICAL_ROOTS_LIMIT]
# [New in EIP6110] # [New in Electra:EIP6110]
deposit_receipts_start_index: uint64 deposit_receipts_start_index: uint64
``` ```
@ -179,10 +181,10 @@ class BeaconState(Container):
def process_block(state: BeaconState, block: BeaconBlock) -> None: def process_block(state: BeaconState, block: BeaconBlock) -> None:
process_block_header(state, block) process_block_header(state, block)
process_withdrawals(state, block.body.execution_payload) process_withdrawals(state, block.body.execution_payload)
process_execution_payload(state, block.body, EXECUTION_ENGINE) # [Modified in EIP6110] process_execution_payload(state, block.body, EXECUTION_ENGINE) # [Modified in Electra:EIP6110]
process_randao(state, block.body) process_randao(state, block.body)
process_eth1_data(state, block.body) process_eth1_data(state, block.body)
process_operations(state, block.body) # [Modified in EIP6110] process_operations(state, block.body) # [Modified in Electra:EIP6110]
process_sync_aggregate(state, block.body.sync_aggregate) process_sync_aggregate(state, block.body.sync_aggregate)
``` ```
@ -192,7 +194,7 @@ def process_block(state: BeaconState, block: BeaconBlock) -> None:
```python ```python
def process_operations(state: BeaconState, body: BeaconBlockBody) -> None: def process_operations(state: BeaconState, body: BeaconBlockBody) -> None:
# [Modified in EIP6110] # [Modified in Electra:EIP6110]
# Disable former deposit mechanism once all prior deposits are processed # Disable former deposit mechanism once all prior deposits are processed
eth1_deposit_index_limit = min(state.eth1_data.deposit_count, state.deposit_receipts_start_index) eth1_deposit_index_limit = min(state.eth1_data.deposit_count, state.deposit_receipts_start_index)
if state.eth1_deposit_index < eth1_deposit_index_limit: if state.eth1_deposit_index < eth1_deposit_index_limit:
@ -217,6 +219,8 @@ def process_operations(state: BeaconState, body: BeaconBlockBody) -> None:
#### New `process_deposit_receipt` #### New `process_deposit_receipt`
*Note*: This function is new in Electra:EIP6110.
```python ```python
def process_deposit_receipt(state: BeaconState, deposit_receipt: DepositReceipt) -> None: def process_deposit_receipt(state: BeaconState, deposit_receipt: DepositReceipt) -> None:
# Set deposit receipt start index # Set deposit receipt start index
@ -276,17 +280,17 @@ def process_execution_payload(state: BeaconState, body: BeaconBlockBody, executi
withdrawals_root=hash_tree_root(payload.withdrawals), withdrawals_root=hash_tree_root(payload.withdrawals),
blob_gas_used=payload.blob_gas_used, blob_gas_used=payload.blob_gas_used,
excess_blob_gas=payload.excess_blob_gas, excess_blob_gas=payload.excess_blob_gas,
deposit_receipts_root=hash_tree_root(payload.deposit_receipts), # [New in EIP6110] deposit_receipts_root=hash_tree_root(payload.deposit_receipts), # [New in Electra:EIP6110]
) )
``` ```
## Testing ## Testing
*Note*: The function `initialize_beacon_state_from_eth1` is modified for pure EIP-6110 testing only. *Note*: The function `initialize_beacon_state_from_eth1` is modified for pure Electra testing only.
Modifications include: Modifications include:
1. Use `ELECTRA_FORK_VERSION` as the previous and current fork version. 1. Use `ELECTRA_FORK_VERSION` as the previous and current fork version.
2. Utilize the EIP-6110 `BeaconBlockBody` when constructing the initial `latest_block_header`. 2. Utilize the Electra `BeaconBlockBody` when constructing the initial `latest_block_header`.
3. Add `deposit_receipts_start_index` variable to the genesis state initialization. 3. *[New in Electra:EIP6110]* Add `deposit_receipts_start_index` variable to the genesis state initialization.
```python ```python
def initialize_beacon_state_from_eth1(eth1_block_hash: Hash32, def initialize_beacon_state_from_eth1(eth1_block_hash: Hash32,
@ -295,8 +299,8 @@ def initialize_beacon_state_from_eth1(eth1_block_hash: Hash32,
execution_payload_header: ExecutionPayloadHeader=ExecutionPayloadHeader() execution_payload_header: ExecutionPayloadHeader=ExecutionPayloadHeader()
) -> BeaconState: ) -> BeaconState:
fork = Fork( fork = Fork(
previous_version=ELECTRA_FORK_VERSION, # [Modified in EIP6110] for testing only previous_version=ELECTRA_FORK_VERSION, # [Modified in Electra:EIP6110] for testing only
current_version=ELECTRA_FORK_VERSION, # [Modified in EIP6110] current_version=ELECTRA_FORK_VERSION, # [Modified in Electra:EIP6110]
epoch=GENESIS_EPOCH, epoch=GENESIS_EPOCH,
) )
state = BeaconState( state = BeaconState(
@ -305,7 +309,7 @@ def initialize_beacon_state_from_eth1(eth1_block_hash: Hash32,
eth1_data=Eth1Data(block_hash=eth1_block_hash, deposit_count=uint64(len(deposits))), eth1_data=Eth1Data(block_hash=eth1_block_hash, deposit_count=uint64(len(deposits))),
latest_block_header=BeaconBlockHeader(body_root=hash_tree_root(BeaconBlockBody())), latest_block_header=BeaconBlockHeader(body_root=hash_tree_root(BeaconBlockBody())),
randao_mixes=[eth1_block_hash] * EPOCHS_PER_HISTORICAL_VECTOR, # Seed RANDAO with Eth1 entropy randao_mixes=[eth1_block_hash] * EPOCHS_PER_HISTORICAL_VECTOR, # Seed RANDAO with Eth1 entropy
deposit_receipts_start_index=UNSET_DEPOSIT_RECEIPTS_START_INDEX, # [New in EIP6110] deposit_receipts_start_index=UNSET_DEPOSIT_RECEIPTS_START_INDEX, # [New in Electra:EIP6110]
) )
# Process deposits # Process deposits

View File

@ -1,4 +1,4 @@
# EIP-6110 -- Fork Logic # Electra -- Fork Logic
**Notice**: This document is a work-in-progress for researchers and implementers. **Notice**: This document is a work-in-progress for researchers and implementers.
@ -12,7 +12,7 @@
- [Helper functions](#helper-functions) - [Helper functions](#helper-functions)
- [Misc](#misc) - [Misc](#misc)
- [Modified `compute_fork_version`](#modified-compute_fork_version) - [Modified `compute_fork_version`](#modified-compute_fork_version)
- [Fork to EIP-6110](#fork-to-eip-6110) - [Fork to Electra](#fork-to-electra)
- [Fork trigger](#fork-trigger) - [Fork trigger](#fork-trigger)
- [Upgrading the state](#upgrading-the-state) - [Upgrading the state](#upgrading-the-state)
@ -55,19 +55,19 @@ def compute_fork_version(epoch: Epoch) -> Version:
return GENESIS_FORK_VERSION return GENESIS_FORK_VERSION
``` ```
## Fork to EIP-6110 ## Fork to Electra
### Fork trigger ### Fork trigger
TBD. This fork is defined for testing purposes, the EIP may be combined with other consensus-layer upgrade. TBD. This fork is defined for testing purposes, the EIP may be combined with other consensus-layer upgrade.
For now, we assume the condition will be triggered at epoch `ELECTRA_FORK_EPOCH`. For now, we assume the condition will be triggered at epoch `ELECTRA_FORK_EPOCH`.
Note that for the pure EIP-6110 networks, we don't apply `upgrade_to_electra` since it starts with EIP-6110 version logic. Note that for the pure Electra networks, we don't apply `upgrade_to_electra` since it starts with Electra version logic.
### Upgrading the state ### Upgrading the state
If `state.slot % SLOTS_PER_EPOCH == 0` and `compute_epoch_at_slot(state.slot) == ELECTRA_FORK_EPOCH`, If `state.slot % SLOTS_PER_EPOCH == 0` and `compute_epoch_at_slot(state.slot) == ELECTRA_FORK_EPOCH`,
an irregular state change is made to upgrade to EIP-6110. an irregular state change is made to upgrade to Electra.
```python ```python
def upgrade_to_electra(pre: deneb.BeaconState) -> BeaconState: def upgrade_to_electra(pre: deneb.BeaconState) -> BeaconState:
@ -90,7 +90,7 @@ def upgrade_to_electra(pre: deneb.BeaconState) -> BeaconState:
withdrawals_root=pre.latest_execution_payload_header.withdrawals_root, withdrawals_root=pre.latest_execution_payload_header.withdrawals_root,
blob_gas_used=uint64(0), blob_gas_used=uint64(0),
excess_blob_gas=uint64(0), excess_blob_gas=uint64(0),
deposit_receipts_root=Root(), # [New in EIP-6110] deposit_receipts_root=Root(), # [New in Electra:EIP6110]
) )
post = BeaconState( post = BeaconState(
# Versioning # Versioning
@ -99,7 +99,7 @@ def upgrade_to_electra(pre: deneb.BeaconState) -> BeaconState:
slot=pre.slot, slot=pre.slot,
fork=Fork( fork=Fork(
previous_version=pre.fork.current_version, previous_version=pre.fork.current_version,
current_version=ELECTRA_FORK_VERSION, # [Modified in EIP-6110] current_version=ELECTRA_FORK_VERSION, # [Modified in Electra:EIP6110]
epoch=epoch, epoch=epoch,
), ),
# History # History
@ -132,14 +132,14 @@ def upgrade_to_electra(pre: deneb.BeaconState) -> BeaconState:
current_sync_committee=pre.current_sync_committee, current_sync_committee=pre.current_sync_committee,
next_sync_committee=pre.next_sync_committee, next_sync_committee=pre.next_sync_committee,
# Execution-layer # Execution-layer
latest_execution_payload_header=latest_execution_payload_header, # [Modified in EIP-6110] latest_execution_payload_header=latest_execution_payload_header, # [Modified in Electra:EIP6110]
# Withdrawals # Withdrawals
next_withdrawal_index=pre.next_withdrawal_index, next_withdrawal_index=pre.next_withdrawal_index,
next_withdrawal_validator_index=pre.next_withdrawal_validator_index, next_withdrawal_validator_index=pre.next_withdrawal_validator_index,
# Deep history valid from Capella onwards # Deep history valid from Capella onwards
historical_summaries=pre.historical_summaries, historical_summaries=pre.historical_summaries,
# EIP-6110 # EIP6110
deposit_receipts_start_index=UNSET_DEPOSIT_RECEIPTS_START_INDEX, # [New in EIP-6110] deposit_receipts_start_index=UNSET_DEPOSIT_RECEIPTS_START_INDEX, # [New in Electra:EIP6110]
) )
return post return post

View File

@ -1,4 +1,4 @@
# EIP-6110 -- Honest Validator # Electra -- Honest Validator
## Table of contents ## Table of contents
@ -16,21 +16,21 @@
## Introduction ## Introduction
This document represents the changes to be made in the code of an "honest validator" to implement EIP-6110. This document represents the changes to be made in the code of an "honest validator" to implement Electra.
## Prerequisites ## Prerequisites
This document is an extension of the [Deneb -- Honest Validator](../../deneb/validator.md) guide. This document is an extension of the [Deneb -- Honest Validator](../../deneb/validator.md) guide.
All behaviors and definitions defined in this document, and documents it extends, carry over unless explicitly noted or overridden. All behaviors and definitions defined in this document, and documents it extends, carry over unless explicitly noted or overridden.
All terminology, constants, functions, and protocol mechanics defined in the updated Beacon Chain doc of [EIP-6110](./beacon-chain.md) are requisite for this document and used throughout. All terminology, constants, functions, and protocol mechanics defined in the updated Beacon Chain doc of [Electra](./beacon-chain.md) are requisite for this document and used throughout.
Please see related Beacon Chain doc before continuing and use them as a reference throughout. Please see related Beacon Chain doc before continuing and use them as a reference throughout.
## Block proposal ## Block proposal
### Deposits ### Deposits
The expected number of deposits MUST be changed from `min(MAX_DEPOSITS, eth1_data.deposit_count - state.eth1_deposit_index)` to the result of the following function: *[New in Electra:EIP6110* The expected number of deposits MUST be changed from `min(MAX_DEPOSITS, eth1_data.deposit_count - state.eth1_deposit_index)` to the result of the following function:
```python ```python
def get_eth1_pending_deposit_count(state: BeaconState) -> uint64: def get_eth1_pending_deposit_count(state: BeaconState) -> uint64: