Skip to content
This repository has been archived by the owner on Jan 16, 2025. It is now read-only.

[DO NOT MERGE] Stateful v1.13.1 #31

Closed
wants to merge 25 commits into from
Closed

Conversation

itsdevbear
Copy link

@itsdevbear itsdevbear commented Sep 18, 2023

Summary by CodeRabbit

  • Refactor: Updated the state database type from *state.StateDB to state.StateDBI across multiple files for better abstraction and modularity.
  • Chore: Adjusted import paths for the ethapi package to ensure correct dependencies.
  • New Feature: Introduced management for precompiled contracts in the Ethereum Virtual Machine (EVM) with a new PrecompileManager interface and its implementation.
  • Refactor: Modified the AccessList struct and its methods for improved functionality.
  • Style: Renamed stateObject to StateObject for consistency and clarity.
  • Test: Various changes in test files and other miscellaneous updates for better code quality and testing coverage.

@itsdevbear itsdevbear requested review from ocnc and calbera September 18, 2023 15:43
@calbera calbera changed the title Stateful v1.13.1 [DO NOT MERGE] Stateful v1.13.1 Sep 19, 2023

// TODO: FIGURE OUT WHY THIS HACK IS NEEDED THANKS
// bump the estimate gas by 20% for stateful precompiles
hi += uint64(float64(hi) * 0.2)
Copy link
Author

Choose a reason for hiding this comment

The reason will be displayed to describe this comment to others. Learn more.

i am gonna fucking rope

@coderabbitai
Copy link

coderabbitai bot commented Sep 28, 2023

Walkthrough

This pull request introduces significant refactoring and updates to the Ethereum codebase. The changes include a shift from *state.StateDB to state.StateDBI, import path updates for the ethapi package, modifications related to precompiled contracts management, adjustments to the AccessList struct and its methods, renaming of stateObject to StateObject, and other miscellaneous updates.

Changes

File(s) Summary
accounts/abi/bind/..., cmd/evm/..., consensus/..., core/..., eth/... Refactored state database type from *state.StateDB to state.StateDBI.
cmd/clef/main.go, cmd/geth/..., eth/filters/... Updated import paths for ethapi package.
core/types/transaction_signing.go, core/vm/... Managed precompiled contracts and their execution.
core/state/access_list.go, core/state/statedb.go Modified AccessList struct and its methods.
core/state/journal.go, core/state/state_object.go Renamed stateObject to StateObject.
accounts/abi/bind/base.go, core/genesis.go, core/state/interface.go, eth/filters/filter_system.go Miscellaneous changes including function signature updates, new interfaces, and method adjustments.

🐇💻

Code hopping through the night,

Under the moon's soft light.

Refactor here, update there,

In the world of code, we share.

With each change, we grow,

In this digital meadow we sow. 🌱🌙


Tips

Chat with CodeRabbit Bot (@coderabbitai)

  • Mention @coderabbitai in any review comment for bot assistance.
  • Note: Review comments are made on code diffs or files, not on the PR overview.

Pause Incremental Reviews

  • Insert @coderabbitai: ignore in the PR description to halt the bot's ongoing reviews. Remove the line to resume.
  • Additionally, enter @coderabbitai pause to halt the bot's ongoing reviews as any issue or review comment. To
    resume reviews, enter @coderabbitai resume as any issue or review comment.

Copy link

@coderabbitai coderabbitai bot left a comment

Choose a reason for hiding this comment

The reason will be displayed to describe this comment to others. Learn more.

Review Status

Actionable comments generated: 11

Commits Files that changed from the base of the PR and between 90d5bd8 and c8dcceccf25ed1e988de2345b489e45e38adcc06.
Files selected for processing (57)
  • accounts/abi/bind/backends/simulated.go (4 hunks)
  • accounts/abi/bind/base.go (3 hunks)
  • cmd/clef/main.go (1 hunks)
  • cmd/evm/internal/t8ntool/execution.go (2 hunks)
  • cmd/evm/runner.go (1 hunks)
  • cmd/evm/staterunner.go (1 hunks)
  • cmd/geth/config.go (1 hunks)
  • cmd/geth/main.go (1 hunks)
  • cmd/utils/flags.go (2 hunks)
  • consensus/beacon/consensus.go (2 hunks)
  • consensus/clique/clique.go (1 hunks)
  • consensus/consensus.go (1 hunks)
  • consensus/ethash/consensus.go (2 hunks)
  • consensus/misc/dao.go (1 hunks)
  • core/block_validator.go (1 hunks)
  • core/blockchain.go (5 hunks)
  • core/blockchain_reader.go (1 hunks)
  • core/chain_makers.go (3 hunks)
  • core/genesis.go (2 hunks)
  • core/state/access_list.go (6 hunks)
  • core/state/interface.go (1 hunks)
  • core/state/journal.go (1 hunks)
  • core/state/state_object.go (17 hunks)
  • core/state/state_test.go (1 hunks)
  • core/state/statedb.go (14 hunks)
  • core/state/statedb_test.go (5 hunks)
  • core/state_prefetcher.go (2 hunks)
  • core/state_processor.go (4 hunks)
  • core/state_transition.go (4 hunks)
  • core/txpool/blobpool/blobpool.go (1 hunks)
  • core/txpool/blobpool/blobpool_test.go (1 hunks)
  • core/txpool/blobpool/interface.go (1 hunks)
  • core/txpool/legacypool/legacypool.go (3 hunks)
  • core/txpool/legacypool/legacypool_test.go (3 hunks)
  • core/txpool/legacypool/noncer.go (1 hunks)
  • core/txpool/validation.go (1 hunks)
  • core/types.go (1 hunks)
  • core/types/transaction_signing.go (7 hunks)
  • core/vm/contracts.go (25 hunks)
  • core/vm/contracts_test.go (2 hunks)
  • core/vm/eips.go (1 hunks)
  • core/vm/evm.go (16 hunks)
  • core/vm/instructions_test.go (1 hunks)
  • core/vm/interface.go (2 hunks)
  • core/vm/precompile_manager.go (1 hunks)
  • core/vm/runtime/runtime.go (5 hunks)
  • eth/api_backend.go (5 hunks)
  • eth/api_debug.go (3 hunks)
  • eth/api_debug_test.go (1 hunks)
  • eth/backend.go (2 hunks)
  • eth/filters/api.go (1 hunks)
  • eth/filters/filter_system.go (1 hunks)
  • eth/filters/filter_system_test.go (1 hunks)
  • eth/protocols/snap/sync.go (1 hunks)
  • eth/state_accessor.go (4 hunks)
  • eth/tracers/api.go (7 hunks)
  • eth/tracers/api_test.go (3 hunks)
Files not processed due to max files limit (39)
  • eth/tracers/js/goja.go
  • eth/tracers/logger/access_list_tracer.go
  • eth/tracers/native/4byte.go
  • eth/tracers/native/call_flat.go
  • ethapi/addrlock.go
  • ethapi/api.go
  • ethapi/api_test.go
  • ethapi/backend.go
  • ethapi/dbapi.go
  • ethapi/transaction_args.go
  • ethapi/transaction_args_test.go
  • ethclient/signer.go
  • graphql/graphql.go
  • graphql/service.go
  • les/api_backend.go
  • les/client.go
  • les/odr_test.go
  • les/state_accessor.go
  • light/odr_test.go
  • light/trie.go
  • light/txpool.go
  • miner/miner.go
  • miner/miner_test.go
  • miner/ordering.go
  • miner/ordering_test.go
  • miner/worker.go
  • node/node.go
  • params/protocol_params.go
  • signer/core/api.go
  • signer/core/api_test.go
  • signer/core/auditlog.go
  • signer/core/cliui.go
  • signer/core/stdioui.go
  • signer/rules/rules.go
  • signer/rules/rules_test.go
  • tests/block_test_util.go
  • tests/fuzzers/bls12381/precompile_fuzzer.go
  • tests/state_test.go
  • tests/state_test_util.go
Files skipped from review due to trivial changes (14)
  • accounts/abi/bind/base.go
  • cmd/clef/main.go
  • core/state/access_list.go
  • core/state/state_object.go
  • core/state/statedb.go
  • core/txpool/blobpool/blobpool_test.go
  • core/txpool/legacypool/noncer.go
  • core/txpool/validation.go
  • core/vm/eips.go
  • core/vm/instructions_test.go
  • eth/api_backend.go
  • eth/api_debug_test.go
  • eth/filters/api.go
  • eth/protocols/snap/sync.go
Additional comments (Suppressed): 120
cmd/geth/config.go (1)
  • 35-41: The import path for the ethapi package has been changed from "github.com/ethereum/go-ethereum/internal/ethapi" to "github.com/ethereum/go-ethereum/ethapi". Please ensure that this new path is correct and accessible, and that it does not break any dependencies.
cmd/evm/runner.go (1)
  • 123-127: The type of statedb has been changed from a concrete type (*state.StateDB) to an interface (state.StateDBI). This change enhances the modularity and flexibility of the code, allowing any type that implements the StateDBI interface to be used as the state database. However, ensure that all usages of statedb in this file are compatible with the new interface.
cmd/evm/staterunner.go (1)
  • 106-112: The function signature of the callback in test.Run has been updated to use the state.StateDBI interface instead of the concrete type *state.StateDB. This change enhances modularity and allows for different implementations of the state database. Ensure that all implementations of state.StateDBI have a method IntermediateRoot that matches the one previously available in *state.StateDB.
consensus/misc/dao.go (1)
  • 75-78: The function signature has been changed from using a concrete type (*state.StateDB) to an interface (state.StateDBI). This change enhances the modularity and flexibility of the code, allowing any type that implements the StateDBI interface to be passed into the function. However, ensure that all calls to this function throughout the codebase have been updated to match the new signature.
consensus/consensus.go (1)
  • 88-100: The function signatures for Finalize and FinalizeAndAssemble have been updated to use the state.StateDBI interface instead of the concrete type *state.StateDB. This change enhances modularity by allowing any type that implements the StateDBI interface to be passed into these functions. However, ensure that all implementations of these methods throughout the codebase have been updated to match the new signature.
consensus/ethash/consensus.go (3)
  • 490-493: The function signature for Finalize has been updated to use the interface state.StateDBI instead of the concrete type *state.StateDB. This change enhances modularity and flexibility, allowing any type that implements the StateDBI interface to be passed into the function. Ensure all calls to this function throughout the codebase have been updated to match the new signature.

  • 497-500: Similar to the Finalize function, the FinalizeAndAssemble function now also uses the state.StateDBI interface. The error handling for unsupported withdrawals remains unchanged.

  • 547-553: The accumulateRewards function now uses the state.StateDBI interface as well. This change is consistent with the updates made to the Finalize and FinalizeAndAssemble functions.

core/block_validator.go (1)
  • 124-124: The function signature of ValidateState has been changed. The type of the second parameter statedb has been updated from a pointer to state.StateDB to an interface state.StateDBI. This change enhances modularity and allows for different implementations of the state database to be used.
- func (v *BlockValidator) ValidateState(block *types.Block, statedb *state.StateDB, receipts types.Receipts, usedGas uint64) error {
+ func (v *BlockValidator) ValidateState(block *types.Block, statedb state.StateDBI, receipts types.Receipts, usedGas uint64) error {

Please ensure that all calls to this function throughout the codebase have been updated to match the new signature.

consensus/clique/clique.go (2)
  • 570-574: The Finalize function has been updated to use the interface state.StateDBI instead of the concrete type *state.StateDB. This change enhances modularity and flexibility in the code. However, ensure that all calls to this function throughout the codebase have been updated to match the new signature.

  • 578-581: Similar to the Finalize function, the FinalizeAndAssemble function now uses the state.StateDBI interface. The error handling for unsupported withdrawals remains unchanged. Ensure that all calls to this function throughout the codebase have been updated to match the new signature.

consensus/beacon/consensus.go (2)
  • 347-355: The Finalize function now uses the state.StateDBI interface instead of the concrete type *state.StateDB. This change enhances modularity and flexibility, allowing any type that implements the StateDBI interface to be passed as an argument. Ensure all calls to this function have been updated accordingly.

  • 366-374: Similar to the Finalize function, the FinalizeAndAssemble function now also uses the state.StateDBI interface. This change should improve code maintainability and testability by decoupling the function from a specific implementation of state management. Make sure all calls to this function are updated to match the new signature.

core/blockchain.go (5)
  • 1404-1407: The function signature of writeBlockWithState has been changed to use the interface state.StateDBI instead of the concrete type *state.StateDB. Ensure that all calls to this function throughout the codebase have been updated to match the new signature.

  • 1492-1495: The function signature of WriteBlockAndSetHead has been changed to use the interface state.StateDBI instead of the concrete type *state.StateDB. Ensure that all calls to this function throughout the codebase have been updated to match the new signature.

  • 1503-1506: The function signature of writeBlockAndSetHead has been changed to use the interface state.StateDBI instead of the concrete type *state.StateDB. Ensure that all calls to this function throughout the codebase have been updated to match the new signature.

  • 1729-1732: The variable activeState now uses the interface state.StateDBI instead of the concrete type *state.StateDB. Ensure that all usages of this variable are compatible with the new interface.

  • 1813-1816: In the goroutine, the variable throwaway now uses the interface state.StateDBI instead of the concrete type *state.StateDB. Ensure that all usages of this variable in the goroutine are compatible with the new interface.

core/chain_makers.go (3)
  • 41-44: The type of statedb has been changed from a concrete type (*state.StateDB) to an interface (state.StateDBI). This change enhances the modularity and flexibility of the code, allowing any type that implements the StateDBI interface to be used as the state database. Ensure all usages of statedb are updated accordingly.

  • 292-294: The function genblock now accepts state.StateDBI instead of *state.StateDB. This is in line with the changes made to the BlockGen struct. Make sure that all calls to this function have been updated to pass an object of a type that implements StateDBI.

  • 374-374: The function makeHeader now accepts state.StateDBI instead of *state.StateDB. This is consistent with the other changes made in this PR. Ensure that all calls to this function have been updated to pass an object of a type that implements StateDBI.

cmd/evm/internal/t8ntool/execution.go (1)
  • 117-123: The function signature for Apply has been updated to return an interface (state.StateDBI) instead of a concrete type (*state.StateDB). This change enhances the flexibility and modularity of the code, allowing any type that implements the StateDBI interface to be returned. Ensure all calls to this function throughout the codebase have been updated to handle the new return type.
core/state/journal.go (1)
  • 93-97: The type of prev has been changed from *stateObject to *StateObject. Ensure that all usages of this field are updated accordingly and that the new type provides all necessary methods and fields used in the code. Also, verify if the change doesn't break any existing functionality or assumptions about the prev field.
cmd/utils/flags.go (2)
  • 54-64: The import path for ethapi has been changed from "github.com/ethereum/go-ethereum/internal/ethapi" to "github.com/ethereum/go-ethereum/ethapi". Ensure that this new path is correct and accessible, and that all references to ethapi in the codebase have been updated accordingly.

  • 1954-1956: The type of stack parameter in RegisterFilterAPI function has been changed from *node.Node to NetworkingStack interface. This change enhances modularity by allowing any type that implements the NetworkingStack interface to be passed as an argument. However, ensure that all types that are passed as stack implement the RegisterAPIs method required by the NetworkingStack interface.

core/state/state_test.go (1)
  • 249-252: The function compareStateObjects has been updated to use the exported type StateObject instead of the unexported type stateObject. Ensure that all calls to this function throughout the codebase have been updated to match the new signature. Also, verify that the Address() method is available and behaves as expected on the StateObject type.
core/txpool/blobpool/interface.go (1)
  • 40-44: The return type of the StateAt method has been changed from a concrete type (*state.StateDB) to an interface (state.StateDBI). This change enhances modularity and allows for easier testing, as mock implementations can be used. However, ensure that all calls to this function throughout the codebase have been updated to handle the new return type correctly.
core/state_transition.go (4)
  • 262-265: The function now returns the error from st.state.Error() instead of nil. Ensure that this change does not affect the callers of this function. They should be able to handle the returned error appropriately.

  • 402-405: The call to vm.ActivePrecompiles(rules) has been replaced with st.evm.PrecompileManager.GetActive(&rules). This change seems to be part of the transition from concrete types to interfaces mentioned in the PR summary. Make sure that the new method provides the same functionality as the old one and that it is compatible with the rest of the codebase.

  • 413-418: Error handling has been added after the st.state.SetNonce operation. This is a good practice as it ensures that any errors occurring during state modification are caught and handled immediately.

  • 439-444: Similar to the previous comment, error handling has been added after the st.state.AddBalance operation. This is a good practice as it ensures that any errors occurring during state modification are caught and handled immediately.

cmd/geth/main.go (1)
  • 35-35: The import path for the ethapi package has been changed from "github.com/ethereum/go-ethereum/internal/ethapi" to "github.com/ethereum/go-ethereum/ethapi". Please ensure that this new path is correct and accessible, and that all references to the ethapi package in the codebase have been updated accordingly.
core/txpool/blobpool/blobpool.go (1)
  • 302-302: The type of state has been changed from a concrete type (*state.StateDB) to an interface (state.StateDBI). This change enhances the modularity and flexibility of the code, allowing any type that implements the StateDBI interface to be used as the state. However, ensure that all usages of state in the codebase are compatible with this change.
core/genesis.go (2)
  • 138-140: The addition of error checking after setting the account code and nonce is a good practice. It ensures that any issues with these operations are caught immediately, preventing potential inconsistencies in the state database.

  • 162-164: Similar to the previous comment, the addition of error checking after setting the account code and nonce is a good practice. This will help catch any issues early on and prevent potential inconsistencies in the state database.

core/state/statedb_test.go (5)
  • 176-182: The Copy() function now returns an interface (StateDBI) instead of a concrete type (*StateDB). This change enhances modularity and flexibility in the code. However, it requires type assertion to convert the interface back to the concrete type. Ensure that all calls to this function throughout the codebase have been updated to match the new usage.

  • 597-600: Similar to the previous comment, the Copy() function now returns an interface (StateDBI) instead of a concrete type (*StateDB). The returned interface is being converted back to the concrete type using type assertion. Ensure that all calls to this function throughout the codebase have been updated to match the new usage.

  • 684-687: Again, the Copy() function now returns an interface (StateDBI) instead of a concrete type (*StateDB). The returned interface is being converted back to the concrete type using type assertion. Ensure that all calls to this function throughout the codebase have been updated to match the new usage.

  • 869-872: The New() function now takes a common.Hash{} as its first argument instead of types.EmptyRootHash. Also, the newAccessList() function has been replaced with NewAccessList(). Ensure that these changes are reflected across the entire codebase.

  • 1021-1024: As with previous comments, the Copy() function now returns an interface (StateDBI) instead of a concrete type (*StateDB). The returned interface is being converted back to the concrete type using type assertion. Ensure that all calls to this function throughout the codebase have been updated to match the new usage.

core/state/interface.go (2)
  • 29-106: The introduction of the StateDBI interface is a significant change that enhances modularity and flexibility in the code. It abstracts the state database operations, allowing for different implementations that adhere to this interface. This is a good practice as it decouples the code and makes it easier to test and maintain.

However, there are some methods in the interface that lack return types. For instance, CreateAccount(common.Address), SetNonce(common.Address, uint64), SetCode(common.Address, []byte), AddRefund(uint64), SubRefund(uint64), SetState(common.Address, common.Hash, common.Hash), SetTransientState(addr common.Address, key, value common.Hash), SelfDestruct(common.Address), Selfdestruct6780(common.Address), AddAddressToAccessList(addr common.Address), AddSlotToAccessList(addr common.Address, slot common.Hash), Prepare(rules params.Rules, sender, coinbase common.Address, dest *common.Address, precompiles []common.Address, txAccesses types.AccessList), RevertToSnapshot(int), AddLog(*types.Log), AddPreimage(common.Hash, []byte), SetBalance(addr common.Address, amount *big.Int), SetStorage(addr common.Address, storage map[common.Hash]common.Hash), Finalise(deleteEmptyObjects bool), SetTxContext(thash common.Hash, ti int), StopPrefetcher(), StartPrefetcher(namespace string) do not specify what they return.

If these methods do not need to return anything, it would be clearer to explicitly declare them as returning nothing by using the void keyword. If they are supposed to return something, please add the appropriate return type.

Here's an example of how you might modify one of these methods:

- SetNonce(common.Address, uint64)
+ SetNonce(common.Address, uint64) void
  • 58-58: The method Selfdestruct6780(common.Address) seems to be a duplicate of SelfDestruct(common.Address). If they perform the same operation, consider removing one to avoid redundancy. If they are different, consider renaming one or both methods to more accurately reflect their functionality and reduce confusion.
core/blockchain_reader.go (3)
  • 323-325: The return type of the State() function has been changed from *state.StateDB to state.StateDBI. This change is in line with the PR's goal of transitioning from concrete types to interfaces for state management. Ensure that all calls to this function throughout the codebase have been updated to handle the new interface return type.

  • 328-330: The return type of the StateAt() function has been changed from *state.StateDB to state.StateDBI. This change is in line with the PR's goal of transitioning from concrete types to interfaces for state management. Ensure that all calls to this function throughout the codebase have been updated to handle the new interface return type.

  • 332-335: A new function StateAtBlockNumber() has been added which returns a mutable state based on a particular block number. This seems like a useful addition, but ensure that error handling is done properly when calling GetHeaderByNumber(number), as it can return nil if the header does not exist.

core/txpool/legacypool/legacypool_test.go (3)
  • 63-68: The change from *state.StateDB to state.StateDBI in the testBlockChain struct is a good move towards better abstraction and modularity. This allows for easier testing and potential future changes in the implementation of the state database without affecting this part of the code.

  • 91-97: The function signatures for StateAt and StateAtBlockNumber have been updated to return state.StateDBI instead of *state.StateDB. Ensure that all calls to these functions throughout the codebase have been updated to handle the new return type.

  • 253-256: The function signature for State has been updated to return state.StateDBI instead of *state.StateDB. Ensure that all calls to this function throughout the codebase have been updated to handle the new return type.

accounts/abi/bind/backends/simulated.go (4)
  • 68-68: The type of pendingState has been changed from *state.StateDB to state.StateDBI. This change is part of the larger effort to transition from concrete types to interfaces for state management, as mentioned in the PR summary. This should enhance modularity and flexibility in the code.

  • 182-185: The return type of stateByBlockNumber function has been updated from *state.StateDB to state.StateDBI. Ensure that all calls to this function throughout the codebase have been updated to handle the new return type.

  • 587-590: The condition for rejecting a transaction has been slightly modified. Previously, it was rejected if hi == cap, but now it's rejected if hi >= cap. This seems like a minor change, but please verify that this doesn't unintentionally alter any logic or behavior in the system.

  • 608-611: The callContract function now accepts state.StateDBI instead of *state.StateDB as an argument. This aligns with the overall goal of transitioning from concrete types to interfaces for state management. Make sure all calls to this function are updated accordingly.

core/txpool/legacypool/legacypool.go (2)
  • 119-126: The interface has been updated to include a new method StateAtBlockNumber(number uint64) (state.StateDBI, error). Ensure that all implementations of this interface have been updated accordingly.

  • 216-222: The type of currentState has been changed from *state.StateDB to state.StateDBI. This change enhances modularity by allowing any type that implements the StateDBI interface to be used as the current state. However, ensure that all usages of currentState throughout the codebase are compatible with this change.

core/types.go (3)
  • 36-36: The function signature of ValidateState has been changed. The type of the second parameter state has been changed from a pointer to a concrete type (*state.StateDB) to an interface (state.StateDBI). This change enhances modularity and allows for different implementations of the state database. However, ensure that all calls to this function throughout the codebase have been updated to match the new signature.

  • 44-44: The function signature of Prefetch has been changed. The type of the second parameter statedb has been changed from a pointer to a concrete type (*state.StateDB) to an interface (state.StateDBI). This change enhances modularity and allows for different implementations of the state database. However, ensure that all calls to this function throughout the codebase have been updated to match the new signature.

  • 52-52: The function signature of Process has been changed. The type of the second parameter statedb has been changed from a pointer to a concrete type (*state.StateDB) to an interface (state.StateDBI). This change enhances modularity and allows for different implementations of the state database. However, ensure that all calls to this function throughout the codebase have been updated to match the new signature.

core/state_prefetcher.go (2)
  • 47-53: The function signature of Prefetch has been updated to use the interface state.StateDBI instead of the concrete type *state.StateDB. This change enhances modularity and allows for different implementations of the state database to be used. Ensure that all calls to this function throughout the codebase have been updated to match the new signature.

  • 85-91: Similar to the previous comment, the function signature of precacheTransaction has been updated to use the interface state.StateDBI instead of the concrete type *state.StateDB. This change also enhances modularity and allows for different implementations of the state database to be used. Ensure that all calls to this function throughout the codebase have been updated to match the new signature.

core/vm/contracts_test.go (3)
  • 19-27: The import of the context and math/big packages is new in this hunk. Ensure that these packages are used appropriately in the code.

  • 98-106: The function RunPrecompiledContract has been introduced to execute a precompiled contract with given input and gas. It checks if the supplied gas is sufficient, deducts the required gas cost, and then runs the contract. This function improves modularity by separating the execution logic from the testing logic.

  • 104-104: The Run method now takes additional parameters: a context, a state interface, an address, and a value. Make sure that all calls to this method have been updated accordingly throughout the codebase.

- output, err := p.Run(input)
+ output, err := p.Run(context.Background(), nil, input, common.Address{}, new(big.Int))
eth/backend.go (2)
  • 44-52: The import path for the ethapi package has been changed from "github.com/ethereum/go-ethereum/internal/ethapi" to "github.com/ethereum/go-ethereum/ethapi". Ensure that this new path is correct and accessible, and that it does not break any dependencies.

  • 299-305: The function call ethapi.GetAPIs(s.APIBackend, s.BlockChain()) now includes an additional argument s.BlockChain(). Make sure all calls to this function throughout the codebase have been updated to match the new signature. Also, verify that the BlockChain() method always returns a valid object when this function is called.

core/vm/runtime/runtime.go (4)
  • 50-52: The type of State in the Config struct has been changed from a concrete type (*state.StateDB) to an interface (state.StateDBI). This change enhances modularity and allows for different implementations of the state database. However, ensure that all implementations of state.StateDBI provide the necessary methods used in this file.

  • 123-123: The method vmenv.PrecompileManager.GetActive(&rules) is now being used instead of vm.ActivePrecompiles(rules). Ensure that PrecompileManager.GetActive() provides the same functionality as vm.ActivePrecompiles().

  • 156-156: Similar to the previous comment, vmenv.PrecompileManager.GetActive(&rules) is now being used instead of vm.ActivePrecompiles(rules). Verify that PrecompileManager.GetActive() provides the same functionality as vm.ActivePrecompiles().

  • 184-184: Again, vmenv.PrecompileManager.GetActive(&rules) is now being used instead of vm.ActivePrecompiles(rules). As mentioned before, verify that PrecompileManager.GetActive() provides the same functionality as vm.ActivePrecompiles().

eth/tracers/api_test.go (3)
  • 42-42: The import path for the ethapi package has been changed from "github.com/ethereum/go-ethereum/internal/ethapi" to "github.com/ethereum/go-ethereum/ethapi". Please ensure that this new path is correct and accessible, and that it does not break any dependencies.

  • 142-145: The function signature of StateAtBlock has been modified. The type of base parameter has been changed from *state.StateDB to state.StateDBI, and the return type has also been updated from *state.StateDB to state.StateDBI. This change enhances modularity by using interfaces instead of concrete types. However, please verify that all calls to this function throughout the codebase have been updated to match the new signature.

  • 158-161: Similar to the previous comment, the function signature of StateAtTransaction has been modified. The return type has been updated from *state.StateDB to state.StateDBI. Please verify that all calls to this function throughout the codebase have been updated to match the new signature.

core/state_processor.go (8)
  • 61-64: The function signature of Process has been updated to use the interface state.StateDBI instead of the concrete type *state.StateDB. This change enhances modularity and allows for different implementations of the state database. Ensure that all calls to this function throughout the codebase have been updated to match the new signature.

  • 89-93: The order of arguments in the applyTransaction function call has been changed. The vmenv and msg parameters are now passed first, followed by the other parameters. Make sure that all calls to applyTransaction in your codebase reflect this change.

  • 108-114: The function signature of applyTransaction has been updated similar to Process, using the interface state.StateDBI instead of the concrete type *state.StateDB. Also, the order of arguments has been changed with evm and msg now being the first two parameters. Ensure that all calls to this function throughout the codebase have been updated to match the new signature and argument order.

  • 161-207: A new function applyTransactionWithResult has been introduced which is similar to applyTransaction but also returns an ExecutionResult. This function can be useful when you want to process a transaction and also get detailed execution results. Make sure to handle the additional return value properly when using this function.

  • 213-225: The function ApplyTransaction has been updated to use the interface state.StateDBI instead of the concrete type *state.StateDB. This change enhances modularity and allows for different implementations of the state database. Ensure that all calls to this function throughout the codebase have been updated to match the new signature.

  • 227-239: A new function ApplyTransactionWithResult has been introduced which is similar to ApplyTransaction but also returns an ExecutionResult. This function can be useful when you want to process a transaction and also get detailed execution results. Make sure to handle the additional return value properly when using this function.

  • 241-250: Two new functions ApplyTransactionWithEVM and ApplyTransactionWithEVMWithResult have been introduced. These functions allow you to apply a transaction using a pre-existing EVM environment, which can be useful in scenarios where you already have an EVM instance and want to reuse it. Ensure that these functions are used correctly in your codebase.

  • 266-269: The function ProcessBeaconBlockRoot has been updated to use the interface state.StateDBI instead of the concrete type *state.StateDB. This change enhances modularity and allows for different implementations of the state database. Ensure that all calls to this function throughout the codebase have been updated to match the new signature.

eth/api_debug.go (3)
  • 28-34: The import path for ethapi has been changed from "github.com/ethereum/go-ethereum/internal/ethapi" to "github.com/ethereum/go-ethereum/ethapi". Ensure that the new path is correct and accessible, and that it doesn't break any dependencies.

  • 136-140: The type of stateDb has been changed from a pointer to a StateDB struct (*state.StateDB) to a StateDBI interface. This change enhances modularity by allowing any type implementing the StateDBI interface to be used here. However, ensure that all types that will be assigned to stateDb do implement this interface.

  • 229-235: Similar to the previous comment, the statedb parameter in the storageRangeAt function has been changed from a pointer to a StateDB struct (*state.StateDB) to a StateDBI interface. Again, this enhances modularity but requires verification that all types passed as statedb implement the StateDBI interface.

core/vm/contracts.go (3)
  • 42-48: The PrecompiledContract interface has been updated to include two new methods: RegistryKey() and Run(). The Run() method now takes additional parameters. Ensure that all implementations of this interface throughout the codebase have been updated accordingly.

  • 156-159: The function signature for ActivePrecompiles has changed from accepting a value of type params.Rules to a pointer to a params.Rules object. Make sure that all calls to this function are updated to pass a pointer instead of a value.

  • 741-748: The Run method in various structs (ecrecover, sha256hash, ripemd160hash, dataCopy, bigModExp, bn256AddIstanbul, bn256AddByzantium, bn256ScalarMulIstanbul, bn256ScalarMulByzantium, bn256PairingIstanbul, bn256PairingByzantium, blake2F, bls12381G1Add, bls12381G1Mul) now includes additional parameters: ctx context.Context, evm PrecompileEVM, caller common.Address, value *big.Int. Ensure that all calls to these Run methods are updated to pass the correct arguments.

core/vm/interface.go (2)
  • 97-99: The CallContext interface remains unchanged and continues to provide a basic interface for EVM calling conventions. The Create method allows for the creation of new contracts.

  • 101-128: Two new interfaces, PrecompileManager and PrecompileEVM, have been introduced. PrecompileManager provides functionality related to managing and executing precompiled contracts in the EVM. PrecompileEVM serves as an interface through which stateful precompiles can call back into the EVM. Ensure that these new interfaces are implemented correctly throughout the codebase.

eth/filters/filter_system.go (1)
  • 545-551: The Unsubscribe() method for es.txsSub has been commented out. This could potentially lead to memory leaks as the subscription may not be properly cleaned up when the event loop ends. If this is intentional, please ensure that there are no adverse effects due to this change.
- // es.txsSub.Unsubscribe()
+ es.txsSub.Unsubscribe()
core/types/transaction_signing.go (3)
  • 162-176: The Signer interface has been extended with three new methods: PubKey, Signature, and SignatureValues. This change enhances the functionality of the signer, allowing it to retrieve the public key and raw signature of a transaction, in addition to the existing capabilities. Ensure that all implementations of this interface have been updated accordingly.

  • 632-646: The FrontierSigner struct now implements the PubKey and Signature methods. The logic seems correct, checking the transaction type and returning an error if it's not a LegacyTxType.

  • 681-712: New utility functions recoverSig, recoverPub, and recoverPlain have been added to handle signature recovery. These functions seem to be correctly implemented, validating the signature values and using the appropriate recovery method based on whether the transaction is homestead or not.

core/vm/evm.go (17)
  • 19-23: The import of the errors package is new in this hunk. Ensure that it's used appropriately in the codebase.

  • 102-109: The addition of PrecompileManager PrecompileManager to the EVM struct introduces a new way to manage precompiled contracts, which should improve modularity and flexibility.

  • 137-142: The instantiation of PrecompileManager within NewEVM() function has been updated. The NewPrecompileManager() function is now being called with &evm.chainRules as an argument. Make sure that the NewPrecompileManager() function handles this argument correctly.

  • 144-161: A new function NewEVMWithPrecompiles() has been introduced. This function allows for the creation of an EVM instance with a specific PrecompileManager. This could be useful for testing or other scenarios where a custom PrecompileManager is needed.

  • 186-192: New getter methods GetStateDB() and GetContext() have been added. These methods provide a way to access the state database and block context of the EVM, respectively. This can enhance encapsulation and data safety.

  • 208-211: The check for precompiled contracts has been updated to use the new PrecompileManager. This change should make the code more modular and easier to maintain.

  • 245-249: The execution of precompiled contracts has been updated to use the new PrecompileManager. This change should make the code more modular and easier to maintain.

  • 268-273: Error handling has been improved by using the errors.Is() function to check if the error is ErrExecutionReverted. This is a more reliable way to check for specific errors compared to direct comparison.

  • 309-314: The check and execution of precompiled contracts in the DelegateCall() function have been updated to use the new PrecompileManager. This change should make the code more modular and easier to maintain.

  • 322-328: Error handling has been improved by using the errors.Is() function to check if the error is ErrExecutionReverted. This is a more reliable way to check for specific errors compared to direct comparison.

  • 356-362: The check and execution of precompiled contracts in the StaticCall() function have been updated to use the new PrecompileManager. This change should make the code more modular and easier to maintain.

  • 369-375: Error handling has been improved by using the errors.Is() function to check if the error is ErrExecutionReverted. This is a more reliable way to check for specific errors compared to direct comparison.

  • 400-402: Added error checking after AddBalance operation. This is a good practice as it ensures that any errors that occur during state modification are caught and handled appropriately.

  • 411-416: The check and execution of precompiled contracts in the Create() function have been updated to use the new PrecompileManager. This change should make the code more modular and easier to maintain.

  • 430-436: Error handling has been improved by using the errors.Is() function to check if the error is ErrExecutionReverted. This is a more reliable way to check for specific errors compared to direct comparison.

  • 467-469: Added error checking after SetNonce operation. This is a good practice as it ensures that any errors that occur during state modification are caught and handled appropriately.

  • 484-487: Added error checking after SetNonce operation. This is a good practice as it ensures that any errors that occur during state modification are caught and handled appropriately.

eth/filters/filter_system_test.go (1)
  • 38-38: The import path for the ethapi package has been changed from "github.com/ethereum/go-ethereum/internal/ethapi" to "github.com/ethereum/go-ethereum/ethapi". Ensure that this new path is correct and accessible, and that it does not break any dependencies.
eth/state_accessor.go (4)
  • 40-43: The function signature for hashState has been updated to use the state.StateDBI interface instead of the concrete type *state.StateDB. This change enhances modularity and allows for different implementations of the state database. Ensure that all calls to this function throughout the codebase have been updated to match the new signature.

  • 177-180: Similar to the previous comment, the function signature for pathState has also been updated to use the state.StateDBI interface. Again, ensure that all calls to this function throughout the codebase have been updated to match the new signature.

  • 211-216: The function signature for stateAtBlock has been updated to use the state.StateDBI interface. This change is consistent with the updates made to the hashState and pathState functions. As before, ensure that all calls to this function throughout the codebase have been updated to match the new signature.

  • 240-261: > Note: This review was outside of the patch, so it was mapped to the patch with the greatest overlap. Original lines [219-261]

The function stateAtTransaction now uses the state.StateDBI interface in its return type. This is consistent with the changes made to other functions in this file. Also, note the change on line 248 where the GetEVM method is now used instead of directly creating a new EVM instance. This could potentially affect the behavior of the function if the GetEVM method has different logic than the previously used constructor. Please verify that this change does not introduce any unintended side effects.

eth/tracers/api.go (7)
  • 36-43: The import path for ethapi has been changed from "github.com/ethereum/go-ethereum/internal/ethapi" to "github.com/ethereum/go-ethereum/ethapi". Ensure that the new path is correct and accessible, and that it doesn't break any dependencies.

  • 85-90: The function signatures for StateAtBlock and StateAtTransaction have been updated. The type of base in StateAtBlock and the return type of state.StateDB in both functions have been changed from *state.StateDB to state.StateDBI. Make sure all calls to these functions throughout the codebase have been updated to match the new signatures.

  • 183-189: The type of statedb in blockTraceTask struct has been changed from *state.StateDB to state.StateDBI. This change should improve modularity by allowing different implementations of the StateDBI interface to be used.

  • 200-205: The type of statedb in txTraceTask struct has been changed from *state.StateDB to state.StateDBI. This change should improve modularity by allowing different implementations of the StateDBI interface to be used.

  • 308-313: The type of statedb variable has been changed from *state.StateDB to state.StateDBI. This change should improve modularity by allowing different implementations of the StateDBI interface to be used.

  • 626-632: The type of statedb parameter in traceBlockParallel function has been changed from *state.StateDB to state.StateDBI. Make sure all calls to this function throughout the codebase have been updated to match the new signature.

  • 922-928: The type of statedb parameter in traceTx function has been changed from *state.StateDB to state.StateDBI. Make sure all calls to this function throughout the codebase have been updated to match the new signature.

Comment on lines +338 to 341
func MakePreState(db ethdb.Database, accounts core.GenesisAlloc) state.StateDBI {
sdb := state.NewDatabaseWithConfig(db, &trie.Config{Preimages: true})
statedb, _ := state.New(types.EmptyRootHash, sdb, nil)
for addr, a := range accounts {
Copy link

Choose a reason for hiding this comment

The reason will be displayed to describe this comment to others. Learn more.

Similar to the Apply function, the MakePreState function now returns an interface (state.StateDBI) instead of a concrete type (*state.StateDB). This is a good practice as it allows for better abstraction and flexibility. However, note that the error from the state.New function is being ignored. It's generally a good idea to handle errors rather than ignoring them, even if you expect them to never occur. Ignoring errors can lead to difficult-to-diagnose bugs.

- statedb, _ := state.New(types.EmptyRootHash, sdb, nil)
+ statedb, err := state.New(types.EmptyRootHash, sdb, nil)
+ if err != nil {
+     // Handle or return the error appropriately
+ }

Comment on lines 1396 to 1417
}
statedb, err := pool.chain.StateAt(newHead.Root)
if err != nil {
log.Error("Failed to reset txpool state", "err", err)
return
statedb, err = pool.chain.StateAtBlockNumber(newHead.Number.Uint64())
if err != nil {
log.Warn("Failed to get new state", "err", err)
}
}

pool.currentHead.Store(newHead)
pool.currentState = statedb
pool.pendingNonces = newNoncer(statedb)
if pool.currentState != nil {
pool.pendingNonces = newNoncer(statedb)
} else {
pool.pendingNonces = &noncer{}
}
Copy link

Choose a reason for hiding this comment

The reason will be displayed to describe this comment to others. Learn more.

The error handling logic has been improved here. Previously, if there was an error in getting the state at newHead.Root, it would log an error and return. Now, it tries to get the state at the block number of newHead before logging a warning. This is a good improvement as it adds a fallback mechanism when the first attempt to get the state fails. However, note that even if both attempts fail, the function does not return and continues execution. Make sure this is the intended behavior and that it won't lead to any runtime errors or unexpected behavior later on.

 	statedb, err := pool.chain.StateAt(newHead.Root)
 	if err != nil {
+		statedb, err = pool.chain.StateAtBlockNumber(newHead.Number.Uint64())
 		if err != nil {
 			log.Warn("Failed to get new state", "err", err)
 		}
 	}

Comment on lines 51 to 53
if pm.precompiles == nil {
pm.precompiles = activePrecompiles(pm.rules)
}
Copy link

Choose a reason for hiding this comment

The reason will be displayed to describe this comment to others. Learn more.

The precompiles map is being initialized inside the Has and Get methods. This can lead to data races if these methods are called concurrently from different goroutines. Consider using a mutex or initializing the precompiles map during the creation of the precompileManager to avoid this issue.

Comment on lines +69 to +72
gasCost := p.RequiredGas(input)
if gasCost > suppliedGas {
return nil, 0, ErrOutOfGas
}
Copy link

Choose a reason for hiding this comment

The reason will be displayed to describe this comment to others. Learn more.

The error handling here is correct but it might be more informative to return a custom error message that includes the amount of gas that was required and the amount that was supplied. This would make debugging easier if an ErrOutOfGas error occurs.

Comment on lines +74 to +77
suppliedGas -= gasCost
output, err := p.Run(context.Background(), evm, input, caller, value)

return output, suppliedGas, err
Copy link

Choose a reason for hiding this comment

The reason will be displayed to describe this comment to others. Learn more.

The context passed to the Run method of the precompiled contract is always a background context. If there's a need to cancel the execution of the precompiled contract based on some conditions or timeouts, it would be better to accept a context as an argument to the Run method of the precompileManager.

Comment on lines 28 to 86
GetCodeHash(common.Address) common.Hash
GetCode(common.Address) []byte
SetCode(common.Address, []byte)
GetCodeSize(common.Address) int

AddRefund(uint64)
SubRefund(uint64)
GetRefund() uint64

GetCommittedState(common.Address, common.Hash) common.Hash
GetState(common.Address, common.Hash) common.Hash
SetState(common.Address, common.Hash, common.Hash)

GetTransientState(addr common.Address, key common.Hash) common.Hash
SetTransientState(addr common.Address, key, value common.Hash)

SelfDestruct(common.Address)
HasSelfDestructed(common.Address) bool

Selfdestruct6780(common.Address)

// Exist reports whether the given account exists in state.
// Notably this should also return true for self-destructed accounts.
Exist(common.Address) bool
// Empty returns whether the given account is empty. Empty
// is defined according to EIP161 (balance = nonce = code = 0).
Empty(common.Address) bool

AddressInAccessList(addr common.Address) bool
SlotInAccessList(addr common.Address, slot common.Hash) (addressOk bool, slotOk bool)
// AddAddressToAccessList adds the given address to the access list. This operation is safe to perform
// even if the feature/fork is not active yet
AddAddressToAccessList(addr common.Address)
// AddSlotToAccessList adds the given (address,slot) to the access list. This operation is safe to perform
// even if the feature/fork is not active yet
AddSlotToAccessList(addr common.Address, slot common.Hash)
Prepare(rules params.Rules, sender, coinbase common.Address, dest *common.Address, precompiles []common.Address, txAccesses types.AccessList)

RevertToSnapshot(int)
Snapshot() int

AddLog(*types.Log)
AddPreimage(common.Hash, []byte)
state.StateDBI
// TODO: streamline this interface
// CreateAccount(common.Address)

// SubBalance(common.Address, *big.Int)
// AddBalance(common.Address, *big.Int)
// GetBalance(common.Address) *big.Int

// GetNonce(common.Address) uint64
// SetNonce(common.Address, uint64)

// GetCodeHash(common.Address) common.Hash
// GetCode(common.Address) []byte
// SetCode(common.Address, []byte)
// GetCodeSize(common.Address) int

// AddRefund(uint64)
// SubRefund(uint64)
// GetRefund() uint64

// GetCommittedState(common.Address, common.Hash) common.Hash
// GetState(common.Address, common.Hash) common.Hash
// SetState(common.Address, common.Hash, common.Hash)

// GetTransientState(addr common.Address, key common.Hash) common.Hash
// SetTransientState(addr common.Address, key, value common.Hash)

// SelfDestruct(common.Address)
// HasSelfDestructed(common.Address) bool

// Selfdestruct6780(common.Address)

// // Exist reports whether the given account exists in state.
// // Notably this should also return true for self-destructed accounts.
// Exist(common.Address) bool
// // Empty returns whether the given account is empty. Empty
// // is defined according to EIP161 (balance = nonce = code = 0).
// Empty(common.Address) bool

// AddressInAccessList(addr common.Address) bool
// SlotInAccessList(addr common.Address, slot common.Hash) (addressOk bool, slotOk bool)
// // AddAddressToAccessList adds the given address to the access list. This operation is safe to perform
// // even if the feature/fork is not active yet
// AddAddressToAccessList(addr common.Address)
// // AddSlotToAccessList adds the given (address,slot) to the access list. This operation is safe to perform
// // even if the feature/fork is not active yet
// AddSlotToAccessList(addr common.Address, slot common.Hash)
// Prepare(rules params.Rules, sender, coinbase common.Address, dest *common.Address, precompiles []common.Address, txAccesses types.AccessList)

// RevertToSnapshot(int)
// Snapshot() int

// AddLog(*types.Log)
// AddPreimage(common.Hash, []byte)

// Error() error
}
Copy link

Choose a reason for hiding this comment

The reason will be displayed to describe this comment to others. Learn more.

The StateDB interface has been updated to extend from state.StateDBI. This change is part of the transition from concrete types to interfaces for state management. However, there are several methods commented out in this interface. If these methods are no longer needed, consider removing them entirely to avoid confusion. If they are planned to be used in the future, consider adding more descriptive comments explaining their intended use or why they are currently commented out.

Comment on lines 279 to 291
func (s londonSigner) PubKey(tx *Transaction) ([]byte, error) {
if tx.Type() != DynamicFeeTxType {
return s.eip2930Signer.PubKey(tx)
}
V, R, S := tx.RawSignatureValues()
// DynamicFee txs are defined to use 0 and 1 as their recovery
// id, add 27 to become equivalent to unprotected Homestead signatures.
V = new(big.Int).Add(V, big.NewInt(27))
if tx.ChainId().Cmp(s.chainId) != 0 {
return nil, fmt.Errorf("%w: have %d want %d", ErrInvalidChainId, tx.ChainId(), s.chainId)
}
return recoverPub(s.Hash(tx), R, S, V, true)
}
Copy link

Choose a reason for hiding this comment

The reason will be displayed to describe this comment to others. Learn more.

The londonSigner struct now implements the PubKey method. The logic seems correct as it checks the transaction type and adjusts the recovery id for DynamicFee transactions. However, there's a potential issue on line 295 where s.eip2930Signer.PubKey(tx) is called instead of s.eip2930Signer.Signature(tx).

- return s.eip2930Signer.PubKey(tx)
+ return s.eip2930Signer.Signature(tx)

Comment on lines 383 to 425
func (s eip2930Signer) PubKey(tx *Transaction) ([]byte, error) {
V, R, S := tx.RawSignatureValues()
switch tx.Type() {
case LegacyTxType:
if !tx.Protected() {
return HomesteadSigner{}.PubKey(tx)
}
V = new(big.Int).Sub(V, s.chainIdMul)
V.Sub(V, big8)
case AccessListTxType:
// AL txs are defined to use 0 and 1 as their recovery
// id, add 27 to become equivalent to unprotected Homestead signatures.
V = new(big.Int).Add(V, big.NewInt(27))
default:
return nil, ErrTxTypeNotSupported
}
if tx.ChainId().Cmp(s.chainId) != 0 {
return nil, fmt.Errorf("%w: have %d want %d", ErrInvalidChainId, tx.ChainId(), s.chainId)
}
return recoverPub(s.Hash(tx), R, S, V, true)
}

func (s eip2930Signer) Signature(tx *Transaction) ([]byte, error) {
V, R, S := tx.RawSignatureValues()
switch tx.Type() {
case LegacyTxType:
if !tx.Protected() {
return HomesteadSigner{}.PubKey(tx)
}
V = new(big.Int).Sub(V, s.chainIdMul)
V.Sub(V, big8)
case AccessListTxType:
// AL txs are defined to use 0 and 1 as their recovery
// id, add 27 to become equivalent to unprotected Homestead signatures.
V = new(big.Int).Add(V, big.NewInt(27))
default:
return nil, ErrTxTypeNotSupported
}
if tx.ChainId().Cmp(s.chainId) != 0 {
return nil, fmt.Errorf("%w: have %d want %d", ErrInvalidChainId, tx.ChainId(), s.chainId)
}
return recoverSig(s.Hash(tx), R, S, V, true)
}
Copy link

Choose a reason for hiding this comment

The reason will be displayed to describe this comment to others. Learn more.

The eip2930Signer struct now implements the PubKey and Signature methods. The logic appears to be correct, handling different transaction types appropriately and adjusting the recovery id for AccessList transactions. However, similar to the previous comment, there's a potential issue on line 410 where HomesteadSigner{}.PubKey(tx) is called instead of HomesteadSigner{}.Signature(tx).

- return HomesteadSigner{}.PubKey(tx)
+ return HomesteadSigner{}.Signature(tx)

Comment on lines 516 to 546
func (s EIP155Signer) PubKey(tx *Transaction) ([]byte, error) {
if tx.Type() != LegacyTxType {
return nil, ErrTxTypeNotSupported
}
if !tx.Protected() {
return HomesteadSigner{}.PubKey(tx)
}
if tx.ChainId().Cmp(s.chainId) != 0 {
return nil, fmt.Errorf("%w: have %d want %d", ErrInvalidChainId, tx.ChainId(), s.chainId)
}
V, R, S := tx.RawSignatureValues()
V = new(big.Int).Sub(V, s.chainIdMul)
V.Sub(V, big8)
return recoverPub(s.Hash(tx), R, S, V, true)
}

func (s EIP155Signer) Signature(tx *Transaction) ([]byte, error) {
if tx.Type() != LegacyTxType {
return nil, ErrTxTypeNotSupported
}
if !tx.Protected() {
return HomesteadSigner{}.Signature(tx)
}
if tx.ChainId().Cmp(s.chainId) != 0 {
return nil, fmt.Errorf("%w: have %d want %d", ErrInvalidChainId, tx.ChainId(), s.chainId)
}
V, R, S := tx.RawSignatureValues()
V = new(big.Int).Sub(V, s.chainIdMul)
V.Sub(V, big8)
return recoverSig(s.Hash(tx), R, S, V, true)
}
Copy link

Choose a reason for hiding this comment

The reason will be displayed to describe this comment to others. Learn more.

The EIP155Signer struct now implements the PubKey and Signature methods. The logic seems correct, checking if the transaction is protected and adjusting the recovery id accordingly. However, there's a potential issue on line 537 where HomesteadSigner{}.PubKey(tx) is called instead of HomesteadSigner{}.Signature(tx).

- return HomesteadSigner{}.PubKey(tx)
+ return HomesteadSigner{}.Signature(tx)

@coderabbitai
Copy link

coderabbitai bot commented Sep 28, 2023

Rate Limit Exceeded

You have exceeded the limit for the number of files or commits that can be reviewed per hour. Please wait 59 minutes and 59 seconds before requesting another review.

To re-trigger a review, convert this PR to a draft and then mark it as ready for review again. Alternatively, you can push a new commit to this PR.

Copy link

@coderabbitai coderabbitai bot left a comment

Choose a reason for hiding this comment

The reason will be displayed to describe this comment to others. Learn more.

Review Status

Actionable comments generated: 12

Commits Files that changed from the base of the PR and between 90d5bd8 and 564e2be.
Files selected for processing (57)
  • accounts/abi/bind/backends/simulated.go (4 hunks)
  • accounts/abi/bind/base.go (3 hunks)
  • cmd/clef/main.go (1 hunks)
  • cmd/evm/internal/t8ntool/execution.go (2 hunks)
  • cmd/evm/runner.go (1 hunks)
  • cmd/evm/staterunner.go (1 hunks)
  • cmd/geth/config.go (1 hunks)
  • cmd/geth/main.go (1 hunks)
  • cmd/utils/flags.go (2 hunks)
  • consensus/beacon/consensus.go (2 hunks)
  • consensus/clique/clique.go (1 hunks)
  • consensus/consensus.go (1 hunks)
  • consensus/ethash/consensus.go (2 hunks)
  • consensus/misc/dao.go (1 hunks)
  • core/block_validator.go (1 hunks)
  • core/blockchain.go (5 hunks)
  • core/blockchain_reader.go (1 hunks)
  • core/chain_makers.go (3 hunks)
  • core/genesis.go (2 hunks)
  • core/state/access_list.go (6 hunks)
  • core/state/interface.go (1 hunks)
  • core/state/journal.go (1 hunks)
  • core/state/state_object.go (17 hunks)
  • core/state/state_test.go (1 hunks)
  • core/state/statedb.go (14 hunks)
  • core/state/statedb_test.go (5 hunks)
  • core/state_prefetcher.go (2 hunks)
  • core/state_processor.go (4 hunks)
  • core/state_transition.go (4 hunks)
  • core/txpool/blobpool/blobpool.go (1 hunks)
  • core/txpool/blobpool/blobpool_test.go (1 hunks)
  • core/txpool/blobpool/interface.go (1 hunks)
  • core/txpool/legacypool/legacypool.go (3 hunks)
  • core/txpool/legacypool/legacypool_test.go (3 hunks)
  • core/txpool/legacypool/noncer.go (1 hunks)
  • core/txpool/validation.go (1 hunks)
  • core/types.go (1 hunks)
  • core/types/transaction_signing.go (7 hunks)
  • core/vm/contracts.go (25 hunks)
  • core/vm/contracts_test.go (2 hunks)
  • core/vm/eips.go (1 hunks)
  • core/vm/evm.go (16 hunks)
  • core/vm/instructions_test.go (1 hunks)
  • core/vm/interface.go (2 hunks)
  • core/vm/precompile_manager.go (1 hunks)
  • core/vm/runtime/runtime.go (5 hunks)
  • eth/api_backend.go (5 hunks)
  • eth/api_debug.go (3 hunks)
  • eth/api_debug_test.go (1 hunks)
  • eth/backend.go (2 hunks)
  • eth/filters/api.go (1 hunks)
  • eth/filters/filter_system.go (1 hunks)
  • eth/filters/filter_system_test.go (1 hunks)
  • eth/protocols/snap/sync.go (1 hunks)
  • eth/state_accessor.go (4 hunks)
  • eth/tracers/api.go (7 hunks)
  • eth/tracers/api_test.go (3 hunks)
Files not processed due to max files limit (40)
  • eth/tracers/js/goja.go
  • eth/tracers/logger/access_list_tracer.go
  • eth/tracers/native/4byte.go
  • eth/tracers/native/call_flat.go
  • ethapi/addrlock.go
  • ethapi/api.go
  • ethapi/api_test.go
  • ethapi/backend.go
  • ethapi/dbapi.go
  • ethapi/transaction_args.go
  • ethapi/transaction_args_test.go
  • ethclient/signer.go
  • graphql/graphql.go
  • graphql/service.go
  • les/api_backend.go
  • les/client.go
  • les/odr_test.go
  • les/state_accessor.go
  • light/odr_test.go
  • light/trie.go
  • light/txpool.go
  • miner/miner.go
  • miner/miner_test.go
  • miner/ordering.go
  • miner/ordering_test.go
  • miner/worker.go
  • miner/worker_test.go
  • node/node.go
  • params/protocol_params.go
  • signer/core/api.go
  • signer/core/api_test.go
  • signer/core/auditlog.go
  • signer/core/cliui.go
  • signer/core/stdioui.go
  • signer/rules/rules.go
  • signer/rules/rules_test.go
  • tests/block_test_util.go
  • tests/fuzzers/bls12381/precompile_fuzzer.go
  • tests/state_test.go
  • tests/state_test_util.go
Files skipped from review due to trivial changes (16)
  • accounts/abi/bind/base.go
  • cmd/clef/main.go
  • core/state/access_list.go
  • core/state/statedb.go
  • core/state_prefetcher.go
  • core/txpool/blobpool/blobpool_test.go
  • core/txpool/legacypool/noncer.go
  • core/txpool/validation.go
  • core/types/transaction_signing.go
  • core/vm/eips.go
  • core/vm/instructions_test.go
  • core/vm/interface.go
  • eth/api_backend.go
  • eth/api_debug_test.go
  • eth/filters/api.go
  • eth/protocols/snap/sync.go
Additional comments (Suppressed): 119
cmd/evm/runner.go (1)
  • 123-127: The type of statedb has been changed from *state.StateDB to state.StateDBI. This change suggests a shift towards an interface-based approach for state management. Ensure that all usages of statedb in the codebase are compatible with this new type.
cmd/evm/staterunner.go (1)
  • 106-112: The function signature of the callback in test.Run has been updated to use state.StateDBI instead of *state.StateDB. Ensure that this change is propagated throughout the codebase and that all implementations of StateDBI have a method IntermediateRoot with the same behavior as the one in *state.StateDB.
core/block_validator.go (1)
  • 124-127: The function signature of ValidateState has been changed to accept state.StateDBI instead of *state.StateDB. Ensure that all calls to this function throughout the codebase have been updated to match the new signature. Also, verify that the interface state.StateDBI provides all the necessary methods that were previously available in *state.StateDB.
cmd/geth/main.go (1)
  • 32-40: The import path for the ethapi package has been updated from github.com/ethereum/go-ethereum/internal/ethapi to github.com/ethereum/go-ethereum/ethapi. Ensure that this new path is correct and accessible, and that it doesn't break any dependencies.
consensus/misc/dao.go (1)
  • 72-78: The function signature for ApplyDAOHardFork has been updated to accept an interface state.StateDBI instead of a pointer to state.StateDB. Ensure that all calls to this function throughout the codebase have been updated to match the new signature. Also, verify that the implementation of StateDBI correctly handles the Exist and CreateAccount methods.
cmd/utils/flags.go (2)
  • 54-64: The import path for ethapi has been updated from github.com/ethereum/go-ethereum/internal/ethapi to github.com/ethereum/go-ethereum/ethapi. Ensure that this new path is correct and accessible, and that it doesn't break any dependencies.

  • 1954-1962: The function signature of RegisterFilterAPI has been changed. The first parameter type has been altered from *node.Node to NetworkingStack, which is an interface. This change implies a shift towards a more abstracted approach, allowing any type that implements the NetworkingStack interface to be passed as an argument. Make sure all calls to this function throughout the codebase have been updated to match the new signature.

consensus/consensus.go (2)
  • 91-92: The Finalize method signature has been updated to accept state.StateDBI instead of *state.StateDB. Ensure that all calls to this function throughout the codebase have been updated to match the new signature.

  • 99-100: The FinalizeAndAssemble method signature has been updated to accept state.StateDBI instead of *state.StateDB. Ensure that all calls to this function throughout the codebase have been updated to match the new signature.

core/blockchain.go (5)
  • 1404-1407: The function signature of writeBlockWithState has been changed to accept state.StateDBI instead of *state.StateDB. Ensure that all calls to this function throughout the codebase have been updated to match the new signature.

  • 1492-1495: The function signature of WriteBlockAndSetHead has been changed to accept state.StateDBI instead of *state.StateDB. Ensure that all calls to this function throughout the codebase have been updated to match the new signature.

  • 1503-1506: The function signature of writeBlockAndSetHead has been changed to accept state.StateDBI instead of *state.StateDB. Ensure that all calls to this function throughout the codebase have been updated to match the new signature.

  • 1729-1732: The type of activeState has been changed from *state.StateDB to state.StateDBI. Ensure that all operations on activeState are compatible with the new interface-based approach.

  • 1813-1816: The anonymous goroutine now accepts throwaway state.StateDBI instead of throwaway *state.StateDB. Ensure that the bc.prefetcher.Prefetch method is compatible with the new interface-based approach.

cmd/evm/internal/t8ntool/execution.go (2)
  • 118-123: The function signature of Apply has been changed to return state.StateDBI instead of *state.StateDB. Ensure that all calls to this function throughout the codebase have been updated to handle the new return type. Also, verify if the change aligns with the overall design and doesn't introduce any unintended side effects.

  • 338-341: The function MakePreState now returns state.StateDBI instead of *state.StateDB. This change should be reflected wherever this function is called. Additionally, the error returned by state.New is being ignored. It's a good practice to handle errors rather than ignoring them. Consider adding error handling here.

- statedb, _ := state.New(types.EmptyRootHash, sdb, nil)
+ statedb, err := state.New(types.EmptyRootHash, sdb, nil)
+ if err != nil {
+     return nil, err
+ }
consensus/clique/clique.go (2)
  • 570-574: The Finalize function has been updated to use the new state.StateDBI interface instead of the *state.StateDB type. The function now also sets the Root and UncleHash fields of the header, which were not set in the previous version. Ensure that these changes do not introduce any unexpected behavior.

  • 578-581: The FinalizeAndAssemble function has also been updated to use the state.StateDBI interface. The function's behavior remains the same, returning an error if there are any withdrawals since Clique does not support them. This change is consistent with the shift towards an interface-based approach for state management.

consensus/ethash/consensus.go (3)
  • 490-493: The function signature of Finalize has been updated to use the interface state.StateDBI instead of the pointer type *state.StateDB. Ensure that all calls to this function throughout the codebase have been updated to match the new signature. Also, verify that the implementation of state.StateDBI is correctly handled in the accumulateRewards function.

  • 497-500: Similar to the Finalize function, the FinalizeAndAssemble function now uses state.StateDBI instead of *state.StateDB. Again, ensure that all calls to this function throughout the codebase have been updated to match the new signature. The error handling for unsupported withdrawals remains unchanged.

  • 547-553: The accumulateRewards function now accepts state.StateDBI instead of *state.StateDB. As before, ensure that all calls to this function throughout the codebase have been updated to match the new signature. The logic within the function appears to be unchanged based on the provided hunk.

consensus/beacon/consensus.go (2)
  • 350-355: The function signature of Finalize() has been updated to accept state.StateDBI instead of *state.StateDB. Ensure that all calls to this function throughout the codebase have been updated to match the new signature. Also, verify that the Finalize() method in the ethone engine is compatible with the new state.StateDBI type.

  • 369-374: The function signature of FinalizeAndAssemble() has been updated to accept state.StateDBI instead of *state.StateDB. Ensure that all calls to this function throughout the codebase have been updated to match the new signature. Also, verify that the FinalizeAndAssemble() method in the ethone engine is compatible with the new state.StateDBI type.

core/genesis.go (2)
  • 135-140: The addition of error handling after setting the code and nonce for an account in the state database is a good practice. It ensures that any errors that occur during these operations are caught and handled immediately, preventing potential inconsistencies in the state database.

  • 159-164: Similar to the previous comment, the addition of error handling after setting the code and nonce for an account in the state database is a good practice. This change improves the robustness of the code by ensuring that errors are not silently ignored.

cmd/geth/config.go (1)
  • 35-41: The import path for the ethapi package has been updated from github.com/ethereum/go-ethereum/internal/ethapi to github.com/ethereum/go-ethereum/ethapi. Ensure that this new path is correct and accessible, and that it doesn't break any dependencies.
core/state/interface.go (1)
  • 29-106: The introduction of the StateDBI interface is a significant change that affects the state management in EVM. This interface-based approach provides flexibility and makes it easier to implement different versions of state databases. However, ensure that all implementations of this interface correctly implement all methods. Also, verify that all parts of the codebase that previously used *state.StateDB have been updated to use StateDBI.
- *state.StateDB
+ state.StateDBI
core/chain_makers.go (3)
  • 41-44: The type of statedb has been changed from a pointer to state.StateDB to an interface state.StateDBI. This change suggests a shift towards an interface-based approach for state management. Ensure that all methods previously called on statedb are defined in the StateDBI interface and that the actual object implementing this interface implements these methods.

  • 292-294: The function genblock now accepts state.StateDBI instead of *state.StateDB as an argument. This is consistent with the change made in the BlockGen struct. Make sure that the passed object correctly implements the StateDBI interface.

  • 374-377: The function makeHeader now accepts state.StateDBI instead of *state.StateDB as an argument. This is consistent with the changes made elsewhere in the code. Ensure that the passed object correctly implements the StateDBI interface.

accounts/abi/bind/backends/simulated.go (4)
  • 66-70: The type of pendingState has been changed from *state.StateDB to state.StateDBI. This change is part of a larger refactoring effort to use interfaces for state management. Ensure that all usages of pendingState throughout the codebase have been updated to work with the new interface type.

  • 182-185: The return type of stateByBlockNumber has been changed from *state.StateDB to state.StateDBI. This change is part of a larger refactoring effort to use interfaces for state management. Ensure that all calls to this function throughout the codebase have been updated to handle the new return type.

  • 587-590: The condition in line 587 has been changed from hi == cap to hi >= cap. This change seems to be intended to catch cases where hi somehow exceeds cap, not just when it equals cap. Please verify that this change does not introduce any unexpected behavior or off-by-one errors.

  • 608-611: The parameter type of stateDB in callContract has been changed from *state.StateDB to state.StateDBI. This change is part of a larger refactoring effort to use interfaces for state management. Ensure that all calls to this function throughout the codebase have been updated to pass an instance of state.StateDBI.

core/state/journal.go (1)
  • 91-97: The resetObjectChange struct has been updated to use the exported StateObject type instead of the previously unexported stateObject. Ensure that all instances of this struct have been updated accordingly throughout the codebase. Also, verify that the change from stateObject to StateObject does not introduce any unintended side effects due to differences in behavior between these two types.
core/txpool/legacypool/legacypool_test.go (3)
  • 63-68: The type of statedb has been changed from a pointer to state.StateDB to the interface state.StateDBI. This change is in line with the PR's goal of shifting towards an interface-based approach for state management. Ensure that all methods and functions that interact with statedb are compatible with this change.

  • 91-97: The return type of StateAt() and StateAtBlockNumber() methods have been updated to return state.StateDBI instead of *state.StateDB. This aligns with the changes made to the statedb field in the testBlockChain struct. Make sure that all calls to these methods are updated accordingly.

  • 253-256: The return type of the State() method has been updated to state.StateDBI from *state.StateDB, consistent with the changes made elsewhere in the codebase. Verify that all calls to this method are updated to handle the new return type.

core/types.go (3)
  • 36-36: The function signature of ValidateState has been changed to accept state.StateDBI instead of *state.StateDB. Ensure that all calls to this function throughout the codebase have been updated to match the new signature.

  • 44-44: The function signature of Prefetch has been changed to accept state.StateDBI instead of *state.StateDB. Ensure that all calls to this function throughout the codebase have been updated to match the new signature.

  • 52-52: The function signature of Process has been changed to accept state.StateDBI instead of *state.StateDB. Ensure that all calls to this function throughout the codebase have been updated to match the new signature.

core/state/statedb_test.go (5)
  • 176-182: The Copy() method now returns an interface (StateDBI) instead of a concrete type (*StateDB). This change is reflected by the type assertion to *StateDB in the new hunk. Ensure that all implementations of the StateDBI interface have a Copy() method that returns a copy of the correct type.

  • 597-600: Similar to the previous comment, ensure that all implementations of the StateDBI interface have a Copy() method that returns a copy of the correct type.

  • 684-687: Again, ensure that all implementations of the StateDBI interface have a Copy() method that returns a copy of the correct type.

  • 869-872: The NewAccessList() function has replaced the newAccessList(). Make sure that this function is correctly implemented and exported as it's now part of the package's public API.

  • 1021-1024: Ensure that all implementations of the StateDBI interface have a Copy() method that returns a copy of the correct type.

core/state_transition.go (1)
  • 402-405: The call to st.state.Prepare() has been updated to use st.evm.PrecompileManager.GetActive(&rules) instead of vm.ActivePrecompiles(rules). Ensure that this change does not affect the functionality of the code, as the GetActive method might have a different implementation than ActivePrecompiles.
core/vm/runtime/runtime.go (3)
  • 50-52: The type of State in the Config struct has been changed from *state.StateDB to state.StateDBI. This change suggests a shift towards an interface-based approach for state management. Ensure that all uses of this field throughout the codebase have been updated to work with the new interface type.

  • 184-184: The method vmenv.PrecompileManager.GetActive(&rules) is used instead of vm.ActivePrecompiles(rules). This change indicates a new way of getting active precompiled contracts. Make sure that the PrecompileManager correctly implements the retrieval of active precompiled contracts and that it's properly tested.

  • 105-108: The function signature of Execute() has been updated to return state.StateDBI instead of *state.StateDB. Ensure that all calls to this function throughout the codebase have been updated to handle the new return type.

core/txpool/blobpool/blobpool.go (1)
  • 302-302: The type of state has been changed from a pointer to state.StateDB to an interface state.StateDBI. This change suggests a shift towards an interface-based approach for state management. Ensure that all methods and functions that interact with state are compatible with this new interface.
eth/api_debug.go (3)
  • 28-34: The import path for the ethapi package has been updated from github.com/ethereum/go-ethereum/internal/ethapi to github.com/ethereum/go-ethereum/ethapi. Ensure that this new path is correct and accessible.

  • 136-140: The type of stateDb has been changed from *state.StateDB to state.StateDBI, indicating a shift towards an interface-based approach. Make sure all methods called on stateDb are defined in the StateDBI interface.

  • 232-235: Similar to the previous comment, the type of statedb in the storageRangeAt function has been changed from *state.StateDB to state.StateDBI. Again, ensure that all methods called on statedb are defined in the StateDBI interface.

core/txpool/blobpool/interface.go (1)
  • 42-43: The function signature for StateAt has been changed to return state.StateDBI instead of *state.StateDB. Ensure that all calls to this function throughout the codebase have been updated to handle the new return type. Also, verify that the implementation of this method is correctly returning an instance of a type that satisfies the state.StateDBI interface.
core/txpool/legacypool/legacypool.go (2)
  • 119-126: The function signatures for StateAt and StateAtBlockNumber have been updated to return state.StateDBI instead of *state.StateDB. Ensure that all calls to these functions throughout the codebase have been updated to handle the new return type. Also, verify that the implementation of these methods correctly returns an instance of a type that satisfies the state.StateDBI interface.

  • 218-219: The type of currentState has been changed from *state.StateDB to state.StateDBI. This change aligns with the shift towards an interface-based approach for state management. Make sure that all usages of currentState in the code are compatible with this change.

core/state/state_test.go (1)
  • 249-252: The function compareStateObjects has been updated to accept arguments of type *StateObject instead of *stateObject. Ensure that all calls to this function throughout the codebase have been updated to match the new argument types. Also, verify that the change from stateObject to StateObject does not expose any internal state or methods that should remain unexported.
eth/filters/filter_system.go (1)
  • 545-551: The call to es.txsSub.Unsubscribe() has been commented out. This could potentially lead to memory leaks as the subscription may not be properly cleaned up when the event loop ends. If this is intentional, please verify and provide a comment explaining why this line is commented out.
- // es.txsSub.Unsubscribe()
+ es.txsSub.Unsubscribe()
core/vm/evm.go (15)
  • 19-23: The import of the errors package is new in this hunk. Ensure that it's used appropriately in the code.

  • 102-109: The PrecompileManager field has been added to the EVM struct. This change suggests a shift towards an interface-based approach for managing and executing precompiled contracts in the EVM.

  • 137-142: The instantiation of PrecompileManager using NewPrecompileManager() within NewEVM() is a new addition. Make sure that NewPrecompileManager() is implemented correctly and that it properly initializes the PrecompileManager.

  • 144-161: A new function NewEVMWithPrecompiles() has been introduced, which returns a new EVM instance with a precompile manager. This function seems to be a variant of NewEVM(), allowing the caller to provide a custom PrecompileManager. Ensure that all calls to this function throughout the codebase are correct and that the provided PrecompileManager is valid.

  • 186-192: New getter methods GetStateDB() and GetContext() have been added to the EVM struct. These methods improve encapsulation by providing controlled access to the StateDB and Context fields.

  • 208-209: The method of checking if a contract is precompiled has changed from evm.precompile(addr) to evm.PrecompileManager.Has(addr). Ensure that the Has() method is implemented correctly and that it accurately determines whether a contract is precompiled.

  • 245-248: The execution of precompiled contracts has been updated to use the Run() method of the PrecompileManager. Ensure that this method is implemented correctly and that it properly executes precompiled contracts.

  • 269-272: The error handling has been updated to use the errors.Is() function for checking if the error is ErrExecutionReverted. This change improves the robustness of the error handling by allowing for wrapped errors.

  • 309-313: Similar to the changes in lines 245-248, the execution of precompiled contracts in the CallCode() method has been updated to use the Run() method of the PrecompileManager.

  • 323-327: The error handling in the CallCode() method has been updated to use the errors.Is() function, similar to the changes in lines 269-272.

  • 356-361: The execution of precompiled contracts in the DelegateCall() method has been updated to use the Run() method of the PrecompileManager, similar to the changes in lines 245-248 and 309-313.

  • 370-375: The error handling in the DelegateCall() method has been updated to use the errors.Is() function, similar to the changes in lines 269-272 and 323-327.

  • 411-415: The execution of precompiled contracts in the StaticCall() method has been updated to use the Run() method of the PrecompileManager, similar to the previous changes.

  • 430-435: The error handling in the StaticCall() method has been updated to use the errors.Is() function, similar to the previous changes.

  • 485-487: Error handling has been added after the StateDB.AddBalance() and StateDB.SetNonce() calls. This is a good practice as it ensures that any errors that occur during these operations are caught and handled appropriately.

eth/state_accessor.go (4)
  • 40-43: The function signature for hashState() has been updated to use the state.StateDBI interface instead of the concrete type *state.StateDB. This change promotes better abstraction and decoupling, allowing different implementations of the StateDBI interface to be used interchangeably. Ensure that all calls to this function throughout the codebase have been updated to match the new signature.

  • 177-180: Similar to the hashState() function, the pathState() function's signature has also been updated to use the state.StateDBI interface. This change is consistent with the shift towards an interface-based approach for state management. Verify that all calls to this function are updated accordingly.

  • 211-216: The stateAtBlock() function now accepts and returns state.StateDBI instead of *state.StateDB, aligning with the changes made in the hashState() and pathState() functions. This change enhances modularity and flexibility in the code by allowing different StateDBI implementations to be used. Make sure all calls to this function are updated to reflect these changes.

  • 240-261: > Note: This review was outside of the patch, so it was mapped to the patch with the greatest overlap. Original lines [219-261]

The stateAtTransaction() function has been updated to return state.StateDBI instead of *state.StateDB. This change is in line with the rest of the updates in this file, promoting an interface-based approach for state management. Additionally, the creation of the EVM environment (line 248) now uses eth.APIBackend.GetEVM(), which might provide more flexibility and control over the EVM configuration. Ensure that all calls to this function are updated to match the new signature and that the new method for creating the EVM environment does not introduce any unexpected behavior.

core/vm/contracts_test.go (2)
  • 19-27: The import of the context and math/big packages is new in this hunk. Ensure that these imports are necessary for the code changes in this file.

  • 98-106: The function RunPrecompiledContract is newly introduced. It seems to execute a precompiled contract, checking if there's enough gas supplied before running the contract. If not, it returns an ErrOutOfGas error. This function appears to be a utility function for testing purposes. Please ensure that the context being passed to the p.Run method on line 104 is appropriate for your use case.

eth/tracers/api.go (7)
  • 36-43: The import path for ethapi has been updated from github.com/ethereum/go-ethereum/internal/ethapi to github.com/ethereum/go-ethereum/ethapi. Ensure that this new path is correct and accessible.

  • 85-90: The function signatures for StateAtBlock and StateAtTransaction have been updated to use the state.StateDBI interface instead of the *state.StateDB pointer. Make sure all calls to these functions throughout the codebase have been updated to match the new signatures.

  • 183-189: The statedb field in the blockTraceTask struct has been updated to use the state.StateDBI interface instead of the *state.StateDB pointer. This change should not affect the functionality of the code, but it's a good practice to ensure that all usages of this struct are still valid with this change.

  • 200-205: The statedb field in the txTraceTask struct has been updated to use the state.StateDBI interface instead of the *state.StateDB pointer. This change should not affect the functionality of the code, but it's a good practice to ensure that all usages of this struct are still valid with this change.

  • 308-314: The statedb variable has been updated to use the state.StateDBI interface instead of the *state.StateDB pointer. This change should not affect the functionality of the code, but it's a good practice to ensure that all usages of this variable are still valid with this change.

  • 626-632: The statedb parameter in the traceBlockParallel function has been updated to use the state.StateDBI interface instead of the *state.StateDB pointer. Make sure all calls to this function throughout the codebase have been updated to match the new signature.

  • 922-928: The statedb parameter in the traceTx function has been updated to use the state.StateDBI interface instead of the *state.StateDB pointer. Make sure all calls to this function throughout the codebase have been updated to match the new signature.

eth/backend.go (2)
  • 44-52: The import path for the ethapi package has been updated from github.com/ethereum/go-ethereum/internal/ethapi to github.com/ethereum/go-ethereum/ethapi. Ensure that this new path is correct and accessible.

  • 299-305: The function call ethapi.GetAPIs(s.APIBackend, s.BlockChain()) now includes an additional argument s.BlockChain(). Make sure all calls to this function have been updated accordingly throughout the codebase.

core/blockchain_reader.go (2)
  • 323-325: The function State() now returns an interface state.StateDBI instead of a pointer to state.StateDB. This change is part of the shift towards an interface-based approach for state management. Ensure that all calls to this function throughout the codebase have been updated to handle the new return type.

  • 328-330: Similar to the State() function, the StateAt() function now returns an interface state.StateDBI instead of a pointer to state.StateDB. Make sure all calls to this function are updated accordingly.

core/state_processor.go (6)
  • 61-64: The function signature of Process has been updated to accept state.StateDBI instead of *state.StateDB. Ensure that all calls to this function throughout the codebase have been updated to match the new signature.

  • 90-93: The order of arguments in the applyTransaction function call has been changed. The vmenv and msg parameters are now passed first, followed by the rest of the parameters. This change should not cause any issues as long as it is consistent across all calls to applyTransaction.

  • 108-114: The function signature of applyTransaction has been updated to accept state.StateDBI instead of *state.StateDB, and the order of arguments has been changed. Ensure that all calls to this function throughout the codebase have been updated to match the new signature and argument order.

  • 161-207: A new function applyTransactionWithResult has been introduced. It appears to be a variant of applyTransaction that also returns an ExecutionResult. This function seems to follow good coding practices, with proper error handling and usage of existing functions like ApplyMessage and crypto.CreateAddress. However, ensure that this function is used correctly in the codebase, especially considering its side effects (like state changes).

  • 213-250: The function signatures of ApplyTransaction, ApplyTransactionWithResult, ApplyTransactionWithEVM, and ApplyTransactionWithEVMWithResult have been updated to accept state.StateDBI instead of *state.StateDB. Ensure that all calls to these functions throughout the codebase have been updated to match the new signatures.

  • 266-269: The function signature of ProcessBeaconBlockRoot has been updated to accept state.StateDBI instead of *state.StateDB. Ensure that all calls to this function throughout the codebase have been updated to match the new signature.

eth/filters/filter_system_test.go (1)
  • 35-43: The import path for the ethapi package has been updated from github.com/ethereum/go-ethereum/internal/ethapi to github.com/ethereum/go-ethereum/ethapi. Ensure that this new path is correct and accessible, and that it does not break any dependencies.
core/vm/contracts.go (3)
  • 42-48: The PrecompiledContract interface has been updated with two new methods: RegistryKey() and an updated Run() method. Ensure that all implementations of this interface throughout the codebase have been updated to include these new methods.

  • 156-159: The function signature for ActivePrecompiles has changed from accepting a value of type params.Rules to a pointer to a params.Rules. Make sure all calls to this function are updated accordingly.

  • 741-750: The Run method in various contracts now includes additional parameters: ctx context.Context, evm PrecompileEVM, caller common.Address, and value *big.Int. Ensure that all calls to this method are updated accordingly.

eth/tracers/api_test.go (3)
  • 42-42: The import path for the ethapi package has been updated from github.com/ethereum/go-ethereum/internal/ethapi to github.com/ethereum/go-ethereum/ethapi. Please ensure that this new path is correct and accessible, and that it does not break any dependencies.

  • 142-145: The function signature of StateAtBlock has been changed. The type of the base parameter and the return type have been updated from *state.StateDB to state.StateDBI. This change suggests a shift towards an interface-based approach for state management. Ensure that all calls to this function throughout the codebase have been updated to match the new signature.

  • 158-161: The function signature of StateAtTransaction has been changed. The return type has been updated from *state.StateDB to state.StateDBI. This change suggests a shift towards an interface-based approach for state management. Ensure that all calls to this function throughout the codebase have been updated to match the new signature.

core/state/state_object.go (15)
  • 57-66: The stateObject struct has been renamed to StateObject, making it an exported type. This change will affect all the places in the codebase where this struct is used. Ensure that all references to this struct have been updated accordingly.

  • 100-108: The newObject function now returns a *StateObject instead of a *stateObject. This change is consistent with the renaming of the struct, but make sure that all calls to this function have been updated to handle the new return type.

  • 118-120: The EncodeRLP method now operates on a *StateObject instead of a *stateObject. This change is consistent with the renaming of the struct, but ensure that all calls to this method have been updated accordingly.

  • 140-143: The getTrie method now operates on a *StateObject instead of a *stateObject. This change is consistent with the renaming of the struct, but ensure that all calls to this method have been updated accordingly.

  • 159-162: The GetState method now operates on a *StateObject instead of a *stateObject. This change is consistent with the renaming of the struct, but ensure that all calls to this method have been updated accordingly.

  • 170-173: The GetCommittedState method now operates on a *StateObject instead of a *stateObject. This change is consistent with the renaming of the struct, but ensure that all calls to this method have been updated accordingly.

  • 230-233: The SetState method now operates on a *StateObject instead of a *stateObject. This change is consistent with the renaming of the struct, but ensure that all calls to this method have been updated accordingly.

  • 273-276: The updateTrie method now operates on a *StateObject instead of a *stateObject. This change is consistent with the renaming of the struct, but ensure that all calls to this method have been updated accordingly.

  • 361-364: The updateRoot method now operates on a *StateObject instead of a *stateObject. This change is consistent with the renaming of the struct, but ensure that all calls to this method have been updated accordingly.

  • 378-381: The commit method now operates on a *StateObject instead of a *stateObject. This change is consistent with the renaming of the struct, but ensure that all calls to this method have been updated accordingly.

  • 404-407: The AddBalance method now operates on a *StateObject instead of a *stateObject. This change is consistent with the renaming of the struct, but ensure that all calls to this method have been updated accordingly.

  • 418-422: The SubBalance method now operates on a *StateObject instead of a *stateObject. This change is consistent with the renaming of the struct, but ensure that all calls to this method have been updated accordingly.

  • 500-503: The SetCode method now operates on a *StateObject instead of a *stateObject. This change is consistent with the renaming of the struct, but ensure that all calls to this method have been updated accordingly.

  • 516-521: The SetNonce method now operates on a *StateObject instead of a *stateObject. This change is consistent with the renaming of the struct, but ensure that all calls to this method have been updated accordingly.

  • 540-542: All these methods now operate on a *StateObject instead of a *stateObject. These changes are consistent with the renaming of the struct, but ensure that all calls to these methods have been updated accordingly.

SelfDestruct(common.Address)
HasSelfDestructed(common.Address) bool

Selfdestruct6780(common.Address)
Copy link

Choose a reason for hiding this comment

The reason will be displayed to describe this comment to others. Learn more.

The method Selfdestruct6780(common.Address) lacks a comment explaining its purpose. It's important to document what this function does, especially given its name doesn't provide much context.

TxIndex() int
Preimages() map[common.Hash][]byte

GetOrNewStateObject(addr common.Address) *StateObject
Copy link

Choose a reason for hiding this comment

The reason will be displayed to describe this comment to others. Learn more.

The method GetOrNewStateObject(addr common.Address) *StateObject returns a pointer to a StateObject. If multiple goroutines call this method and manipulate the returned StateObject, it could lead to data races. Consider returning a copy of the StateObject or using synchronization primitives to prevent concurrent access.

Comment on lines 262 to 265

st.initialGas = st.msg.GasLimit
st.state.SubBalance(st.msg.From, mgval)
return nil
return st.state.Error()
Copy link

Choose a reason for hiding this comment

The reason will be displayed to describe this comment to others. Learn more.

The function st.state.SubBalance(st.msg.From, mgval) is called and then immediately after, the error from the state is returned. This change might cause unexpected behavior if SubBalance method doesn't set an error in the state when it fails. It would be better to modify the SubBalance method to return an error directly, which can be checked here.

-  	st.state.SubBalance(st.msg.From, mgval)
-  	return st.state.Error()
+  	if err := st.state.SubBalance(st.msg.From, mgval); err != nil {
+  		return err
+  	}
+  	return nil

Comment on lines 413 to 418
} else {
// Increment the nonce for the next transaction
st.state.SetNonce(msg.From, st.state.GetNonce(sender.Address())+1)
if err := st.state.Error(); err != nil {
return nil, err
}
Copy link

Choose a reason for hiding this comment

The reason will be displayed to describe this comment to others. Learn more.

Similar to the previous comment, the error checking after st.state.SetNonce(msg.From, st.state.GetNonce(sender.Address())+1) could lead to unexpected behavior if SetNonce doesn't set an error in the state when it fails. Consider modifying SetNonce to return an error directly.

-  	st.state.SetNonce(msg.From, st.state.GetNonce(sender.Address())+1)
-  	if err := st.state.Error(); err != nil {
-  		return nil, err
-  	}
+  	if err := st.state.SetNonce(msg.From, st.state.GetNonce(sender.Address())+1); err != nil {
+  		return nil, err
+  	}

Comment on lines 439 to 444
fee := new(big.Int).SetUint64(st.gasUsed())
fee.Mul(fee, effectiveTip)
st.state.AddBalance(st.evm.Context.Coinbase, fee)
if err := st.state.Error(); err != nil {
return nil, err
}
Copy link

Choose a reason for hiding this comment

The reason will be displayed to describe this comment to others. Learn more.

Again, the error checking after st.state.AddBalance(st.evm.Context.Coinbase, fee) could lead to unexpected behavior if AddBalance doesn't set an error in the state when it fails. Consider modifying AddBalance to return an error directly.

-  	st.state.AddBalance(st.evm.Context.Coinbase, fee)
-  	if err := st.state.Error(); err != nil {
-  		return nil, err
-  	}
+  	if err := st.state.AddBalance(st.evm.Context.Coinbase, fee); err != nil {
-  		return nil, err
+  	}

core/blockchain_reader.go Show resolved Hide resolved
Comment on lines 33 to 38
// NewPrecompileManager returns a new PrecompileManager for the current chain rules.
func NewPrecompileManager(rules *params.Rules) PrecompileManager {
return &precompileManager{
rules: rules,
}
}
Copy link

Choose a reason for hiding this comment

The reason will be displayed to describe this comment to others. Learn more.

The NewPrecompileManager function initializes a new precompileManager with the provided rules but does not initialize the precompiles map. This could lead to potential null pointer exceptions if the Has or Get methods are called before the precompiles map is initialized. Consider initializing the precompiles map in the NewPrecompileManager function.

func NewPrecompileManager(rules *params.Rules) PrecompileManager {
	return &precompileManager{
		rules: rules,
+		precompiles: activePrecompiles(rules),
	}
}

Comment on lines 40 to 47
// Has returns whether a precompiled contract is deployed at the given address.
func (pm *precompileManager) Has(addr common.Address) bool {
if pm.precompiles == nil {
pm.precompiles = activePrecompiles(pm.rules)
}
_, found := pm.precompiles[addr]
return found
}
Copy link

Choose a reason for hiding this comment

The reason will be displayed to describe this comment to others. Learn more.

The Has method checks if a precompiled contract exists for a given address. However, it also initializes the precompiles map if it's not already initialized. This side effect might be unexpected for a function named Has. Consider separating the initialization of the precompiles map from this method to improve clarity and maintainability.

Comment on lines 49 to 55
// Get returns the precompiled contract deployed at the given address.
func (pm *precompileManager) Get(addr common.Address) PrecompiledContract {
if pm.precompiles == nil {
pm.precompiles = activePrecompiles(pm.rules)
}
return pm.precompiles[addr]
}
Copy link

Choose a reason for hiding this comment

The reason will be displayed to describe this comment to others. Learn more.

Similar to the Has method, the Get method also initializes the precompiles map if it's not already initialized. This side effect might be unexpected for a function named Get. Consider separating the initialization of the precompiles map from this method to improve clarity and maintainability.

Comment on lines 57 to 62
// GetActive sets the chain rules on the precompile manager and returns the list of active
// precompile addresses.
func (pm *precompileManager) GetActive(rules *params.Rules) []common.Address {
pm.rules = rules
return ActivePrecompiles(pm.rules)
}
Copy link

Choose a reason for hiding this comment

The reason will be displayed to describe this comment to others. Learn more.

The GetActive method sets the chain rules on the precompile manager and returns the list of active precompile addresses. However, it modifies the state of the precompile manager by changing its rules field. This side effect might be unexpected for a function named GetActive. Consider renaming this method to reflect that it changes the state of the precompile manager, or refactor the code to avoid changing the state.

Copy link

@coderabbitai coderabbitai bot left a comment

Choose a reason for hiding this comment

The reason will be displayed to describe this comment to others. Learn more.

Review Status

Actionable comments generated: 2

Commits Files that changed from the base of the PR and between 564e2be and 814ffd5.
Files selected for processing (5)
  • eth/backend.go (3 hunks)
  • miner/miner.go (3 hunks)
  • miner/miner_test.go (3 hunks)
  • miner/worker.go (11 hunks)
  • miner/worker_test.go (1 hunks)
Additional comments (Suppressed): 22
miner/worker_test.go (1)
  • 147-148: Ensure that all calls to BlockChain() and TxPool() throughout the codebase have been updated to match the new return types. Also, verify if any changes are required for the newly introduced MinerChain() method.
eth/backend.go (2)
  • 44-52: The import path for ethapi has been changed from github.com/ethereum/go-ethereum/internal/ethapi to github.com/ethereum/go-ethereum/ethapi. Ensure that the new path is correct and all functionalities are working as expected.

  • 299-305: The function signature of ethapi.GetAPIs() has been modified to include an additional parameter s.BlockChain(). Make sure that this change doesn't break any existing calls to this function and the added parameter is handled correctly in the function definition.

miner/miner.go (3)
  • 40-45: The Backend interface has been updated to include a new method MinerChain(). Ensure that all implementations of this interface have been updated accordingly.

  • 47-58: The BlockChain interface has been significantly expanded with new methods. This change enhances the modularity and flexibility of the codebase, but it's important to ensure that all implementations of this interface are updated to include these new methods. Also, the return type of StateAt() and StateAtBlockNumber() methods has been changed from *state.StateDB to state.StateDBI, which indicates a shift from a concrete implementation to an interface-based approach. This change should improve the testability and maintainability of the code.

  • 221-223: The return type of the Pending() method has been changed from (*types.Block, *state.StateDB) to (*types.Block, state.StateDBI). This change aligns with the shift towards an interface-based approach for managing state databases. Make sure to update all calls to this method throughout the codebase to handle the new return type.

miner/miner_test.go (5)
  • 42-45: The type of bc in mockBackend struct has been changed from a pointer to core.BlockChain to BlockChain. This change indicates that the code is moving towards an interface-based approach, which can improve modularity and testability. However, ensure that all methods that were available on *core.BlockChain are also available on the BlockChain interface.

  • 54-60: The method MinerChain() has been added to the mockBackend struct. This method returns the blockchain associated with the miner. Ensure that this method is used appropriately throughout the codebase.

  • 66-68: The function signature of StateAtBlock has been updated to return state.StateDBI instead of *state.StateDB. This aligns with the shift towards using interfaces. However, make sure that all calls to this function have been updated accordingly.

  • 71-75: The type of statedb in testBlockChain struct has been changed from a pointer to state.StateDB to state.StateDBI. This change indicates that the code is moving towards an interface-based approach, which can improve modularity and testability. However, ensure that all methods that were available on *state.StateDB are also available on the state.StateDBI interface.

  • 92-98: The function signatures of StateAt and StateAtBlockNumber have been updated to return state.StateDBI instead of *state.StateDB. This aligns with the shift towards using interfaces. However, make sure that all calls to these functions have been updated accordingly.

miner/worker.go (11)
  • 86-89: The state field in the environment struct has been changed from a pointer to an interface. This change enhances modularity and allows for different implementations of the state database. Ensure that all usages of this field are updated accordingly.

  • 134-137: Similar to the previous comment, the state field in the task struct has been changed from a pointer to an interface. Make sure all usages of this field are updated to match the new type.

  • 179-182: The chain field in the worker struct has been changed from a pointer to an interface. This change improves flexibility by allowing different blockchain implementations. Verify that all usages of this field have been updated to match the new type.

  • 215-218: The snapshotState field in the worker struct has been changed from a pointer to an interface. This change enhances modularity and allows for different implementations of the state snapshot. Ensure that all usages of this field are updated accordingly.

  • 249-252: The method used to get the blockchain from the Ethereum backend has been changed from eth.BlockChain() to eth.MinerChain(). Verify that this new method returns the expected results and that it doesn't introduce any breaking changes.

  • 269-272: The method used to subscribe to chain head events has been changed from eth.BlockChain().SubscribeChainHeadEvent(worker.chainHeadCh) to eth.MinerChain().SubscribeChainHeadEvent(worker.chainHeadCh). Confirm that this new method works as expected and that it doesn't introduce any breaking changes.

  • 340-343: The return type of the pending() method has been changed from a pointer to an interface. This change enhances modularity and allows for different implementations of the pending state. Ensure that all usages of this method are updated accordingly.

  • 552-555: The newTransactionsByPriceAndNonce function has been renamed to NewTransactionsByPriceAndNonce. This change makes the function exported, allowing it to be used outside of its package. Verify that this change is intentional and doesn't introduce any security issues.

  • 708-715: Error handling has been added when getting the state at a specific block root. If an error occurs, the code now tries to get the state at a specific block number instead. This change improves robustness by providing a fallback mechanism. However, ensure that the use of w.chain.StateAtBlockNumber(parent.Number.Uint64()) is appropriate in this context.

  • 797-800: The commitTransactions method's second parameter type has been changed from a pointer to an interface. This change enhances modularity and allows for different implementations of transactions sorted by price and nonce. Ensure that all calls to this method have been updated accordingly.

  • 993-1002: The newTransactionsByPriceAndNonce function has been renamed to NewTransactionsByPriceAndNonce. This change makes the function exported, allowing it to be used outside of its package. Verify that this change is intentional and doesn't introduce any security issues.

Comment on lines +147 to +148
func (b *testWorkerBackend) BlockChain() BlockChain { return b.chain }
func (b *testWorkerBackend) MinerChain() BlockChain { return b.chain }
Copy link

Choose a reason for hiding this comment

The reason will be displayed to describe this comment to others. Learn more.

The function MinerChain() is newly introduced and it seems to return the same value as BlockChain(). If these two functions are intended to serve different purposes, consider adding comments to clarify their roles. If they are meant to be identical, consider removing one to avoid redundancy.

- func (b *testWorkerBackend) BlockChain() BlockChain { return b.chain }
- func (b *testWorkerBackend) MinerChain() BlockChain { return b.chain }
+ // BlockChain returns the blockchain associated with the test worker backend.
+ func (b *testWorkerBackend) BlockChain() BlockChain { return b.chain }

@@ -468,6 +467,7 @@ func (s *Ethereum) Miner() *miner.Miner { return s.miner }

func (s *Ethereum) AccountManager() *accounts.Manager { return s.accountManager }
func (s *Ethereum) BlockChain() *core.BlockChain { return s.blockchain }
func (s *Ethereum) MinerChain() miner.BlockChain { return s.blockchain }
Copy link

Choose a reason for hiding this comment

The reason will be displayed to describe this comment to others. Learn more.

A new method MinerChain() has been introduced. This seems to return the blockchain object just like the BlockChain() method. If these two methods serve the same purpose, consider removing one to avoid redundancy. If they serve different purposes, ensure that the differences are well-documented.

Copy link

@coderabbitai coderabbitai bot left a comment

Choose a reason for hiding this comment

The reason will be displayed to describe this comment to others. Learn more.

Review Status

Actionable comments generated: 0

Commits Files that changed from the base of the PR and between 814ffd5 and 0c73bc8.
Files selected for processing (1)
  • core/state_processor.go (5 hunks)
Additional comments (Suppressed): 7
core/state_processor.go (7)
  • 35-54: The StateProcessor struct has been updated to use an interface SPBlockchain instead of a concrete type *BlockChain. This change enhances modularity and flexibility, allowing any type that implements the SPBlockchain interface to be used with the StateProcessor. Ensure all implementations of SPBlockchain adhere to its defined methods.
-	bc     *BlockChain         // Canonical block chain
+	bc     SPBlockchain        // Canonical block chain
  • 66-69: The Process method now accepts state.StateDBI as an argument instead of *state.StateDB. This is another shift from a concrete implementation to an interface-based approach. Make sure all calls to this function are updated accordingly.
- func (p *StateProcessor) Process(block *types.Block, statedb *state.StateDB, cfg vm.Config) (types.Receipts, []*types.Log, uint64, error) {
+ func (p *StateProcessor) Process(block *types.Block, statedb state.StateDBI, cfg vm.Config) (types.Receipts, []*types.Log, uint64, error) {
  • 95-98: The order of arguments in the applyTransaction function call has changed. The vmenv and msg parameters have switched places. Ensure that this change does not affect the functionality of the code.
- receipt, err := applyTransaction(msg, p.config, gp, statedb, blockNumber, blockHash, tx, usedGas, vmenv)
+ receipt, err := applyTransaction(vmenv, msg, p.config, gp, statedb, blockNumber, blockHash, tx, usedGas)
  • 113-119: Similar to the previous comment, the order of arguments in the applyTransaction function definition has changed. The vmenv and msg parameters have switched places. This change should be consistent across all calls to this function.
- func applyTransaction(msg *Message, config *params.ChainConfig, gp *GasPool, statedb *state.StateDB, blockNumber *big.Int, blockHash common.Hash, tx *types.Transaction, usedGas *uint64, evm *vm.EVM) (*types.Receipt, error) {
+ func applyTransaction(evm *vm.EVM, msg *Message, config *params.ChainConfig, gp *GasPool, statedb state.StateDBI, blockNumber *big.Int, blockHash common.Hash, tx *types.Transaction, usedGas *uint64) (*types.Receipt, error) {
  • 166-212: A new function applyTransactionWithResult has been introduced. It seems to perform similar operations as applyTransaction, but it also returns an ExecutionResult. Ensure that this function is used correctly where the execution result is needed.

  • 214-255: The public functions ApplyTransaction, ApplyTransactionWithResult, ApplyTransactionWithEVM, and ApplyTransactionWithEVMWithResult have been updated to use the state.StateDBI interface instead of the *state.StateDB concrete type. Make sure all calls to these functions are updated accordingly.

- statedb *state.StateDB
+ statedb state.StateDBI
  • 271-274: The ProcessBeaconBlockRoot function now accepts state.StateDBI as an argument instead of *state.StateDB. This is another shift from a concrete implementation to an interface-based approach. Make sure all calls to this function are updated accordingly.
- func ProcessBeaconBlockRoot(beaconRoot common.Hash, vmenv *vm.EVM, statedb *state.StateDB) {
+ func ProcessBeaconBlockRoot(beaconRoot common.Hash, vmenv *vm.EVM, statedb state.StateDBI) {

Copy link

@coderabbitai coderabbitai bot left a comment

Choose a reason for hiding this comment

The reason will be displayed to describe this comment to others. Learn more.

Review Status

Actionable comments generated: 8

Commits Files that changed from the base of the PR and between 0c73bc8 and f9e036d.
Files selected for processing (13)
  • core/state/interface.go (1 hunks)
  • core/state/statedb.go (15 hunks)
  • core/state_processor.go (5 hunks)
  • core/state_transition.go (1 hunks)
  • core/vm/contracts.go (24 hunks)
  • core/vm/evm.go (14 hunks)
  • core/vm/interface.go (2 hunks)
  • core/vm/precompile_manager.go (1 hunks)
  • core/vm/runtime/runtime.go (5 hunks)
  • eth/tracers/js/goja.go (1 hunks)
  • eth/tracers/native/4byte.go (1 hunks)
  • eth/tracers/native/call_flat.go (1 hunks)
  • ethapi/api.go (8 hunks)
Additional comments (Suppressed): 53
core/state/interface.go (1)
  • 29-107: The interface StateDBI has been introduced to abstract the state database. This is a good practice as it enhances modularity and makes testing easier. However, there are some points that need attention:
  1. The method GetPrecompileManager() returns any. It's better to return a specific interface or type for clarity and type safety.

  2. The method Selfdestruct6780(common.Address) lacks a comment explaining its purpose. It's important to document public methods in an interface.

  3. The method DumpToCollector(c DumpCollector, conf *DumpConfig) (nextKey []byte) uses a custom type DumpCollector which is not defined in this file. Ensure that this type is properly defined and imported.

  4. The method GetOrNewStateObject(addr common.Address) *StateObject returns a pointer to StateObject. If StateObject is a struct, consider returning an interface instead to keep the abstraction consistent.

Please verify these points and make necessary changes.

core/state_transition.go (1)
  • 402-405: The Prepare method now includes an additional argument vm.ActivePrecompiles(st.evm, rules). Ensure that this change doesn't break the existing functionality and is compatible with the rest of the codebase. Also, verify if the new argument correctly represents the active precompiled contracts for the given EVM and rules.
eth/tracers/native/4byte.go (2)
  • 82-85: The CaptureStart method now includes an additional call to vm.ActivePrecompiles(env, rules) with the EVM environment and chain rules as parameters. This change suggests that the list of active precompiled contracts is now dynamically updated based on the current block context. Ensure that this dynamic update does not introduce any unexpected behavior or performance issues.

  • 85-85: The assignment of t.activePrecompiles has been modified. Previously, it was assigned the result of vm.ActivePrecompiles(rules), but now it's assigned the result of vm.ActivePrecompiles(env, rules). This change implies that the function vm.ActivePrecompiles() might have been updated to accept an additional parameter. Verify that all calls to this function throughout the codebase have been updated to match the new signature.

core/vm/precompile_manager.go (2)
  • 36-39: The Get method currently returns nil, false for all cases. This might be a placeholder implementation. Ensure that the actual logic is implemented before merging.

  • 41-45: Similar to the Get method, the GetActive method also returns nil for all cases. This might be a placeholder implementation. Ensure that the actual logic is implemented before merging.

eth/tracers/js/goja.go (1)
  • 251-254: The vm.ActivePrecompiles function now takes two arguments instead of one. Ensure that this change is reflected across all calls to this function in the codebase. Also, verify that the new argument env is always available and correctly initialized where this function is called.
-	t.activePrecompiles = vm.ActivePrecompiles(rules)
+	t.activePrecompiles = vm.ActivePrecompiles(env, rules)
core/vm/interface.go (3)
  • 28-31: The StateDB interface has been simplified to embed the state.StateDBI interface. Ensure that the state.StateDBI interface includes all necessary methods previously defined in the StateDB interface.

  • 47-59: A new interface PrecompileManager is introduced for managing precompiled contracts. This seems to be a good abstraction, but ensure that all methods are implemented wherever this interface is used.

  • 61-70: The PrecompileEVM interface is introduced to provide stateful precompiles with a way to call back into the EVM. Make sure that all methods are correctly implemented and used.

core/vm/contracts.go (1)
  • 19-23: The import of context is new. Ensure that it's used appropriately in the codebase.
ethapi/api.go (7)
  • 732-748: The code for creating the accountProof has been commented out and replaced with a TODO comment. This might affect the functionality of the method if proofs are required elsewhere in the codebase. Please verify this change.
- 	// tr, err := trie.NewStateTrie(trie.StateTrieID(header.Root), state.Database().TrieDB())
- 	// if err != nil {
- 	// 	return nil, err
- 	// }
- 	var accountProof proofList = make(proofList, 0)
- 	// if err := tr.Prove(crypto.Keccak256(address.Bytes()), &accountProof); err != nil {
- 	// 	return nil, err
- 	// }
  • 957-970: The Apply function now checks for errors after setting the nonce and code. This is a good practice as it ensures that any issues are caught immediately.
+	if err := state.Error(); err != nil {
+		return err
+	}
  • 974-979: Similar to the previous comment, error checking has been added after setting the balance.
+	if err := state.Error(); err != nil {
+		return err
+	}
  • 1072-1075: The type of the state parameter in the doCall function has been changed from *state.StateDB to state.StateDBI. Ensure all calls to this function have been updated to match the new signature.

  • 1093-1096: The way blockCtx is created has been changed. Make sure this new approach is compatible with the rest of your codebase.

  • 1185-1188: The type of the state parameter in the executeEstimate function has been changed from *state.StateDB to state.StateDBI. Ensure all calls to this function have been updated to match the new signature.

  • 1318-1320: A 20% increase has been added to the hi variable. This seems like a workaround and might cause issues in the future. It would be better to understand why this is needed and try to address the root cause.

+	// TODO: FIGURE OUT WHY THIS HACK IS NEEDED THANKS
+	// bump the estimate gas by 20% for stateful precompiles
+	hi += uint64(float64(hi) * 0.2)

1637:
The way precompiles are retrieved has been changed, and there's a TODO comment suggesting further changes. Make sure these changes don't break anything and that the suggested changes are tracked and implemented.

-	precompiles := vm.ActivePrecompiles(b.ChainConfig().Rules(header.Number, isPostMerge, header.Time))
+	precompiles := vm.ActivePrecompiles(vm.NewEVM(vm.BlockContext{}, vm.TxContext{}, state, b.ChainConfig(), vm.Config{}), rules) // TODO: use evm precompile manager instead
eth/tracers/native/call_flat.go (1)
  • 148-151: The vm.ActivePrecompiles function now takes two arguments instead of one. Ensure that this change is reflected across all calls to this function in the codebase.
-	t.activePrecompiles = vm.ActivePrecompiles(rules)
+	t.activePrecompiles = vm.ActivePrecompiles(env, rules)
core/vm/runtime/runtime.go (5)
  • 50-52: The type of State in the Config struct has been changed from a pointer to state.StateDB to an interface state.StateDBI. This change enhances modularity and allows for different implementations of the state database. Ensure that all uses of State throughout the codebase are compatible with this new interface.

  • 105-108: The return type of the Execute function has been updated to match the new state.StateDBI interface. Make sure that all calls to this function handle the returned state correctly.

  • 123-126: The vm.ActivePrecompiles function now takes two arguments: vmenv and rules. Verify that this change is consistent with updates to the vm.ActivePrecompiles function definition elsewhere in the codebase.

  • 156-159: Similar to the previous comment, the vm.ActivePrecompiles function now takes two arguments: vmenv and rules. Confirm that this change aligns with updates to the vm.ActivePrecompiles function definition.

  • 184-187: Again, the vm.ActivePrecompiles function now takes two arguments: vmenv and rules. Validate that this change is consistent with updates to the vm.ActivePrecompiles function definition.

core/vm/evm.go (14)
  • 19-23: The import of the errors package is new. Ensure that it's used appropriately in the code.

  • 53-60: The precompile lookup logic has been updated to use a PrecompileManager if the initial lookup fails. This change enhances modularity and allows for more flexible management of precompiled contracts.

  • 105-112: A new field PrecompileManager has been added to the EVM struct. This change aligns with the introduction of the PrecompileManager interface, enhancing modularity and abstraction.

  • 140-150: The creation of an EVM instance now includes setting up a PrecompileManager. This change ensures that each EVM instance has its own PrecompileManager, which can be used to manage precompiled contracts.

  • 232-238: The call to run a precompiled contract now uses the PrecompileManager. This change aligns with the introduction of the PrecompileManager interface and enhances modularity.

  • 254-260: Error handling has been updated to use the errors.Is function from the standard library. This is a more reliable way to compare errors than direct comparison.

  • 295-301: The call to run a precompiled contract now uses the PrecompileManager. This change aligns with the introduction of the PrecompileManager interface and enhances modularity.

  • 307-313: Error handling has been updated to use the errors.Is function from the standard library. This is a more reliable way to compare errors than direct comparison.

  • 340-346: The call to run a precompiled contract now uses the PrecompileManager. This change aligns with the introduction of the PrecompileManager interface and enhances modularity.

  • 351-357: Error handling has been updated to use the errors.Is function from the standard library. This is a more reliable way to compare errors than direct comparison.

  • 389-395: The call to run a precompiled contract now uses the PrecompileManager. This change aligns with the introduction of the PrecompileManager interface and enhances modularity.

  • 407-413: Error handling has been updated to use the errors.Is function from the standard library. This is a more reliable way to compare errors than direct comparison.

  • 502-508: Error handling has been updated to use the errors.Is function from the standard library. This is a more reliable way to compare errors than direct comparison.

  • 535-539: New getter methods have been added for BlockContext and StateDB. These changes improve encapsulation by providing controlled access to these fields.

core/state_processor.go (5)
  • 35-54: The type of bc in StateProcessor struct has been changed from *BlockChain to SPBlockchain. Ensure that all methods required by the SPBlockchain interface are implemented wherever a StateProcessor is used. Also, verify that all calls to NewStateProcessor have been updated to pass an instance of a type that implements SPBlockchain instead of *BlockChain.

  • 66-66: The type of statedb parameter in Process method has been changed from *state.StateDB to state.StateDBI. Make sure that all calls to this method throughout the codebase have been updated to match the new signature.

  • 113-113: The type of statedb parameter in applyTransaction function has been changed from *state.StateDB to state.StateDBI. Ensure that all calls to this function have been updated to match the new signature.

  • 167-167: The type of statedb parameter in ApplyTransaction function has been changed from *state.StateDB to state.StateDBI. Verify that all calls to this function have been updated to match the new signature.

  • 180-180: The type of statedb parameter in ProcessBeaconBlockRoot function has been changed from *state.StateDB to state.StateDBI. Ensure that all calls to this function have been updated to match the new signature.

core/state/statedb.go (10)
  • 82-85: The type of stateObjects has been changed from *stateObject to *StateObject. Ensure that the StateObject struct provides the same or enhanced functionality as the stateObject struct. Also, verify that all methods and properties of stateObject are available in StateObject.

  • 109-109: The type of accessList has been changed from *accessList to *AccessList. Ensure that the AccessList struct provides the same or enhanced functionality as the accessList struct. Also, verify that all methods and properties of accessList are available in AccessList.

  • 158-166: The initialization of stateObjects and accessList has been updated to use StateObject and AccessList respectively. This change is consistent with the type changes mentioned above.

  • 506-507: The type of obj in updateStateObject(obj *StateObject) has been changed from *stateObject to *StateObject. This change is consistent with the type changes mentioned above.

  • 538-539: The type of obj in deleteStateObject(obj *StateObject) has been changed from *stateObject to *StateObject. This change is consistent with the type changes mentioned above.

  • 553-556: The return type of getStateObject(addr common.Address) has been changed from *stateObject to *StateObject. This change is consistent with the type changes mentioned above.

  • 564-567: The return type of getDeletedStateObject(addr common.Address) has been changed from *stateObject to *StateObject. This change is consistent with the type changes mentioned above.

  • 617-625: The return and parameter types of createObject(addr common.Address) have been changed from *stateObject to *StateObject. This change is consistent with the type changes mentioned above.

  • 700-706: > Note: This review was outside of the patch, so it was mapped to the patch with the greatest overlap. Original lines [692-706]

The return type of Copy() has been changed from *StateDB to StateDBI. Ensure that StateDBI provides the same or enhanced functionality as *StateDB. Also, verify that all methods and properties of *StateDB are available in StateDBI.

  • 1318-1324: The initialization of al has been updated to use NewAccessList(). This change is consistent with the type changes mentioned above.

core/vm/precompile_manager.go Show resolved Hide resolved
core/vm/contracts.go Show resolved Hide resolved
core/vm/contracts.go Show resolved Hide resolved
core/vm/contracts.go Show resolved Hide resolved
core/vm/contracts.go Show resolved Hide resolved
core/state/statedb.go Show resolved Hide resolved
core/state/statedb.go Outdated Show resolved Hide resolved
core/state/statedb.go Show resolved Hide resolved
@coderabbitai
Copy link

coderabbitai bot commented Oct 8, 2023

CodeRabbit review skipped

By default, CodeRabbit only reviews PRs on the default branch. If you wish to have PRs reviewed on additional branches, you can configure that under the repository settings in the UI.

@itsdevbear itsdevbear closed this Nov 5, 2023
Sign up for free to subscribe to this conversation on GitHub. Already have an account? Sign in.
Labels
None yet
Projects
None yet
Development

Successfully merging this pull request may close these issues.

1 participant