Skip to content
New issue

Have a question about this project? Sign up for a free GitHub account to open an issue and contact its maintainers and the community.

By clicking “Sign up for GitHub”, you agree to our terms of service and privacy statement. We’ll occasionally send you account related emails.

Already on GitHub? Sign in to your account

Optimize EstimateGas API #391

Closed
wants to merge 107 commits into from
Closed

Optimize EstimateGas API #391

wants to merge 107 commits into from

Conversation

trinhdn2
Copy link

@trinhdn2 trinhdn2 commented Oct 9, 2023

Resolve issue #390

EstimateGas repeatedly executes a transaction, performing a binary search with multiple gas prices to determine proper pricing. Each call retrieves a new copy of the state https://github.com/tomochain/tomochain/blob/76420ee3ba79120351018b86c1a84c4001ad9064/internal/ethapi/api.go#L1136
Because the pending/latest state can be changed during the execution of EstimateGas, this can potentially cause strange behaviors. EstimateGas currently conducts a binary search to determine a suitable gas limit for a tx, and continues searching with a higher gas limit whenever the transaction's execution results in revert. While this makes sense if the reason for revert is out of gas, increasing the gas limit is highly unlikely to allow a non-OOG reverting transaction to succeed (unless it is making unusual use of the GAS opcode).

This PR modifies EstimateGas to retrieve the state once and use a copy of it for every call invocation it does. This has two benefits:

  • Saves compute overhead.
  • Eliminates a race condition where a reverting transaction causes the gas limit lowerbound to increase repeatedly during gas estimation, only for a state change to allow the transaction to later succeed later in the loop, resulting in an unreasonably high estimate being returned. (We believe this is happening in practice in one of our applications)

trinhdn97 and others added 30 commits June 16, 2023 14:30
@trinhdn2 trinhdn2 marked this pull request as ready for review October 10, 2023 09:41
@trinhdn2
Copy link
Author

trinhdn2 commented Dec 9, 2023

Superseded by #409

@trinhdn2 trinhdn2 closed this Dec 9, 2023
Sign up for free to join this conversation on GitHub. Already have an account? Sign in to comment
Labels
None yet
Projects
None yet
Development

Successfully merging this pull request may close these issues.

5 participants