Skip to content

Commit

Permalink
merge master & resolve conflicts
Browse files Browse the repository at this point in the history
  • Loading branch information
ganeshvanahalli committed May 31, 2024
2 parents 9121b5e + 06235f4 commit 692c326
Show file tree
Hide file tree
Showing 4 changed files with 45 additions and 19 deletions.
6 changes: 3 additions & 3 deletions arbos/tx_processor.go
Original file line number Diff line number Diff line change
Expand Up @@ -436,13 +436,13 @@ func (p *TxProcessor) GasChargingHook(gasRemaining *uint64) (common.Address, err
}

var poster common.Address
if p.msg.TxRunMode != core.MessageCommitMode {
if !p.msg.TxRunMode.ExecutedOnChain() {
poster = l1pricing.BatchPosterAddress
} else {
poster = p.evm.Context.Coinbase
}

if p.msg.TxRunMode == core.MessageCommitMode {
if p.msg.TxRunMode.ExecutedOnChain() {
p.msg.SkipL1Charging = false
}
if basefee.Sign() > 0 && !p.msg.SkipL1Charging {
Expand Down Expand Up @@ -509,7 +509,7 @@ func (p *TxProcessor) EndTxHook(gasLeft uint64, success bool) {
if underlyingTx != nil && underlyingTx.Type() == types.ArbitrumRetryTxType {
inner, _ := underlyingTx.GetInner().(*types.ArbitrumRetryTx)
effectiveBaseFee := inner.GasFeeCap
if p.msg.TxRunMode == core.MessageCommitMode && !arbmath.BigEquals(effectiveBaseFee, p.evm.Context.BaseFee) {
if p.msg.TxRunMode.ExecutedOnChain() && !arbmath.BigEquals(effectiveBaseFee, p.evm.Context.BaseFee) {
log.Error(
"ArbitrumRetryTx GasFeeCap doesn't match basefee in commit mode",
"txHash", underlyingTx.Hash(),
Expand Down
53 changes: 40 additions & 13 deletions execution/gethexec/sequencer.go
Original file line number Diff line number Diff line change
Expand Up @@ -173,6 +173,7 @@ func SequencerConfigAddOptions(prefix string, f *flag.FlagSet) {

type txQueueItem struct {
tx *types.Transaction
txSize int // size in bytes of the marshalled transaction
options *arbitrum_types.ConditionalOptions
resultChan chan<- error
returnedResult bool
Expand Down Expand Up @@ -450,6 +451,11 @@ func (s *Sequencer) PublishTransaction(parentCtx context.Context, tx *types.Tran
return types.ErrTxTypeNotSupported
}

txBytes, err := tx.MarshalBinary()
if err != nil {
return err
}

queueTimeout := s.config().QueueTimeout
queueCtx, cancelFunc := ctxWithTimeout(parentCtx, queueTimeout)
defer cancelFunc()
Expand All @@ -461,6 +467,7 @@ func (s *Sequencer) PublishTransaction(parentCtx context.Context, tx *types.Tran
resultChan := make(chan error, 1)
queueItem := txQueueItem{
tx,
len(txBytes),
options,
resultChan,
false,
Expand Down Expand Up @@ -686,7 +693,8 @@ func (s *Sequencer) expireNonceFailures() *time.Timer {
}

// There's no guarantee that returned tx nonces will be correct
func (s *Sequencer) precheckNonces(queueItems []txQueueItem) []txQueueItem {
func (s *Sequencer) precheckNonces(queueItems []txQueueItem, totalBlockSize int) []txQueueItem {
config := s.config()
bc := s.execEngine.bc
latestHeader := bc.CurrentBlock()
latestState, err := bc.StateAt(latestHeader.Root)
Expand Down Expand Up @@ -736,7 +744,13 @@ func (s *Sequencer) precheckNonces(queueItems []txQueueItem) []txQueueItem {
if err != nil {
revivingFailure.queueItem.returnResult(err)
} else {
nextQueueItem = &revivingFailure.queueItem
if arbmath.SaturatingAdd(totalBlockSize, queueItem.txSize) > config.MaxTxDataSize {
// This tx would be too large to add to this block
s.txRetryQueue.Push(queueItem)
} else {
nextQueueItem = &revivingFailure.queueItem
totalBlockSize += queueItem.txSize
}
}
}
} else if txNonce < stateNonce || txNonce > pendingNonce {
Expand Down Expand Up @@ -810,7 +824,7 @@ func writeAndLog(pprof, trace *bytes.Buffer) {

func (s *Sequencer) createBlock(ctx context.Context) (returnValue bool) {
var queueItems []txQueueItem
var totalBatchSize int
var totalBlockSize int

defer func() {
panicErr := recover()
Expand Down Expand Up @@ -881,37 +895,47 @@ func (s *Sequencer) createBlock(ctx context.Context) (returnValue bool) {
queueItem.returnResult(err)
continue
}
txBytes, err := queueItem.tx.MarshalBinary()
if err != nil {
queueItem.returnResult(err)
continue
}
if len(txBytes) > config.MaxTxDataSize {
if queueItem.txSize > config.MaxTxDataSize {
// This tx is too large
queueItem.returnResult(txpool.ErrOversizedData)
continue
}
if totalBatchSize+len(txBytes) > config.MaxTxDataSize {
if totalBlockSize+queueItem.txSize > config.MaxTxDataSize {
// This tx would be too large to add to this batch
s.txRetryQueue.Push(queueItem)
// End the batch here to put this tx in the next one
break
}
totalBatchSize += len(txBytes)
totalBlockSize += queueItem.txSize
queueItems = append(queueItems, queueItem)
}

s.nonceCache.Resize(config.NonceCacheSize) // Would probably be better in a config hook but this is basically free
s.nonceCache.BeginNewBlock()
queueItems = s.precheckNonces(queueItems)
queueItems = s.precheckNonces(queueItems, totalBlockSize)
txes := make([]*types.Transaction, len(queueItems))
hooks := s.makeSequencingHooks()
hooks.ConditionalOptionsForTx = make([]*arbitrum_types.ConditionalOptions, len(queueItems))
totalBlockSize = 0 // recompute the totalBlockSize to double check it
for i, queueItem := range queueItems {
txes[i] = queueItem.tx
totalBlockSize = arbmath.SaturatingAdd(totalBlockSize, queueItem.txSize)
hooks.ConditionalOptionsForTx[i] = queueItem.options
}

if totalBlockSize > config.MaxTxDataSize {
for _, queueItem := range queueItems {
s.txRetryQueue.Push(queueItem)
}
log.Error(
"put too many transactions in a block",
"numTxes", len(queueItems),
"totalBlockSize", totalBlockSize,
"maxTxDataSize", config.MaxTxDataSize,
)
return false
}

if s.handleInactive(ctx, queueItems) {
return false
}
Expand All @@ -923,13 +947,16 @@ func (s *Sequencer) createBlock(ctx context.Context) (returnValue bool) {
s.L1BlockAndTimeMutex.Unlock()

if s.l1Reader != nil && (l1Block == 0 || math.Abs(float64(l1Timestamp)-float64(timestamp)) > config.MaxAcceptableTimestampDelta.Seconds()) {
for _, queueItem := range queueItems {
s.txRetryQueue.Push(queueItem)
}
log.Error(
"cannot sequence: unknown L1 block or L1 timestamp too far from local clock time",
"l1Block", l1Block,
"l1Timestamp", time.Unix(int64(l1Timestamp), 0),
"localTimestamp", time.Unix(int64(timestamp), 0),
)
return false
return true
}

header := &arbostypes.L1IncomingMessageHeader{
Expand Down
3 changes: 1 addition & 2 deletions execution/nodeInterface/NodeInterface.go
Original file line number Diff line number Diff line change
Expand Up @@ -213,12 +213,11 @@ func (n NodeInterface) EstimateRetryableTicket(
}

// ArbitrumSubmitRetryableTx is unsigned so the following won't panic
msg, err := core.TransactionToMessage(types.NewTx(submitTx), types.NewArbitrumSigner(nil), nil)
msg, err := core.TransactionToMessage(types.NewTx(submitTx), types.NewArbitrumSigner(nil), nil, core.MessageGasEstimationMode)
if err != nil {
return err
}

msg.TxRunMode = core.MessageGasEstimationMode
*n.returnMessage.message = *msg
*n.returnMessage.changed = true
return nil
Expand Down

0 comments on commit 692c326

Please sign in to comment.