mirror of
https://gitlab.com/pulsechaincom/erigon-pulse.git
synced 2025-01-19 00:54:12 +00:00
88 lines
2.6 KiB
Go
88 lines
2.6 KiB
Go
package statechange
|
|
|
|
import (
|
|
"github.com/ledgerwatch/erigon/cl/abstract"
|
|
"github.com/ledgerwatch/erigon/cl/clparams"
|
|
"github.com/ledgerwatch/erigon/cl/cltypes/solid"
|
|
"github.com/ledgerwatch/erigon/cl/phase1/core/state"
|
|
)
|
|
|
|
func GetUnslashedIndiciesSet(s abstract.BeaconState) [][]bool {
|
|
if s.Version() == clparams.Phase0Version {
|
|
return nil
|
|
}
|
|
weights := s.BeaconConfig().ParticipationWeights()
|
|
flagsUnslashedIndiciesSet := make([][]bool, len(weights))
|
|
for i := range weights {
|
|
flagsUnslashedIndiciesSet[i] = make([]bool, s.ValidatorLength())
|
|
}
|
|
previousEpoch := state.PreviousEpoch(s)
|
|
|
|
s.ForEachValidator(func(validator solid.Validator, validatorIndex, total int) bool {
|
|
for i := range weights {
|
|
flagsUnslashedIndiciesSet[i][validatorIndex] = state.IsUnslashedParticipatingIndex(s, previousEpoch, uint64(validatorIndex), i)
|
|
}
|
|
return true
|
|
})
|
|
return flagsUnslashedIndiciesSet
|
|
}
|
|
|
|
// ProcessEpoch process epoch transition.
|
|
func ProcessEpoch(s abstract.BeaconState) error {
|
|
eligibleValidators := state.EligibleValidatorsIndicies(s)
|
|
// start := time.Now()
|
|
|
|
unslashedIndiciesSet := GetUnslashedIndiciesSet(s)
|
|
if err := ProcessJustificationBitsAndFinality(s, unslashedIndiciesSet); err != nil {
|
|
return err
|
|
}
|
|
// fmt.Println("ProcessJustificationBitsAndFinality", time.Since(start))
|
|
// start = time.Now()
|
|
|
|
if s.Version() >= clparams.AltairVersion {
|
|
if err := ProcessInactivityScores(s, eligibleValidators, unslashedIndiciesSet); err != nil {
|
|
return err
|
|
}
|
|
}
|
|
// fmt.Println("ProcessInactivityScores", time.Since(start))
|
|
// start = time.Now()
|
|
if err := ProcessRewardsAndPenalties(s, eligibleValidators, unslashedIndiciesSet); err != nil {
|
|
return err
|
|
}
|
|
// fmt.Println("ProcessRewardsAndPenalties", time.Since(start))
|
|
// start = time.Now()
|
|
if err := ProcessRegistryUpdates(s); err != nil {
|
|
return err
|
|
}
|
|
// fmt.Println("ProcessRegistryUpdates", time.Since(start))
|
|
// start = time.Now()
|
|
if err := ProcessSlashings(s); err != nil {
|
|
return err
|
|
}
|
|
// fmt.Println("ProcessSlashings", time.Since(start))
|
|
ProcessEth1DataReset(s)
|
|
// start = time.Now()
|
|
if err := ProcessEffectiveBalanceUpdates(s); err != nil {
|
|
return err
|
|
}
|
|
// fmt.Println("ProcessEffectiveBalanceUpdates", time.Since(start))
|
|
ProcessSlashingsReset(s)
|
|
ProcessRandaoMixesReset(s)
|
|
if err := ProcessHistoricalRootsUpdate(s); err != nil {
|
|
return err
|
|
}
|
|
if s.Version() == clparams.Phase0Version {
|
|
if err := ProcessParticipationRecordUpdates(s); err != nil {
|
|
return err
|
|
}
|
|
}
|
|
|
|
if s.Version() >= clparams.AltairVersion {
|
|
ProcessParticipationFlagUpdates(s)
|
|
if err := ProcessSyncCommitteeUpdate(s); err != nil {
|
|
return err
|
|
}
|
|
}
|
|
return nil
|
|
}
|