Skip to content
New issue

Have a question about this project? Sign up for a free GitHub account to open an issue and contact its maintainers and the community.

By clicking “Sign up for GitHub”, you agree to our terms of service and privacy statement. We’ll occasionally send you account related emails.

Already on GitHub? Sign in to your account

new epoch start blockchain hooks #6548

Open
wants to merge 56 commits into
base: rc/barnard
Choose a base branch
from
Open
Show file tree
Hide file tree
Changes from 44 commits
Commits
Show all changes
56 commits
Select commit Hold shift + click to select a range
a7e9294
add new blockchain hooks
laurci Jul 16, 2024
9ff3ca2
Merge remote-tracking branch 'origin/rc/v1.7.next1' into new-blockcha…
laurci Jul 24, 2024
67a99d6
Merge remote-tracking branch 'origin/rc/v1.7.2' into new-blockchain-h…
laurci Jul 25, 2024
f060fde
use cached epoch start block in vm blockchain hook
laurci Jul 26, 2024
a4b93be
tpn nil epoch start trigger
laurci Jul 26, 2024
c8ef463
use round handler to get round duration in blockchain hook
laurci Jul 26, 2024
9334561
fix nil pointer epoch start block header
laurci Jul 26, 2024
b9eef0c
nil checks for RoundHandler and EpochStartTriggerHandler
laurci Jul 29, 2024
f94bc3c
fix more RoundHandler nils in tests
laurci Jul 29, 2024
8d9114d
deep copy header when returning from trigger
laurci Jul 29, 2024
0684c29
epochStartHdr nil error check
laurci Jul 29, 2024
53f4563
propagate SetCurrentHeader errors
laurci Jul 30, 2024
0534fc4
remove log; epoch start hdr check if nil
laurci Jul 30, 2024
1f07ae2
simplify error handling in LastCommitedEpochStartHdr impl
laurci Jul 31, 2024
1877e0c
get epoch start block from storage for sc query
laurci Jul 31, 2024
6f64220
add comment for SetEpochStartHeader
laurci Aug 1, 2024
a333893
rc/1.7.2 update dependencies
laurci Aug 2, 2024
fc46b8b
managed buffer small ints gas cost
laurci Aug 2, 2024
5d877d8
formatting fixes
laurci Aug 2, 2024
4ac3ab5
update vm version
laurci Aug 2, 2024
a6a1af7
chainsimulator tests fixes
laurci Aug 7, 2024
e770491
more chain simulator tests fixing
laurci Aug 7, 2024
2a402b5
add warn logs for error cases in updateEpochStartHeaderFromCurrentHeader
laurci Aug 14, 2024
bc949a7
Merge remote-tracking branch 'origin/rc/barnard' into new-blockchain-…
laurci Oct 21, 2024
98a24b2
fixes after merge
sasurobert Oct 23, 2024
96d4de0
delete files
sasurobert Oct 23, 2024
dc39f02
Merge branch 'spica-to-barnard-23-okt' into new-blockchain-hooks
sasurobert Oct 23, 2024
c27f005
go mod tidy
sasurobert Oct 23, 2024
c47b844
go lint fixes
sasurobert Oct 23, 2024
4a2031b
Merge branch 'spica-to-barnard-23-okt' into new-blockchain-hooks
sasurobert Oct 28, 2024
71dcf66
merges
sasurobert Oct 28, 2024
0ae6ede
Merge branch 'rc/barnard' into new-blockchain-hooks
sasurobert Nov 4, 2024
6af33da
fallback read from storage for epoch start header
laurci Nov 11, 2024
5462659
log.Debug instead of Warn
laurci Nov 12, 2024
cd27078
fix: epoch start block for epoch 0 is the genesis block
laurci Nov 13, 2024
a050424
Merge branch 'rc/barnard' into new-blockchain-hooks
sasurobert Nov 14, 2024
23dab4f
Merge branch 'rc/barnard' into new-blockchain-hooks
laurci Nov 18, 2024
91a906a
fix set header order and add unit tests
laurci Nov 18, 2024
88b8ce5
add logs
laurci Nov 19, 2024
d190c37
don't set current header if epoch start fetch fails
laurci Nov 20, 2024
ea04d0d
don't mask storage error
laurci Nov 21, 2024
50a7149
request epoch start block hash
laurci Dec 2, 2024
39fe24b
request epoch start shard block
laurci Dec 2, 2024
dd9cb7d
request epoch start shard block
laurci Dec 3, 2024
3888988
epoch start shard header syncer
laurci Dec 4, 2024
35fd8f2
epoch start header syncer tests
laurci Dec 11, 2024
c85c294
more test fixing
laurci Dec 11, 2024
ca45571
fix shard check in storage save
laurci Dec 11, 2024
951c0fd
Merge branch 'rc/barnard' into new-blockchain-hooks
laurci Dec 11, 2024
2375301
add more tests and refactors
laurci Dec 12, 2024
77e77f1
Merge branch 'new-blockchain-hooks' of github.com:multiversx/mx-chain…
laurci Dec 12, 2024
f89b8f9
update vm version with new binaries
laurci Dec 22, 2024
6cd3429
use wait group in epoch start shard headers syncer concurrent tests
laurci Dec 22, 2024
114738d
update epoch start trigger tests
laurci Dec 22, 2024
4b564c0
more test coverage, fixes and cleanup
laurci Dec 22, 2024
9ca661f
delegation test fixes
laurci Dec 22, 2024
File filter

Filter by extension

Filter by extension


Conversations
Failed to load comments.
Loading
Jump to
Jump to file
Failed to load files.
Loading
Diff view
Diff view
9 changes: 9 additions & 0 deletions cmd/node/config/gasSchedules/gasScheduleV1.toml
Original file line number Diff line number Diff line change
Expand Up @@ -113,6 +113,11 @@
GetCodeMetadata = 10000
IsBuiltinFunction = 10000
IsReservedFunctionName = 10000
GetRoundTime = 1000
EpochStartBlockTimeStamp = 1000
EpochStartBlockNonce = 1000
EpochStartBlockRound = 1000


[EthAPICost]
UseGas = 100
Expand Down Expand Up @@ -237,6 +242,10 @@
MBufferSetRandom = 6000
MBufferToBigFloat = 2000
MBufferFromBigFloat = 2000
MBufferToSmallIntUnsigned = 10000
MBufferToSmallIntSigned = 10000
MBufferFromSmallIntUnsigned = 10000
MBufferFromSmallIntSigned = 10000

[BigFloatAPICost]
BigFloatNewFromParts = 3000
Expand Down
8 changes: 8 additions & 0 deletions cmd/node/config/gasSchedules/gasScheduleV2.toml
Original file line number Diff line number Diff line change
Expand Up @@ -113,6 +113,10 @@
GetCodeMetadata = 10000
IsBuiltinFunction = 10000
IsReservedFunctionName = 10000
GetRoundTime = 10000
EpochStartBlockTimeStamp = 10000
EpochStartBlockNonce = 10000
EpochStartBlockRound = 10000

[EthAPICost]
UseGas = 100
Expand Down Expand Up @@ -237,6 +241,10 @@
MBufferSetRandom = 6000
MBufferToBigFloat = 2000
MBufferFromBigFloat = 2000
MBufferToSmallIntUnsigned = 10000
MBufferToSmallIntSigned = 10000
MBufferFromSmallIntUnsigned = 10000
MBufferFromSmallIntSigned = 10000

[BigFloatAPICost]
BigFloatNewFromParts = 3000
Expand Down
8 changes: 8 additions & 0 deletions cmd/node/config/gasSchedules/gasScheduleV3.toml
Original file line number Diff line number Diff line change
Expand Up @@ -113,6 +113,10 @@
GetCodeMetadata = 10000
IsBuiltinFunction = 10000
IsReservedFunctionName = 10000
GetRoundTime = 10000
EpochStartBlockTimeStamp = 10000
EpochStartBlockNonce = 10000
EpochStartBlockRound = 10000

[EthAPICost]
UseGas = 100
Expand Down Expand Up @@ -237,6 +241,10 @@
MBufferSetRandom = 6000
MBufferToBigFloat = 2000
MBufferFromBigFloat = 2000
MBufferToSmallIntUnsigned = 10000
MBufferToSmallIntSigned = 10000
MBufferFromSmallIntUnsigned = 10000
MBufferFromSmallIntSigned = 10000

[BigFloatAPICost]
BigFloatNewFromParts = 3000
Expand Down
8 changes: 8 additions & 0 deletions cmd/node/config/gasSchedules/gasScheduleV4.toml
Original file line number Diff line number Diff line change
Expand Up @@ -113,6 +113,10 @@
GetCodeMetadata = 10000
IsBuiltinFunction = 10000
IsReservedFunctionName = 10000
GetRoundTime = 10000
EpochStartBlockTimeStamp = 10000
EpochStartBlockNonce = 10000
EpochStartBlockRound = 10000

[EthAPICost]
UseGas = 100
Expand Down Expand Up @@ -237,6 +241,10 @@
MBufferSetRandom = 6000
MBufferToBigFloat = 2000
MBufferFromBigFloat = 2000
MBufferToSmallIntUnsigned = 10000
MBufferToSmallIntSigned = 10000
MBufferFromSmallIntUnsigned = 10000
MBufferFromSmallIntSigned = 10000

[BigFloatAPICost]
BigFloatNewFromParts = 3000
Expand Down
8 changes: 8 additions & 0 deletions cmd/node/config/gasSchedules/gasScheduleV5.toml
Original file line number Diff line number Diff line change
Expand Up @@ -113,6 +113,10 @@
GetCodeMetadata = 10000
IsBuiltinFunction = 10000
IsReservedFunctionName = 10000
GetRoundTime = 10000
EpochStartBlockTimeStamp = 10000
EpochStartBlockNonce = 10000
EpochStartBlockRound = 10000

[EthAPICost]
UseGas = 100
Expand Down Expand Up @@ -237,6 +241,10 @@
MBufferSetRandom = 6000
MBufferToBigFloat = 2000
MBufferFromBigFloat = 2000
MBufferToSmallIntUnsigned = 10000
MBufferToSmallIntSigned = 10000
MBufferFromSmallIntUnsigned = 10000
MBufferFromSmallIntSigned = 10000

[BigFloatAPICost]
BigFloatNewFromParts = 3000
Expand Down
8 changes: 8 additions & 0 deletions cmd/node/config/gasSchedules/gasScheduleV6.toml
Original file line number Diff line number Diff line change
Expand Up @@ -113,6 +113,10 @@
GetCodeMetadata = 10000
IsBuiltinFunction = 10000
IsReservedFunctionName = 10000
GetRoundTime = 10000
EpochStartBlockTimeStamp = 10000
EpochStartBlockNonce = 10000
EpochStartBlockRound = 10000

[EthAPICost]
UseGas = 100
Expand Down Expand Up @@ -237,6 +241,10 @@
MBufferSetRandom = 6000
MBufferToBigFloat = 2000
MBufferFromBigFloat = 2000
MBufferToSmallIntUnsigned = 10000
MBufferToSmallIntSigned = 10000
MBufferFromSmallIntUnsigned = 10000
MBufferFromSmallIntSigned = 10000

[BigFloatAPICost]
BigFloatNewFromParts = 3000
Expand Down
8 changes: 8 additions & 0 deletions cmd/node/config/gasSchedules/gasScheduleV7.toml
Original file line number Diff line number Diff line change
Expand Up @@ -114,6 +114,10 @@
GetCodeMetadata = 10000
IsBuiltinFunction = 10000
IsReservedFunctionName = 10000
GetRoundTime = 10000
EpochStartBlockTimeStamp = 10000
EpochStartBlockNonce = 10000
EpochStartBlockRound = 10000

[EthAPICost]
UseGas = 100
Expand Down Expand Up @@ -238,6 +242,10 @@
MBufferSetRandom = 6000
MBufferToBigFloat = 2000
MBufferFromBigFloat = 2000
MBufferToSmallIntUnsigned = 10000
MBufferToSmallIntSigned = 10000
MBufferFromSmallIntUnsigned = 10000
MBufferFromSmallIntSigned = 10000

[BigFloatAPICost]
BigFloatNewFromParts = 3000
Expand Down
8 changes: 8 additions & 0 deletions cmd/node/config/gasSchedules/gasScheduleV8.toml
Original file line number Diff line number Diff line change
Expand Up @@ -114,6 +114,10 @@
GetCodeMetadata = 10000
IsBuiltinFunction = 10000
IsReservedFunctionName = 10000
GetRoundTime = 10000
EpochStartBlockTimeStamp = 10000
EpochStartBlockNonce = 10000
EpochStartBlockRound = 10000

[EthAPICost]
UseGas = 100
Expand Down Expand Up @@ -238,6 +242,10 @@
MBufferSetRandom = 6000
MBufferToBigFloat = 2000
MBufferFromBigFloat = 2000
MBufferToSmallIntUnsigned = 10000
MBufferToSmallIntSigned = 10000
MBufferFromSmallIntUnsigned = 10000
MBufferFromSmallIntSigned = 10000

[BigFloatAPICost]
BigFloatNewFromParts = 3000
Expand Down
11 changes: 10 additions & 1 deletion epochStart/bootstrap/baseStorageHandler.go
Original file line number Diff line number Diff line change
Expand Up @@ -179,8 +179,17 @@ func (bsh *baseStorageHandler) saveShardHdrToStorage(hdr data.HeaderHandler) ([]
return nil, err
}

if hdr.IsStartOfEpochBlock() {
err = shardHdrStorage.Put([]byte(core.EpochStartIdentifier(hdr.GetEpoch())), headerBytes)
if err != nil {
return nil, err
}
}

nonceToByteSlice := bsh.uint64Converter.ToByteSlice(hdr.GetNonce())
shardHdrNonceStorage, err := bsh.storageService.GetStorer(dataRetriever.ShardHdrNonceHashDataUnit + dataRetriever.UnitType(hdr.GetShardID()))
shardId := hdr.GetShardID()
unitType := dataRetriever.UnitType(shardId)
shardHdrNonceStorage, err := bsh.storageService.GetStorer(dataRetriever.ShardHdrNonceHashDataUnit + unitType)
sstanculeanu marked this conversation as resolved.
Show resolved Hide resolved
if err != nil {
return nil, err
}
Expand Down
11 changes: 11 additions & 0 deletions epochStart/bootstrap/disabled/disabledEpochStartTrigger.go
Original file line number Diff line number Diff line change
Expand Up @@ -2,6 +2,7 @@ package disabled

import (
"github.com/multiversx/mx-chain-core-go/data"
"github.com/multiversx/mx-chain-core-go/data/block"
)

type epochStartTrigger struct {
Expand Down Expand Up @@ -54,6 +55,16 @@ func (e *epochStartTrigger) EpochStartMetaHdrHash() []byte {
return nil
}

// LastCommitedEpochStartHdr -
func (e *epochStartTrigger) LastCommitedEpochStartHdr() (data.HeaderHandler, error) {
return &block.HeaderV2{}, nil
}

// GetEpochStartHdrFromStorage -
func (e *epochStartTrigger) GetEpochStartHdrFromStorage(_ uint32) (data.HeaderHandler, error) {
return &block.HeaderV2{}, nil
}

// GetSavedStateKey -
func (e *epochStartTrigger) GetSavedStateKey() []byte {
return nil
Expand Down
71 changes: 71 additions & 0 deletions epochStart/bootstrap/process.go
Original file line number Diff line number Diff line change
Expand Up @@ -897,6 +897,68 @@ func (e *epochStartBootstrap) findSelfShardEpochStartData() (data.EpochStartShar
return epochStartData, epochStart.ErrEpochStartDataForShardNotFound
}

func (e *epochStartBootstrap) findPrevEpochLatestFinalizedBlockForShard() data.EpochStartShardDataHandler {
lastFinalizedHeaders := e.prevEpochStartMeta.GetEpochStartHandler().GetLastFinalizedHeaderHandlers()
sstanculeanu marked this conversation as resolved.
Show resolved Hide resolved
for _, hdr := range lastFinalizedHeaders {
if hdr.GetShardID() == e.shardCoordinator.SelfId() {
return hdr
}
}

return nil
}

func (e *epochStartBootstrap) syncLatestEpochStartShardBlock(targetEpoch uint32, ctx context.Context) (data.HeaderHandler, []byte, error) {
prevEpochLatestFinalizedBlock := e.findPrevEpochLatestFinalizedBlockForShard()
if prevEpochLatestFinalizedBlock == nil {
laurci marked this conversation as resolved.
Show resolved Hide resolved
return nil, nil, epochStart.ErrEpochStartDataForShardNotFound
}

type headerResult struct {
header data.HeaderHandler
hash []byte
}

waitForHeader := func(nonce uint64, shardId uint32, ch chan headerResult) {
laurci marked this conversation as resolved.
Show resolved Hide resolved
for {
select {
case <-ch:
return
default:
hdrs, hashes, err := e.dataPool.Headers().GetHeadersByNonceAndShardId(nonce, shardId)
if err == nil && len(hdrs) > 0 {
ch <- headerResult{
header: hdrs[0],
hash: hashes[0],
}
return
}
}
}
}

nonce := prevEpochLatestFinalizedBlock.GetNonce()
for {
e.requestHandler.RequestShardHeaderByNonce(e.shardCoordinator.SelfId(), nonce+1)

resultChan := make(chan headerResult)
defer close(resultChan)

go waitForHeader(nonce+1, e.shardCoordinator.SelfId(), resultChan)

select {
case <-ctx.Done():
return nil, nil, epochStart.ErrTimeoutWaitingForShardBlock
case res := <-resultChan:
if res.header.GetEpoch() == targetEpoch {
return res.header, res.hash, nil
} else {
nonce = res.header.GetNonce()
}
}
}
}

func (e *epochStartBootstrap) requestAndProcessForShard(peerMiniBlocks []*block.MiniBlock) error {
epochStartData, err := e.findSelfShardEpochStartData()
if err != nil {
Expand Down Expand Up @@ -950,6 +1012,15 @@ func (e *epochStartBootstrap) requestAndProcessForShard(peerMiniBlocks []*block.
return epochStart.ErrWrongTypeAssertion
}

ctx, cancel = context.WithTimeout(context.Background(), DefaultTimeToWaitForRequestedData)
laurci marked this conversation as resolved.
Show resolved Hide resolved
epochStartShardBlock, epochStartShardBlockHash, err := e.syncLatestEpochStartShardBlock(epochStartData.GetEpoch(), ctx)
cancel()
if err != nil {
return err
}

e.syncedHeaders[string(epochStartShardBlockHash)] = epochStartShardBlock

dts, err := e.getDataToSync(
epochStartData,
shardNotarizedHeader,
Expand Down
18 changes: 18 additions & 0 deletions epochStart/bootstrap/shardStorageHandler.go
Original file line number Diff line number Diff line change
Expand Up @@ -95,6 +95,11 @@ func (ssh *shardStorageHandler) SaveDataToStorage(components *ComponentsNeededFo
return err
}

err = ssh.saveEpochStartShardHdrs(components)
if err != nil {
return err
}

ssh.saveMiniblocksFromComponents(components)

log.Debug("saving synced miniblocks", "num miniblocks", len(syncedMiniBlocks))
Expand Down Expand Up @@ -173,6 +178,19 @@ func (ssh *shardStorageHandler) saveEpochStartMetaHdrs(components *ComponentsNee
return nil
}

func (ssh *shardStorageHandler) saveEpochStartShardHdrs(components *ComponentsNeededForBootstrap) error {
for _, hdr := range components.Headers {
if hdr.IsStartOfEpochBlock() && hdr.GetShardID() != core.MetachainShardId {
laurci marked this conversation as resolved.
Show resolved Hide resolved
_, err := ssh.saveShardHdrToStorage(hdr)
if err != nil {
return err
}
}
}

return nil
}

func getEpochStartShardData(metaBlock data.MetaHeaderHandler, shardId uint32) (data.EpochStartShardDataHandler, error) {
for _, epochStartShardData := range metaBlock.GetEpochStartHandler().GetLastFinalizedHeaderHandlers() {
if epochStartShardData.GetShardID() == shardId {
Expand Down
3 changes: 3 additions & 0 deletions epochStart/errors.go
Original file line number Diff line number Diff line change
Expand Up @@ -185,6 +185,9 @@ var ErrNilRater = errors.New("nil rater")
// ErrTimeoutWaitingForMetaBlock signals that a timeout event was raised while waiting for the epoch start meta block
var ErrTimeoutWaitingForMetaBlock = errors.New("timeout while waiting for epoch start meta block")

// ErrTimeoutWaitingForShardBlock signals that a timeout event was raised while waiting for the epoch start shard block
var ErrTimeoutWaitingForShardBlock = errors.New("timeout while waiting for epoch start shard block")
sstanculeanu marked this conversation as resolved.
Show resolved Hide resolved

// ErrNilStorageUnitOpener signals that a nil storage unit opener was provided
var ErrNilStorageUnitOpener = errors.New("nil storage unit opener")

Expand Down
2 changes: 2 additions & 0 deletions epochStart/interface.go
Original file line number Diff line number Diff line change
Expand Up @@ -22,6 +22,8 @@ type TriggerHandler interface {
Update(round uint64, nonce uint64)
EpochStartRound() uint64
EpochStartMetaHdrHash() []byte
LastCommitedEpochStartHdr() (data.HeaderHandler, error)
GetEpochStartHdrFromStorage(epoch uint32) (data.HeaderHandler, error)
GetSavedStateKey() []byte
LoadState(key []byte) error
SetProcessed(header data.HeaderHandler, body data.BodyHandler)
Expand Down
2 changes: 2 additions & 0 deletions epochStart/metachain/systemSCs_test.go
Original file line number Diff line number Diff line change
Expand Up @@ -841,6 +841,8 @@ func createFullArgumentsForSystemSCProcessing(enableEpochsConfig config.EnableEp
GasSchedule: gasScheduleNotifier,
Counter: &testscommon.BlockChainHookCounterStub{},
MissingTrieNodesNotifier: &testscommon.MissingTrieNodesNotifierStub{},
EpochStartTrigger: &testscommon.EpochStartTriggerStub{},
RoundHandler: &testscommon.RoundHandlerMock{},
}

defaults.FillGasMapInternal(gasSchedule, 1)
Expand Down
Loading
Loading