Skip to content

Commit

Permalink
Merge branch 'master' into export-memdb-errors
Browse files Browse the repository at this point in the history
  • Loading branch information
anodar committed Aug 3, 2023
2 parents 58afb9d + 1319d38 commit 5939408
Show file tree
Hide file tree
Showing 5 changed files with 35 additions and 1 deletion.
20 changes: 20 additions & 0 deletions core/rawdb/accessors_chain.go
Original file line number Diff line number Diff line change
Expand Up @@ -734,6 +734,10 @@ func ReadLogs(db ethdb.Reader, hash common.Hash, number uint64, config *params.C
}
receipts := []*receiptLogs{}
if err := rlp.DecodeBytes(data, &receipts); err != nil {
if logs := readLegacyLogs(db, hash, number, config); logs != nil {
return logs
}

log.Error("Invalid receipt array RLP", "hash", hash, "err", err)
return nil
}
Expand All @@ -745,6 +749,22 @@ func ReadLogs(db ethdb.Reader, hash common.Hash, number uint64, config *params.C
return logs
}

// readLegacyLogs is a temporary workaround for when trying to read logs
// from a block which has its receipt stored in the legacy format. It'll
// be removed after users have migrated their freezer databases.
// Arbitrum: we are keeping this to handle classic (legacy) receipts
func readLegacyLogs(db ethdb.Reader, hash common.Hash, number uint64, config *params.ChainConfig) [][]*types.Log {
receipts := ReadReceipts(db, hash, number, config)
if receipts == nil {
return nil
}
logs := make([][]*types.Log, len(receipts))
for i, receipt := range receipts {
logs[i] = receipt.Logs
}
return logs
}

// ReadBlock retrieves an entire block corresponding to the hash, assembling it
// back from the stored header and body. If either the header or body could not
// be retrieved nil is returned.
Expand Down
3 changes: 3 additions & 0 deletions core/state_transition.go
Original file line number Diff line number Diff line change
Expand Up @@ -149,6 +149,9 @@ type Message struct {
// account nonce in state. It also disables checking that the sender is an EOA.
// This field will be set to true for operations like RPC eth_call.
SkipAccountChecks bool
// L1 charging is disabled when SkipL1Charging is true.
// This field might be set to true for operations like RPC eth_call.
SkipL1Charging bool
}

type MessageRunMode uint8
Expand Down
3 changes: 3 additions & 0 deletions ethclient/ethclient.go
Original file line number Diff line number Diff line change
Expand Up @@ -603,6 +603,9 @@ func toCallArg(msg ethereum.CallMsg) interface{} {
if msg.GasPrice != nil {
arg["gasPrice"] = (*hexutil.Big)(msg.GasPrice)
}
if msg.SkipL1Charging {
arg["skipL1Charging"] = msg.SkipL1Charging
}
return arg
}

Expand Down
3 changes: 2 additions & 1 deletion interfaces.go
Original file line number Diff line number Diff line change
Expand Up @@ -166,7 +166,8 @@ type CallMsg struct {
Value *big.Int // amount of wei sent along with the call
Data []byte // input data, usually an ABI-encoded contract method invocation

AccessList types.AccessList // EIP-2930 access list.
AccessList types.AccessList // EIP-2930 access list.
SkipL1Charging bool // L1 charging is disabled when SkipL1Charging is true
}

// A ContractCaller provides contract calls, essentially transactions that are executed by
Expand Down
7 changes: 7 additions & 0 deletions internal/ethapi/transaction_args.go
Original file line number Diff line number Diff line change
Expand Up @@ -44,6 +44,7 @@ type TransactionArgs struct {
MaxPriorityFeePerGas *hexutil.Big `json:"maxPriorityFeePerGas"`
Value *hexutil.Big `json:"value"`
Nonce *hexutil.Uint64 `json:"nonce"`
SkipL1Charging *bool `json:"skipL1Charging"`

// We accept "data" and "input" for backwards-compatibility reasons.
// "input" is the newer name and should be preferred by clients.
Expand Down Expand Up @@ -267,6 +268,11 @@ func (args *TransactionArgs) ToMessage(globalGasCap uint64, header *types.Header
accessList = *args.AccessList
}

skipL1Charging := false
if args.SkipL1Charging != nil {
skipL1Charging = *args.SkipL1Charging
}

msg := &core.Message{
From: addr,
To: args.To,
Expand All @@ -279,6 +285,7 @@ func (args *TransactionArgs) ToMessage(globalGasCap uint64, header *types.Header
AccessList: accessList,
SkipAccountChecks: true,
TxRunMode: runMode,
SkipL1Charging: skipL1Charging,
}
// Arbitrum: raise the gas cap to ignore L1 costs so that it's compute-only
if core.InterceptRPCGasCap != nil && state != nil {
Expand Down

0 comments on commit 5939408

Please sign in to comment.