HeadersPOS: to use snapshots (#4178)

This commit is contained in:
Alex Sharov 2022-05-17 17:42:34 +07:00 committed by GitHub
parent 75b93aca47
commit 55a4fa75b4
No known key found for this signature in database
GPG Key ID: 4AEE18F83AFDEB23

View File

@ -179,7 +179,7 @@ func HeadersPOS(
cfg.hd.ClearPendingPayloadStatus() cfg.hd.ClearPendingPayloadStatus()
if forkChoiceInsteadOfNewPayload { if forkChoiceInsteadOfNewPayload {
if err := startHandlingForkChoice(forkChoiceMessage, status, requestId, s, u, ctx, tx, cfg, headerInserter); err != nil { if err := startHandlingForkChoice(forkChoiceMessage, status, requestId, s, u, ctx, tx, cfg, headerInserter, cfg.blockReader); err != nil {
return err return err
} }
} else { } else {
@ -242,6 +242,7 @@ func startHandlingForkChoice(
tx kv.RwTx, tx kv.RwTx,
cfg HeadersCfg, cfg HeadersCfg,
headerInserter *headerdownload.HeaderInserter, headerInserter *headerdownload.HeaderInserter,
headerReader interfaces.HeaderReader,
) error { ) error {
headerHash := forkChoice.HeadBlockHash headerHash := forkChoice.HeadBlockHash
log.Info(fmt.Sprintf("[%s] Handling fork choice", s.LogPrefix()), "headerHash", headerHash) log.Info(fmt.Sprintf("[%s] Handling fork choice", s.LogPrefix()), "headerHash", headerHash)
@ -307,7 +308,10 @@ func startHandlingForkChoice(
forkingPoint := uint64(0) forkingPoint := uint64(0)
if headerNumber > 0 { if headerNumber > 0 {
parent := rawdb.ReadHeader(tx, header.ParentHash, headerNumber-1) parent, err := headerReader.Header(ctx, tx, header.ParentHash, headerNumber-1)
if err != nil {
return err
}
forkingPoint, err = headerInserter.ForkingPoint(tx, header, parent) forkingPoint, err = headerInserter.ForkingPoint(tx, header, parent)
if err != nil { if err != nil {
if requestStatus == engineapi.New { if requestStatus == engineapi.New {
@ -439,7 +443,10 @@ func handleNewPayload(
return nil return nil
} }
parent := rawdb.ReadHeader(tx, header.ParentHash, headerNumber-1) parent, err := cfg.blockReader.Header(ctx, tx, header.ParentHash, headerNumber-1)
if err != nil {
return err
}
if parent == nil { if parent == nil {
log.Info(fmt.Sprintf("[%s] New payload missing parent", s.LogPrefix())) log.Info(fmt.Sprintf("[%s] New payload missing parent", s.LogPrefix()))
hashToDownload := header.ParentHash hashToDownload := header.ParentHash