cross

package
v1.11.2 Latest Latest
Warning

This package is not in the latest version of its module.

Go to latest
Published: Feb 21, 2025 License: MIT Imports: 9 Imported by: 0

Documentation

Index

Constants

This section is empty.

Variables

View Source
var (
	ErrCycle                  = errors.New("cycle detected")
	ErrExecMsgHasInvalidIndex = errors.New("executing message has invalid log index")
	ErrExecMsgUnknownChain    = errors.New("executing message references unknown chain")
)

Functions

func CrossSafeHazards

func CrossSafeHazards(d SafeStartDeps, chainID eth.ChainID, inL1Source eth.BlockID,
	candidate types.BlockSeal, execMsgs []*types.ExecutingMessage) (hazards map[types.ChainIndex]types.BlockSeal, err error)

CrossSafeHazards checks if the given messages all exist and pass invariants. It returns a hazard-set: if any intra-block messaging happened, these hazard blocks have to be verified.

func CrossSafeUpdate

func CrossSafeUpdate(logger log.Logger, chainID eth.ChainID, d CrossSafeDeps) error

func CrossUnsafeHazards

func CrossUnsafeHazards(d UnsafeStartDeps, chainID eth.ChainID,
	candidate types.BlockSeal, execMsgs []*types.ExecutingMessage) (hazards map[types.ChainIndex]types.BlockSeal, err error)

CrossUnsafeHazards checks if the given messages all exist and pass invariants. It returns a hazard-set: if any intra-block messaging happened, these hazard blocks have to be verified.

func CrossUnsafeUpdate

func CrossUnsafeUpdate(logger log.Logger, chainID eth.ChainID, d CrossUnsafeDeps) error

func GenerateMermaidDiagram

func GenerateMermaidDiagram(g *graph) string

GenerateMermaidDiagram creates a Mermaid flowchart diagram from the graph data for debugging.

func HazardCycleChecks

func HazardCycleChecks(depSet depset.ChainIDFromIndex, d CycleCheckDeps, inTimestamp uint64, hazards map[types.ChainIndex]types.BlockSeal) error

HazardCycleChecks checks for cyclical dependencies between logs at the given timestamp. Here the timestamp invariant alone does not ensure ordering of messages.

We perform this check in 3 steps:

  • Gather all logs across all hazard blocks at the given timestamp.
  • Build the logs into a directed graph of dependencies between logs.
  • Check the graph for cycles.

The edges of the graph are determined by:

  • For all logs except the first in a block, there is an edge from the previous log.
  • For all executing messages, there is an edge from the initiating message.

The edges between sequential logs ensure the graph is well-connected and free of any disjoint subgraphs that would make cycle checking more difficult.

The cycle check is performed by executing Kahn's topological sort algorithm which succeeds if and only if a graph is acyclic.

Returns nil if no cycles are found or ErrCycle if a cycle is detected.

func HazardSafeFrontierChecks

func HazardSafeFrontierChecks(d SafeFrontierCheckDeps, inL1Source eth.BlockID, hazards map[types.ChainIndex]types.BlockSeal) error

HazardSafeFrontierChecks verifies all the hazard blocks are either:

  • already cross-safe.
  • the first (if not first: local blocks to verify before proceeding) local-safe block, after the cross-safe block.

func HazardUnsafeFrontierChecks

func HazardUnsafeFrontierChecks(d UnsafeFrontierCheckDeps, hazards map[types.ChainIndex]types.BlockSeal) error

HazardUnsafeFrontierChecks verifies all the hazard blocks are either:

  • already cross-unsafe.
  • the first (if not first: local blocks to verify before proceeding) local-unsafe block, after the cross-unsafe block.

Types

type CrossSafeDeps

type CrossSafeDeps interface {
	CrossSafe(chainID eth.ChainID) (pair types.DerivedBlockSealPair, err error)

	SafeFrontierCheckDeps
	SafeStartDeps

	CandidateCrossSafe(chain eth.ChainID) (candidate types.DerivedBlockRefPair, err error)
	NextSource(chain eth.ChainID, source eth.BlockID) (after eth.BlockRef, err error)
	PreviousDerived(chain eth.ChainID, derived eth.BlockID) (prevDerived types.BlockSeal, err error)

	OpenBlock(chainID eth.ChainID, blockNum uint64) (ref eth.BlockRef, logCount uint32, execMsgs map[uint32]*types.ExecutingMessage, err error)

	UpdateCrossSafe(chain eth.ChainID, l1View eth.BlockRef, lastCrossDerived eth.BlockRef) error

	// InvalidateLocalSafe is called when a local block cannot be upgraded to cross-safe, and has to be dropped.
	// This is called relative to what was determined based on the l1Scope.
	// It is called with the candidate, the block that will be invalidated.
	// The replacement of this candidate will effectively be "derived from"
	// the scope that the candidate block was invalidated at.
	InvalidateLocalSafe(chainID eth.ChainID, candidate types.DerivedBlockRefPair) error
}

type CrossSafeWorker added in v1.11.0

type CrossSafeWorker struct {
	// contains filtered or unexported fields
}

func NewCrossSafeWorker

func NewCrossSafeWorker(logger log.Logger, chainID eth.ChainID, d CrossSafeDeps) *CrossSafeWorker

func (*CrossSafeWorker) OnEvent added in v1.11.0

func (c *CrossSafeWorker) OnEvent(ev event.Event) bool

type CrossUnsafeDeps

type CrossUnsafeDeps interface {
	CrossUnsafe(chainID eth.ChainID) (types.BlockSeal, error)

	UnsafeStartDeps
	UnsafeFrontierCheckDeps

	OpenBlock(chainID eth.ChainID, blockNum uint64) (block eth.BlockRef, logCount uint32, execMsgs map[uint32]*types.ExecutingMessage, err error)

	UpdateCrossUnsafe(chain eth.ChainID, crossUnsafe types.BlockSeal) error
}

type CrossUnsafeWorker added in v1.11.0

type CrossUnsafeWorker struct {
	// contains filtered or unexported fields
}

func NewCrossUnsafeWorker

func NewCrossUnsafeWorker(logger log.Logger, chainID eth.ChainID, d CrossUnsafeDeps) *CrossUnsafeWorker

func (*CrossUnsafeWorker) OnEvent added in v1.11.0

func (c *CrossUnsafeWorker) OnEvent(ev event.Event) bool

type CycleCheckDeps

type CycleCheckDeps interface {
	// OpenBlock returns log data for the requested block, to be used for cycle checking.
	OpenBlock(chainID eth.ChainID, blockNum uint64) (block eth.BlockRef, logCount uint32, execMsgs map[uint32]*types.ExecutingMessage, err error)
}

CycleCheckDeps is an interface for checking cyclical dependencies between logs.

type SafeFrontierCheckDeps

type SafeFrontierCheckDeps interface {
	CandidateCrossSafe(chain eth.ChainID) (candidate types.DerivedBlockRefPair, err error)

	CrossDerivedToSource(chainID eth.ChainID, derived eth.BlockID) (source types.BlockSeal, err error)

	DependencySet() depset.DependencySet
}

type SafeStartDeps

type SafeStartDeps interface {
	Contains(chain eth.ChainID, query types.ContainsQuery) (includedIn types.BlockSeal, err error)

	CrossDerivedToSource(chainID eth.ChainID, derived eth.BlockID) (source types.BlockSeal, err error)

	DependencySet() depset.DependencySet
}

type UnsafeFrontierCheckDeps

type UnsafeFrontierCheckDeps interface {
	ParentBlock(chainID eth.ChainID, parentOf eth.BlockID) (parent eth.BlockID, err error)

	IsCrossUnsafe(chainID eth.ChainID, block eth.BlockID) error
	IsLocalUnsafe(chainID eth.ChainID, block eth.BlockID) error

	DependencySet() depset.DependencySet
}

type UnsafeStartDeps

type UnsafeStartDeps interface {
	Contains(chain eth.ChainID, query types.ContainsQuery) (includedIn types.BlockSeal, err error)

	IsCrossUnsafe(chainID eth.ChainID, block eth.BlockID) error

	DependencySet() depset.DependencySet
}

Jump to

Keyboard shortcuts

? : This menu
/ : Search site
f or F : Jump to
y or Y : Canonical URL