mirror of
https://gitlab.com/pulsechaincom/prysm-pulse.git
synced 2025-01-12 12:40:05 +00:00
7cc32c4dda
* remove unused code * remove defer use in loop * Remove unused methods and constants * gofmt and gaz * nilness check * remove unused args * Add TODO for refactoring subscribeWithBase to remove unused arg. It seems too involved to include in this sweeping PR. https://github.com/prysmaticlabs/prysm/issues/7437 * replace empty slice declaration * Remove unnecessary type conversions * remove redundant type declaration * rename receivers to be consistent * Remove bootnode query tool. It is now obsolete by discv5 * Remove relay node. It is no longer used or supported * Revert "Remove relay node. It is no longer used or supported" This reverts commit 4bd7717334dad85ef4766ed9bc4da711fb5fa810. * Delete unused test directory * Delete unsupported gcp startup script * Delete old k8s script * build fixes * fix build * go mod tidy * revert slasher/db/kv/block_header.go * fix build * remove redundant nil check * combine func args Co-authored-by: prylabs-bulldozer[bot] <58059840+prylabs-bulldozer[bot]@users.noreply.github.com> Co-authored-by: Victor Farazdagi <simple.square@gmail.com>
84 lines
2.7 KiB
Go
84 lines
2.7 KiB
Go
package stategen
|
|
|
|
import (
|
|
"context"
|
|
|
|
ethpb "github.com/prysmaticlabs/ethereumapis/eth/v1alpha1"
|
|
"github.com/prysmaticlabs/prysm/beacon-chain/core/helpers"
|
|
"github.com/prysmaticlabs/prysm/beacon-chain/state"
|
|
pb "github.com/prysmaticlabs/prysm/proto/beacon/p2p/v1"
|
|
"github.com/prysmaticlabs/prysm/shared/bytesutil"
|
|
"github.com/prysmaticlabs/prysm/shared/params"
|
|
"go.opencensus.io/trace"
|
|
)
|
|
|
|
// SaveState saves the state in the cache and/or DB.
|
|
func (s *State) SaveState(ctx context.Context, root [32]byte, state *state.BeaconState) error {
|
|
ctx, span := trace.StartSpan(ctx, "stateGen.SaveState")
|
|
defer span.End()
|
|
|
|
return s.saveStateByRoot(ctx, root, state)
|
|
}
|
|
|
|
// ForceCheckpoint initiates a cold state save of the given state. This method does not update the
|
|
// "last archived state" but simply saves the specified state from the root argument into the DB.
|
|
func (s *State) ForceCheckpoint(ctx context.Context, root []byte) error {
|
|
ctx, span := trace.StartSpan(ctx, "stateGen.ForceCheckpoint")
|
|
defer span.End()
|
|
|
|
root32 := bytesutil.ToBytes32(root)
|
|
// Before the first finalized check point, the finalized root is zero hash.
|
|
// Return early if there hasn't been a finalized check point.
|
|
if root32 == params.BeaconConfig().ZeroHash {
|
|
return nil
|
|
}
|
|
|
|
fs, err := s.loadStateByRoot(ctx, root32)
|
|
if err != nil {
|
|
return err
|
|
}
|
|
|
|
return s.beaconDB.SaveState(ctx, fs, root32)
|
|
}
|
|
|
|
// SaveStateSummary saves the relevant state summary for a block and its corresponding state slot in the
|
|
// state summary cache.
|
|
func (s *State) SaveStateSummary(_ context.Context, blk *ethpb.SignedBeaconBlock, blockRoot [32]byte) {
|
|
// Save State summary
|
|
s.stateSummaryCache.Put(blockRoot, &pb.StateSummary{
|
|
Slot: blk.Block.Slot,
|
|
Root: blockRoot[:],
|
|
})
|
|
}
|
|
|
|
// This saves a post beacon state. On the epoch boundary,
|
|
// it saves a full state. On an intermediate slot, it saves a back pointer to the
|
|
// nearest epoch boundary state.
|
|
func (s *State) saveStateByRoot(ctx context.Context, blockRoot [32]byte, state *state.BeaconState) error {
|
|
ctx, span := trace.StartSpan(ctx, "stateGen.saveStateByRoot")
|
|
defer span.End()
|
|
|
|
// If the hot state is already in cache, one can be sure the state was processed and in the DB.
|
|
if s.hotStateCache.Has(blockRoot) {
|
|
return nil
|
|
}
|
|
|
|
// Only on an epoch boundary slot, saves epoch boundary state in epoch boundary root state cache.
|
|
if helpers.IsEpochStart(state.Slot()) {
|
|
if err := s.epochBoundaryStateCache.put(blockRoot, state); err != nil {
|
|
return err
|
|
}
|
|
}
|
|
|
|
// On an intermediate slots, save the hot state summary.
|
|
s.stateSummaryCache.Put(blockRoot, &pb.StateSummary{
|
|
Slot: state.Slot(),
|
|
Root: blockRoot[:],
|
|
})
|
|
|
|
// Store the copied state in the hot state cache.
|
|
s.hotStateCache.Put(blockRoot, state)
|
|
|
|
return nil
|
|
}
|