From fb2843779fc2b6390187edce611789a322508c7e Mon Sep 17 00:00:00 2001 From: Kartik Chopra Date: Wed, 29 May 2024 12:00:41 -0400 Subject: [PATCH] feat: adds v1 tracing --- internal/ethapi/api.go | 4 ++++ miner/worker.go | 12 ++++++++++-- 2 files changed, 14 insertions(+), 2 deletions(-) diff --git a/internal/ethapi/api.go b/internal/ethapi/api.go index c022bd4ac0e8..1efbb3fb432d 100644 --- a/internal/ethapi/api.go +++ b/internal/ethapi/api.go @@ -1530,6 +1530,10 @@ func AccessList(ctx context.Context, b Backend, blockNrOrHash rpc.BlockNumberOrH vmenv := b.GetEVM(ctx, msg, statedb, header, &config, nil) res, err := core.ApplyMessage(vmenv, msg, new(core.GasPool).AddGas(msg.GasLimit)) if err != nil { + log.Error("Failed to apply message", "txHash", args.toTransaction().Hash(), "error", err) + } else { + log.Info("Successfully applied message", "txHash", args.toTransaction().Hash()) + } return nil, 0, nil, fmt.Errorf("failed to apply transaction: %v err: %v", args.toTransaction().Hash(), err) } if tracer.Equal(prevTracer) { diff --git a/miner/worker.go b/miner/worker.go index 201db9ea8b68..40e5f3519668 100644 --- a/miner/worker.go +++ b/miner/worker.go @@ -750,6 +750,9 @@ func (w *worker) updateSnapshot(env *environment) { w.snapshotState = env.state.Copy() } +// This function commits a transaction to the EVM. +// If the transaction type is BlobTxType, it calls the commitBlobTransaction function. +// Otherwise, it applies the transaction and updates the EVM state. func (w *worker) commitTransaction(env *environment, tx *types.Transaction) ([]*types.Log, error) { if tx.Type() == types.BlobTxType { return w.commitBlobTransaction(env, tx) @@ -762,7 +765,6 @@ func (w *worker) commitTransaction(env *environment, tx *types.Transaction) ([]* env.receipts = append(env.receipts, receipt) return receipt.Logs, nil } - func (w *worker) commitBlobTransaction(env *environment, tx *types.Transaction) ([]*types.Log, error) { sc := tx.BlobTxSidecar() if sc == nil { @@ -793,14 +795,20 @@ func (w *worker) applyTransaction(env *environment, tx *types.Transaction) (*typ snap = env.state.Snapshot() gp = env.gasPool.Gas() ) + log.Info("Applying transaction", "tx_hash", tx.Hash(), "coinbase", env.coinbase, "gas_available", gp) receipt, err := core.ApplyTransaction(w.chainConfig, w.chain, &env.coinbase, env.gasPool, env.state, env.header, tx, &env.header.GasUsed, *w.chain.GetVMConfig()) if err != nil { + log.Error("Transaction application failed", "tx_hash", tx.Hash(), "error", err) env.state.RevertToSnapshot(snap) env.gasPool.SetGas(gp) + } else { + log.Info("Transaction applied successfully", "tx_hash", tx.Hash(), "gas_used", env.header.GasUsed) } return receipt, err } +// This function commits transactions by processing them in order of price and nonce. +// It handles transaction execution, gas and tip calculations, and interruption handling. func (w *worker) commitTransactions(env *environment, txs *transactionsByPriceAndNonce, interrupt *atomic.Int32, minTip *big.Int) error { gasLimit := env.header.GasLimit if env.gasPool == nil { @@ -827,7 +835,7 @@ func (w *worker) commitTransactions(env *environment, txs *transactionsByPriceAn } // If we don't have enough space for the next transaction, skip the account. if env.gasPool.Gas() < ltx.Gas { - log.Trace("Not enough gas left for transaction", "hash", ltx.Hash, "left", env.gasPool.Gas(), "needed", ltx.Gas) + log.Info("Not enough gas left for transaction", "hash", ltx.Hash, "left", env.gasPool.Gas(), "needed", ltx.Gas) txs.Pop() continue }