erigon-pulse/cmd/erigon-cl/core/state/upgrade.go
2023-05-07 01:37:53 +02:00

111 lines
3.3 KiB
Go

package state
import (
libcommon "github.com/ledgerwatch/erigon-lib/common"
"github.com/ledgerwatch/erigon/cl/clparams"
"github.com/ledgerwatch/erigon/cl/cltypes"
"github.com/ledgerwatch/erigon/cl/utils"
)
func (b *BeaconState) UpgradeToAltair() error {
b.previousStateRoot = libcommon.Hash{}
epoch := Epoch(b.BeaconState)
// update version
fork := b.Fork()
fork.Epoch = epoch
fork.CurrentVersion = utils.Uint32ToBytes4(b.BeaconConfig().AltairForkVersion)
b.SetFork(fork)
// Process new fields
b.SetPreviousEpochParticipationFlags(make(cltypes.ParticipationFlagsList, b.ValidatorLength()))
b.SetCurrentEpochParticipationFlags(make(cltypes.ParticipationFlagsList, b.ValidatorLength()))
b.SetInactivityScores(make([]uint64, b.ValidatorLength()))
// Change version
b.SetVersion(clparams.AltairVersion)
// Fill in previous epoch participation from the pre state's pending attestations
for _, attestation := range b.PreviousEpochAttestations() {
flags, err := b.GetAttestationParticipationFlagIndicies(attestation.Data, attestation.InclusionDelay)
if err != nil {
return err
}
indices, err := b.GetAttestingIndicies(attestation.Data, attestation.AggregationBits, false)
if err != nil {
return err
}
for _, index := range indices {
for _, flagIndex := range flags {
b.AddPreviousEpochParticipationAt(int(index), flagIndex)
}
}
}
b.ResetPreviousEpochAttestations()
// Process sync committees
var err error
currentSyncCommittee, err := b.ComputeNextSyncCommittee()
if err != nil {
return err
}
b.SetCurrentSyncCommittee(currentSyncCommittee)
nextSyncCommittee, err := b.ComputeNextSyncCommittee()
if err != nil {
return err
}
b.SetNextSyncCommittee(nextSyncCommittee)
return nil
}
func (b *BeaconState) UpgradeToBellatrix() error {
b.previousStateRoot = libcommon.Hash{}
epoch := Epoch(b.BeaconState)
// update version
fork := b.Fork()
fork.Epoch = epoch
fork.PreviousVersion = fork.CurrentVersion
fork.CurrentVersion = utils.Uint32ToBytes4(b.BeaconConfig().BellatrixForkVersion)
b.SetFork(fork)
b.SetLatestExecutionPayloadHeader(cltypes.NewEth1Header(clparams.BellatrixVersion))
// Update the state root cache
b.SetVersion(clparams.BellatrixVersion)
return nil
}
func (b *BeaconState) UpgradeToCapella() error {
b.previousStateRoot = libcommon.Hash{}
epoch := Epoch(b.BeaconState)
// update version
fork := b.Fork()
fork.Epoch = epoch
fork.PreviousVersion = fork.CurrentVersion
fork.CurrentVersion = utils.Uint32ToBytes4(b.BeaconConfig().CapellaForkVersion)
b.SetFork(fork)
// Update the payload header.
header := b.LatestExecutionPayloadHeader()
header.Capella()
b.SetLatestExecutionPayloadHeader(header)
// Set new fields
b.SetNextWithdrawalIndex(0)
b.SetNextWithdrawalValidatorIndex(0)
b.ResetHistoricalSummaries()
// Update the state root cache
b.SetVersion(clparams.CapellaVersion)
return nil
}
func (b *BeaconState) UpgradeToDeneb() error {
b.previousStateRoot = libcommon.Hash{}
epoch := Epoch(b.BeaconState)
// update version
fork := b.Fork()
fork.Epoch = epoch
fork.PreviousVersion = fork.CurrentVersion
fork.CurrentVersion = utils.Uint32ToBytes4(b.BeaconConfig().DenebForkVersion)
b.SetFork(fork)
// Update the payload header.
header := b.LatestExecutionPayloadHeader()
header.Deneb()
b.SetLatestExecutionPayloadHeader(header)
// Update the state root cache
b.SetVersion(clparams.DenebVersion)
return nil
}