* add historical summaries * fix tree hash caching, disable the sanity slots test with fake crypto * add ssz static HistoricalSummary * only store historical summaries after capella * Teach `UpdatePattern` about Capella * Tidy EF tests * Clippy Co-authored-by: Michael Sproul <michael@sigmaprime.io>
79 lines
2.8 KiB
Rust
79 lines
2.8 KiB
Rust
use super::altair::inactivity_updates::process_inactivity_updates;
|
|
use super::altair::justification_and_finalization::process_justification_and_finalization;
|
|
use super::altair::participation_cache::ParticipationCache;
|
|
use super::altair::participation_flag_updates::process_participation_flag_updates;
|
|
use super::altair::rewards_and_penalties::process_rewards_and_penalties;
|
|
use super::altair::sync_committee_updates::process_sync_committee_updates;
|
|
use super::{process_registry_updates, process_slashings, EpochProcessingSummary, Error};
|
|
use crate::per_epoch_processing::{
|
|
effective_balance_updates::process_effective_balance_updates,
|
|
resets::{process_eth1_data_reset, process_randao_mixes_reset, process_slashings_reset},
|
|
};
|
|
use types::{BeaconState, ChainSpec, EthSpec, RelativeEpoch};
|
|
|
|
pub use historical_summaries_update::process_historical_summaries_update;
|
|
|
|
mod historical_summaries_update;
|
|
|
|
pub fn process_epoch<T: EthSpec>(
|
|
state: &mut BeaconState<T>,
|
|
spec: &ChainSpec,
|
|
) -> Result<EpochProcessingSummary<T>, Error> {
|
|
// Ensure the committee caches are built.
|
|
state.build_committee_cache(RelativeEpoch::Previous, spec)?;
|
|
state.build_committee_cache(RelativeEpoch::Current, spec)?;
|
|
state.build_committee_cache(RelativeEpoch::Next, spec)?;
|
|
|
|
// Pre-compute participating indices and total balances.
|
|
let participation_cache = ParticipationCache::new(state, spec)?;
|
|
let sync_committee = state.current_sync_committee()?.clone();
|
|
|
|
// Justification and finalization.
|
|
let justification_and_finalization_state =
|
|
process_justification_and_finalization(state, &participation_cache)?;
|
|
justification_and_finalization_state.apply_changes_to_state(state);
|
|
|
|
process_inactivity_updates(state, &participation_cache, spec)?;
|
|
|
|
// Rewards and Penalties.
|
|
process_rewards_and_penalties(state, &participation_cache, spec)?;
|
|
|
|
// Registry Updates.
|
|
process_registry_updates(state, spec)?;
|
|
|
|
// Slashings.
|
|
process_slashings(
|
|
state,
|
|
participation_cache.current_epoch_total_active_balance(),
|
|
spec,
|
|
)?;
|
|
|
|
// Reset eth1 data votes.
|
|
process_eth1_data_reset(state)?;
|
|
|
|
// Update effective balances with hysteresis (lag).
|
|
process_effective_balance_updates(state, spec)?;
|
|
|
|
// Reset slashings
|
|
process_slashings_reset(state)?;
|
|
|
|
// Set randao mix
|
|
process_randao_mixes_reset(state)?;
|
|
|
|
// Set historical summaries accumulator
|
|
process_historical_summaries_update(state)?;
|
|
|
|
// Rotate current/previous epoch participation
|
|
process_participation_flag_updates(state)?;
|
|
|
|
process_sync_committee_updates(state, spec)?;
|
|
|
|
// Rotate the epoch caches to suit the epoch transition.
|
|
state.advance_caches(spec)?;
|
|
|
|
Ok(EpochProcessingSummary::Altair {
|
|
participation_cache,
|
|
sync_committee,
|
|
})
|
|
}
|