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

complete gas optimization Report #160

Open
burhankhaja opened this issue Jun 19, 2024 · 2 comments
Open

complete gas optimization Report #160

burhankhaja opened this issue Jun 19, 2024 · 2 comments

Comments

@burhankhaja
Copy link

burhankhaja commented Jun 19, 2024

Hats username: @ghost
Twitter username: @imaybeghost
Discord username: @burhan_khaja
wallet: 0x022df5782baf4ec29BB89529de3c89CdA7AF5B7d

Severity: gas-saving

GAS-1: Avoid having ERC20 token balances go to zero, always keep a small amount

Since we know that 0 - 1 writes cost 22K gas, which is a lot. If an address is frequently emptying (and reloading) it’s account balance, this will lead to a lot of zero to one writes, resulting in crazy amount of gas usage

The way it can be implemented in src/modules/fundingManager/rebasing/abstracts/ElasticReceiptTokenBase_v1.sol
is to add 1 to _accountBits[address] on the first balance increase, what i mean by that is when a user gets his initial _accountBits updated use +1 (as an extra number to prevent 0 - 1 writes) then while withdrawing subtract -1 from his total balance which will accomplish both tasks, preserve the balance solvency and prevent 0 - 1 writes

Instances

GAS-2 : Make constructors Payable

Making the constructor payable saved 200 gas on deployment. This is because non-payable functions have an implicit require(msg.value == 0) inserted in them. Additionally, fewer bytecode at deploy time mean less gas cost due to smaller calldata.

instances

GAS-3 : Admin Functions can be

We can make admin specific functions payable to save gas, because the compiler won’t be checking the callvalue of the function.
This will also make the contract smaller and cheaper to deploy as there will be fewer opcodes in the creation and runtime code.
we could make all functions payable to make our codebase hyper gas efficient but that will cause user fund loss, so that is why it usually good idea to just apply this optimization to priviledged functions assuming higher knowledge.
Instances
The functions using these modifier across the codebase are better options to use this payable modifier on

  • onlyCommunityOrTeamMultisig
  • onlyself
  • onlyModule
  • onlyOrchestratorAdmin
  • onlyModuleRoleAdmin

GAS-4 : Custom errors are cheaper than require statements

Custom errors are cheaper than require statements with strings because of how custom errors are handled. Solidity stores only the first 4 bytes of the hash of the error signature and returns only that. This means during reverting, only 4 bytes needs to be stored in memory. In the case of string messages in require statements, Solidity has to store(in memory) and revert with at least 64 bytes.

Instances

GAS-5: Split require statements that have boolean expressions

When we split require statements, we are essentially saying that each statement must be true for the function to continue executing.
If the first statement evaluates to false, the function will revert immediately and the following require statements will not be examined. This will save the gas cost rather than evaluating the next require statement.

Instances

GAS-6 : Split revert statements

Similar to splitting require statements, you will usually save some gas by not having a boolean operator in the if statement.
Instances

GAS-7 : Timestamps and block numbers in storage do not need to be uint256

A timestamp of size uint48 will work for millions of years into the future. A block number increments once every 12 seconds. This should give you a sense of the size of numbers that are sensible.

Instances

@0xmahdirostami
Copy link

thanks but gas submission is different in hats

Please remember the following instructions: for next competition

Users need to clone the repository, make changes, and then upload it to their private repository.
In their report, they should include the link to their private repository.
After that, they will need to invite sponsors to their private repository.
The winner will be chosen based on the average gas savings in tests.
There are some rules to consider: if any test fails due to changes, the submission is invalid. Additionally, if a user employs assembly, the submission is also invalid.

and read competition scope for more details.

@burhankhaja
Copy link
Author

please, explain this part

Additionally, if a user employs assembly,

Sign up for free to join this conversation on GitHub. Already have an account? Sign in to comment
Projects
None yet
Development

No branches or pull requests

2 participants