diff --git a/consensus/state_processing/src/per_block_processing.rs b/consensus/state_processing/src/per_block_processing.rs index abb08d5a99f..7b0f2b64ec9 100644 --- a/consensus/state_processing/src/per_block_processing.rs +++ b/consensus/state_processing/src/per_block_processing.rs @@ -127,6 +127,17 @@ pub fn per_block_processing( state.build_committee_cache(RelativeEpoch::Previous, spec)?; state.build_committee_cache(RelativeEpoch::Current, spec)?; + // The call to the `process_execution_payload` must happen before the call to the + // `process_randao` as the former depends on the `randao_mix` computed with the reveal of the + // previous block. + if is_execution_enabled(state, block.body()) { + let payload = block + .body() + .execution_payload() + .ok_or(BlockProcessingError::IncorrectStateType)?; + process_execution_payload(state, payload, spec)?; + } + process_randao(state, block, verify_signatures, spec)?; process_eth1_data(state, block.body().eth1_data())?; process_operations(state, block.body(), proposer_index, verify_signatures, spec)?; @@ -141,14 +152,6 @@ pub fn per_block_processing( )?; } - if is_execution_enabled(state, block.body()) { - let payload = block - .body() - .execution_payload() - .ok_or(BlockProcessingError::IncorrectStateType)?; - process_execution_payload(state, payload, spec)?; - } - Ok(()) } @@ -344,13 +347,6 @@ pub fn process_execution_payload( found: payload.block_number, } ); - block_verify!( - payload.random == *state.get_randao_mix(state.current_epoch())?, - BlockProcessingError::ExecutionRandaoMismatch { - expected: *state.get_randao_mix(state.current_epoch())?, - found: payload.random, - } - ); block_verify!( is_valid_gas_limit(payload, state.latest_execution_payload_header()?)?, BlockProcessingError::ExecutionInvalidGasLimit { @@ -359,6 +355,13 @@ pub fn process_execution_payload( } ); } + block_verify!( + payload.random == *state.get_randao_mix(state.current_epoch())?, + BlockProcessingError::ExecutionRandaoMismatch { + expected: *state.get_randao_mix(state.current_epoch())?, + found: payload.random, + } + ); let timestamp = compute_timestamp_at_slot(state, spec)?; block_verify!( @@ -380,6 +383,7 @@ pub fn process_execution_payload( gas_limit: payload.gas_limit, gas_used: payload.gas_used, timestamp: payload.timestamp, + extra_data: payload.extra_data.clone(), base_fee_per_gas: payload.base_fee_per_gas, block_hash: payload.block_hash, transactions_root: payload.transactions.tree_hash_root(), diff --git a/consensus/types/src/eth_spec.rs b/consensus/types/src/eth_spec.rs index c45ecf8f7b6..f57aa48afbf 100644 --- a/consensus/types/src/eth_spec.rs +++ b/consensus/types/src/eth_spec.rs @@ -91,6 +91,7 @@ pub trait EthSpec: 'static + Default + Sync + Send + Clone + Debug + PartialEq + type BytesPerLogsBloom: Unsigned + Clone + Sync + Send + Debug + PartialEq; type GasLimitDenominator: Unsigned + Clone + Sync + Send + Debug + PartialEq; type MinGasLimit: Unsigned + Clone + Sync + Send + Debug + PartialEq; + type MaxExtraDataBytes: Unsigned + Clone + Sync + Send + Debug + PartialEq; /* * Derived values (set these CAREFULLY) */ @@ -262,6 +263,7 @@ impl EthSpec for MainnetEthSpec { type BytesPerLogsBloom = U256; type GasLimitDenominator = U1024; type MinGasLimit = U5000; + type MaxExtraDataBytes = U32; type SyncSubcommitteeSize = U128; // 512 committee size / 4 sync committee subnet count type MaxPendingAttestations = U4096; // 128 max attestations * 32 slots per epoch type SlotsPerEth1VotingPeriod = U2048; // 64 epochs * 32 slots per epoch @@ -308,7 +310,8 @@ impl EthSpec for MinimalEthSpec { MaxTransactionsPerPayload, BytesPerLogsBloom, GasLimitDenominator, - MinGasLimit + MinGasLimit, + MaxExtraDataBytes }); fn default_spec() -> ChainSpec { diff --git a/consensus/types/src/execution_payload.rs b/consensus/types/src/execution_payload.rs index 4311f2d5ff2..688d1239006 100644 --- a/consensus/types/src/execution_payload.rs +++ b/consensus/types/src/execution_payload.rs @@ -57,6 +57,8 @@ pub struct ExecutionPayload { pub gas_used: u64, #[serde(with = "eth2_serde_utils::quoted_u64")] pub timestamp: u64, + #[serde(with = "ssz_types::serde_utils::hex_var_list")] + pub extra_data: VariableList, pub base_fee_per_gas: Hash256, pub block_hash: Hash256, #[test_random(default)] @@ -77,6 +79,7 @@ impl ExecutionPayload { gas_limit: 0, gas_used: 0, timestamp: 0, + extra_data: VariableList::empty(), base_fee_per_gas: Hash256::zero(), block_hash: Hash256::zero(), transactions: VariableList::empty(), diff --git a/consensus/types/src/execution_payload_header.rs b/consensus/types/src/execution_payload_header.rs index 79129f4098e..e9876d89b94 100644 --- a/consensus/types/src/execution_payload_header.rs +++ b/consensus/types/src/execution_payload_header.rs @@ -24,6 +24,8 @@ pub struct ExecutionPayloadHeader { pub gas_used: u64, #[serde(with = "eth2_serde_utils::quoted_u64")] pub timestamp: u64, + #[serde(with = "ssz_types::serde_utils::hex_var_list")] + pub extra_data: VariableList, pub base_fee_per_gas: Hash256, pub block_hash: Hash256, pub transactions_root: Hash256,