This Meta EIP documents all the proposals for Glamsterdam related to the gas repricing effort. The goal of this effort is to harmonize gas costs across the EVM, thereby reducing the impact of specific bottlenecks on scaling. Proposals include changes to the cost of single EVM operations, as well as bigger changes to the gas model. This Meta EIP is purely informational and does not aim to have an active role in the governance process for the Glamsterdam fork. Instead, it serves as a directory for all repricing-related proposals, helping to organize the work and keeping the community informed about the status of each EIP.
The main objective of the Glamsterdam fork is to improve L1 scalability. A crucial aspect of this initiative is to create a better alignment between gas costs and actual resource usage. Currently, the gas model often misprices operations, resulting in inefficiencies and unintended incentives. For instance, within the pure compute operations, there is a high variance in execution time per gas unit, which indicates that a single unit of computation is not priced equally across the various opcodes.
By standardizing gas costs across EVM operations and other resources, we can reduce bottlenecks and enhance the utilization of EVM resources, which will subsequently enable further scalability. The EIPs listed below constitute a significant first step in that direction. We expect that further iteration will be necessary in future hardforks.
The following table lists all EIPs related to repricings that are being discussed in the scope of the Glamsterdam fork. There are three types of EIPs in this list:
| EIP | Description | Type | Resource class | Gas change overview |
|---|---|---|---|---|
| EIP-2780 | Decompose the flat intrinsic transaction cost into explicit primitives priced to match the resources a transaction actually consumes. | Broad harmonization | Multi-resource | Decompose flat 21,000 into TX_BASE_COST (12,000) + COLD_ACCOUNT_ACCESS (3,000) + TX_VALUE_COST (4,244) + TRANSFER_LOG_COST (1,756); add STATE_BYTES_PER_NEW_ACCOUNT × CPSB (183,600) state gas to value transfers that create an account |
| EIP-7778 | Prevent Block Gas Limit Circumvention by Excluding Refunds from Block Gas Accounting. | Pricing extension | General Accounting | No opcode repricing; excludes gas refunds (e.g. SSTORE clearing) from block gas accounting |
| EIP-7904 | Empirical analysis of EVM compute operation runtimes (Informational); concludes no compute gas cost needs repricing at the target throughput. | Broad harmonization | Compute | No changes: with EIP-7928 optimizations in place, all examined compute opcodes and precompiles already meet the 100 Mgas/s target at their current cost |
| EIP-7976 | Increase the calldata floor cost to 64/64 gas per byte to reduce maximum block size. | Pricing extension | Data | Increase calldata floor cost (10/40 → 64/64 per byte) |
| EIP-7981 | Price access lists for data to reduce maximum block size. | Pricing extension | Data | Increase: new floor charge on access list data (addresses + storage keys) |
| EIP-8037 | Harmonization, increase and separate metering of state creation gas costs to mitigate state growth and unblock scaling. | Broad harmonization | State | All increase via a fixed CPSB (1,530 gas/byte), metered in a separate state-gas dimension: GAS_CREATE, GAS_CODE_DEPOSIT, GAS_NEW_ACCOUNT, GAS_STORAGE_SET, PER_AUTH_BASE_COST, PER_EMPTY_ACCOUNT_COST |
| EIP-8038 | Increases the gas cost of state-access operations to reflect Ethereum's larger state. | Broad harmonization | State | Increase: STORAGE_WRITE, COLD_STORAGE_ACCESS, COLD_ACCOUNT_ACCESS, ACCOUNT_WRITE, CREATE_ACCESS, access list costs; EXTCODESIZE/EXTCODECOPY extra warm read; WARM_ACCESS unchanged |
| EIP | Description | Type | Resource class |
|---|---|---|---|
| EIP-2926 | Introduce code-chunking in an MPT context. | Pricing extension | State |
| EIP-7686 | Adjust memory limits and gas limits of sub-calls to create a clear linear bound on how much total memory an EVM execution can consume. | Pricing extension | Memory |
| EIP-7923 | Linearize Memory Costing and replace the current quadratic formula with a page-based cost model. | Pricing extension | Memory |
| EIP-7971 | Decrease costs for TLOAD and TSTORE with a transaction-global limit. |
Pricing extension | Memory |
| EIP-7973 | Introduce warm account writes, decreasing the cost of writing to an account after the first write. | Pricing extension | State |
| EIP-8011 | Gas accounting by EVM resource, increasing throughput and improving resource usage controls, with minimal changes to the protocol and UX. | Supporting | NA |
| EIP-8032 | Makes SSTORE gas cost scale with a contract's storage size to discourage state bloat. |
Pricing extension | State |
| EIP-8053 | Adds milli-gas as the EVM's internal gas accounting unit, reducing rounding errors without impacting UX. |
Supporting | NA |
| EIP-8057 | Multi‑block temporal locality discounts for state and account access. | Pricing extension | State |
| EIP-8058 | Reduces gas costs for deploying duplicate contract bytecode via access-list based mechanism. | Pricing extension | State |
| EIP-8059 | Gas parameters and variables are increased to a factor of REBASE_FACTOR to reduce rounding errors without major changes to the EVM. |
Supporting | NA |
The following tables summarize the preliminary gas cost changes. Numbers are not yet finalized and will be subject to change.
EIP-7904 is now Informational and recommends no repricing. Earlier revisions proposed raising the cost of a set of compute opcodes and precompiles, but re-running the benchmark and estimation pipeline against clients that include the parallel-execution optimizations unlocked by EIP-7928 (Block-Level Access Lists) shows those operations now clear the 100 Mgas/s throughput target at their current gas costs. Every compute opcode and precompile examined is therefore left unchanged.
| Opcode(s) | Component | Current | New | Direction |
|---|---|---|---|---|
SSTORE |
STORAGE_WRITE (first-time write surcharge) |
2,800 | 10,000 | increase |
SSTORE, SLOAD |
COLD_STORAGE_ACCESS |
2,100 | 3,000 | increase |
*CALL, BALANCE, EXT*, SELFDESTRUCT |
COLD_ACCOUNT_ACCESS |
2,600 | 3,000 | increase |
*CALL, SELFDESTRUCT, ETH transfers |
ACCOUNT_WRITE (first-time account-leaf write surcharge) |
6,700 | 8,000 | increase |
| All state ops (warm) | WARM_ACCESS |
100 | 100 | unchanged |
CREATE, CREATE2 |
CREATE_ACCESS |
7,000 | 11,000 | increase |
EXTCODESIZE |
Extra warm read for 2nd DB lookup | 0 | +WARM_ACCESS |
increase (new) |
EXTCODECOPY |
Extra warm read for 2nd DB lookup | 0 | +WARM_ACCESS |
increase (new) |
SSTORE, SLOAD (access list) |
ACCESS_LIST_STORAGE_KEY_COST |
1,900 | 3,000 | increase |
*CALL etc. (access list) |
ACCESS_LIST_ADDRESS_COST |
2,400 | 3,000 | increase |
SSTORE |
STORAGE_CLEAR_REFUND |
4,800 | 12,480 | increase (refund) |
EIP-8037 introduces a fixed cost per state byte, CPSB = 1,530 (derived from a 150M reference block gas limit), and meters state creation in a separate state-gas dimension. The new-state byte counts are 120 per account, 64 per storage slot, and 23 per EIP-7702 authorization indicator. The "New state gas" column is charged to the state-gas dimension; the "New regular gas" column accompanies it in regular gas.
| Operation | Opcodes Affected | Current | New state gas | New regular gas | Direction |
|---|---|---|---|---|---|
GAS_CREATE |
CREATE, CREATE2, create txs |
32,000 | 120 × CPSB (183,600) | CREATE_ACCESS |
increase |
GAS_CODE_DEPOSIT |
CREATE, CREATE2, create txs |
200/byte | CPSB/byte (1,530/byte) | 6 × ceil(len/32) (hash) |
increase |
GAS_NEW_ACCOUNT |
CALL* to new accounts, SELFDESTRUCT |
25,000 | 120 × CPSB (183,600) | 0 | increase |
GAS_STORAGE_SET |
SSTORE (0 → non-zero) |
20,000 | 64 × CPSB (97,920) | 0 | increase |
PER_EMPTY_ACCOUNT_COST |
EIP-7702 auth | 25,000 | 120 × CPSB (183,600) | ACCOUNT_WRITE |
increase |
PER_AUTH_BASE_COST |
EIP-7702 auth | 12,500 | 23 × CPSB (35,190) | REGULAR_PER_AUTH_BASE_COST |
increase |
| Parameter | Current | New | Direction | EIP |
|---|---|---|---|---|
| Intrinsic base (plain transfer to existing account) | 21,000 | 21,000, decomposed into TX_BASE_COST (12,000) + COLD_ACCOUNT_ACCESS (3,000) + TX_VALUE_COST (4,244) + TRANSFER_LOG_COST (1,756) |
unchanged (decomposed) | 2780 |
| New-account charge (value transfer creating an account) | 0 | STATE_BYTES_PER_NEW_ACCOUNT × CPSB = 183,600 state gas |
increase (new) | 2780, 8037 |
| Calldata floor cost | 10/40 per byte | 64/64 per byte | increase | 7976 |
| Access list data cost | 0 | floor_token_cost per token |
increase (new) | 7981 |
Discussed in the individual EIPs.
Copyright and related rights waived via CC0.