From b20cf08365b0862fbb9ab1f7b274468d8093086c Mon Sep 17 00:00:00 2001 From: irrun Date: Tue, 26 Mar 2024 10:09:21 +0800 Subject: [PATCH] feat: call mev_params before send bid (#12) --- miner/bidder.go | 28 ++++++++++++++++++++++++---- miner/worker.go | 4 ++++ 2 files changed, 28 insertions(+), 4 deletions(-) diff --git a/miner/bidder.go b/miner/bidder.go index 65561aab16..33cc181e97 100644 --- a/miner/bidder.go +++ b/miner/bidder.go @@ -25,13 +25,19 @@ type ValidatorConfig struct { URL string } +type validator struct { + *validatorclient.Client + BidSimulationLeftOver time.Duration + GasCeil uint64 +} + type Bidder struct { config *MevConfig delayLeftOver time.Duration engine consensus.Engine chain *core.BlockChain - validators map[common.Address]*validatorclient.Client // validator address -> validatorclient.Client + validators map[common.Address]*validator // address -> validator bestWorksMu sync.RWMutex bestWorks map[int64]*environment @@ -50,7 +56,7 @@ func NewBidder(config *MevConfig, delayLeftOver time.Duration, engine consensus. delayLeftOver: delayLeftOver, engine: engine, chain: eth.BlockChain(), - validators: make(map[common.Address]*validatorclient.Client), + validators: make(map[common.Address]*validator), bestWorks: make(map[int64]*environment), newBidCh: make(chan *environment, 10), exitCh: make(chan struct{}), @@ -74,7 +80,17 @@ func NewBidder(config *MevConfig, delayLeftOver time.Duration, engine consensus. continue } - b.validators[v.Address] = cl + params, err := cl.MevParams(context.Background()) + if err != nil { + log.Error("Bidder: failed to get mev params", "url", v.URL, "err", err) + continue + } + + b.validators[v.Address] = &validator{ + Client: cl, + BidSimulationLeftOver: params.BidSimulationLeftOver, + GasCeil: params.GasCeil, + } } if len(b.validators) == 0 { @@ -107,8 +123,12 @@ func (b *Bidder) mainLoop() { bidNum = 0 parentHeader := b.chain.GetHeaderByHash(work.header.ParentHash) + var bidSimulationLeftOver time.Duration + if b.validators[work.coinbase] != nil { + bidSimulationLeftOver = b.validators[work.coinbase].BidSimulationLeftOver + } betterBidBefore = bidutil.BidBetterBefore(parentHeader, b.chain.Config().Parlia.Period, b.delayLeftOver, - b.config.BidSimulationLeftOver) + bidSimulationLeftOver) if time.Now().After(betterBidBefore) { timer.Reset(0) diff --git a/miner/worker.go b/miner/worker.go index 076ecfd75b..eb114c1306 100644 --- a/miner/worker.go +++ b/miner/worker.go @@ -1181,6 +1181,10 @@ func (w *worker) commitWork(interruptCh chan int32, timestamp int64) { log.Warn("Consensus engine does not support validator setting") return } + + if w.bidder.validators[coinbase] != nil { + w.config.GasCeil = w.bidder.validators[coinbase].GasCeil + } } else { coinbase = w.etherbase() if coinbase == (common.Address{}) {