package misc import ( "github.com/holiman/uint256" libcommon "github.com/ledgerwatch/erigon-lib/common" "github.com/ledgerwatch/erigon/consensus" "github.com/ledgerwatch/erigon/core/state" "github.com/ledgerwatch/erigon/core/types" "github.com/ledgerwatch/erigon/params" ) func ApplyBeaconRootEip4788(chain consensus.ChainHeaderReader, header *types.Header, state *state.IntraBlockState) { historyStorageAddress := libcommon.BytesToAddress(params.HistoryStorageAddress) historicalRootsModulus := params.HistoricalRootsModulus timestampReduced := header.Time % historicalRootsModulus timestampExtended := timestampReduced + historicalRootsModulus timestampIndex := libcommon.BytesToHash((uint256.NewInt(timestampReduced)).Bytes()) rootIndex := libcommon.BytesToHash(uint256.NewInt(timestampExtended).Bytes()) parentBeaconBlockRootInt := *uint256.NewInt(0).SetBytes(header.ParentBeaconBlockRoot.Bytes()) state.SetState(historyStorageAddress, ×tampIndex, *uint256.NewInt(header.Time)) state.SetState(historyStorageAddress, &rootIndex, parentBeaconBlockRootInt) // Ensure that the historyStorageAddress has nonzero nonce to prevent wipe-out of its storage stipulated by EIP-161 // (when the historyStorageAddress has zero balance). // See https://github.com/ethereum/EIPs/pull/7431 if state.GetNonce(historyStorageAddress) == 0 { state.SetNonce(historyStorageAddress, 1) } }