From b737e5370fee75af306a93a4d86f4a9ed7ca2220 Mon Sep 17 00:00:00 2001 From: Enrico Del Fante Date: Wed, 16 Nov 2022 12:12:18 +0100 Subject: [PATCH 1/3] fix state upgrade --- specs/eip4844/fork.md | 21 +++++++++++++++++++-- 1 file changed, 19 insertions(+), 2 deletions(-) diff --git a/specs/eip4844/fork.md b/specs/eip4844/fork.md index eaabba916..18d334261 100644 --- a/specs/eip4844/fork.md +++ b/specs/eip4844/fork.md @@ -66,8 +66,25 @@ Since the `eip4844.BeaconState` format is equal to the `bellatrix.BeaconState` f ```python def upgrade_to_eip4844(pre: bellatrix.BeaconState) -> BeaconState: - # TODO: if Capella gets scheduled, add sync it with Capella.BeaconState + # TODO: if Capella gets scheduled, add sync it with Capella.BeaconState and Capella.ExecutionPayloadHeader epoch = bellatrix.get_current_epoch(pre) + latest_execution_payload_header = ExecutionPayloadHeader( + parent_hash=pre.latest_execution_payload_header.parent_hash, + fee_recipient=pre.latest_execution_payload_header.fee_recipient, + state_root=pre.latest_execution_payload_header.state_root, + receipts_root=pre.latest_execution_payload_header.receipts_root, + logs_bloom=pre.latest_execution_payload_header.logs_bloom, + prev_randao=pre.latest_execution_payload_header.prev_randao, + block_number=pre.latest_execution_payload_header.block_number, + gas_limit=pre.latest_execution_payload_header.gas_limit, + gas_used=pre.latest_execution_payload_header.gas_used, + timestamp=pre.latest_execution_payload_header.timestamp, + extra_data=pre.latest_execution_payload_header.extra_data, + base_fee_per_gas=pre.latest_execution_payload_header.base_fee_per_gas, + excess_blobs=uint64(0), # [New in EIP-4844] + block_hash=pre.latest_execution_payload_header.block_hash, + transactions_root=pre.latest_execution_payload_header.transactions_root, + ) post = BeaconState( # Versioning genesis_time=pre.genesis_time, @@ -108,7 +125,7 @@ def upgrade_to_eip4844(pre: bellatrix.BeaconState) -> BeaconState: current_sync_committee=pre.current_sync_committee, next_sync_committee=pre.next_sync_committee, # Execution-layer - latest_execution_payload_header=pre.latest_execution_payload_header, + latest_execution_payload_header=latest_execution_payload_header, ) return post From 620943b2756fa28a767a3f6dd470e68449a233de Mon Sep 17 00:00:00 2001 From: Enrico Del Fante Date: Wed, 16 Nov 2022 19:19:39 +0100 Subject: [PATCH 2/3] Update specs/eip4844/fork.md Co-authored-by: Alex Stokes --- specs/eip4844/fork.md | 2 +- 1 file changed, 1 insertion(+), 1 deletion(-) diff --git a/specs/eip4844/fork.md b/specs/eip4844/fork.md index 18d334261..fcae85c25 100644 --- a/specs/eip4844/fork.md +++ b/specs/eip4844/fork.md @@ -66,7 +66,7 @@ Since the `eip4844.BeaconState` format is equal to the `bellatrix.BeaconState` f ```python def upgrade_to_eip4844(pre: bellatrix.BeaconState) -> BeaconState: - # TODO: if Capella gets scheduled, add sync it with Capella.BeaconState and Capella.ExecutionPayloadHeader + # TODO: if Capella gets scheduled, add sync it with Capella.BeaconState epoch = bellatrix.get_current_epoch(pre) latest_execution_payload_header = ExecutionPayloadHeader( parent_hash=pre.latest_execution_payload_header.parent_hash, From 30dce7f232b1864ff4afdce8f3a2a80e0b69b11c Mon Sep 17 00:00:00 2001 From: Hsiao-Wei Wang Date: Fri, 18 Nov 2022 02:25:56 +0800 Subject: [PATCH 3/3] Apply suggestions from code review Co-authored-by: Alex Stokes --- specs/eip4844/fork.md | 3 ++- 1 file changed, 2 insertions(+), 1 deletion(-) diff --git a/specs/eip4844/fork.md b/specs/eip4844/fork.md index fcae85c25..8e3a727df 100644 --- a/specs/eip4844/fork.md +++ b/specs/eip4844/fork.md @@ -81,9 +81,10 @@ def upgrade_to_eip4844(pre: bellatrix.BeaconState) -> BeaconState: timestamp=pre.latest_execution_payload_header.timestamp, extra_data=pre.latest_execution_payload_header.extra_data, base_fee_per_gas=pre.latest_execution_payload_header.base_fee_per_gas, - excess_blobs=uint64(0), # [New in EIP-4844] + excess_data_gas=uint256(0), # [New in EIP-4844] block_hash=pre.latest_execution_payload_header.block_hash, transactions_root=pre.latest_execution_payload_header.transactions_root, + withdrawals_root=pre.latest_execution_payload_header.withdrawals_root, ) post = BeaconState( # Versioning