Proposal Title: Upgrade 15 - Isthmus Hard Fork
Proposal Type: Protocol Upgrade
This proposal is intended to be voted on in Cycle 35
This proposal is contingent upon the passing of Upgrade Proposal #14
Executive Summary
Hi, I’m Lewej, a Technical Program Manager at OP Labs. I prepared this proposal in collaboration with Sebastian Stammler, Paul Dowman, and Ben Clabby from the OP Labs Team, Aurélien from Succinct, and Julian Meyer from Base.
Neither OP Labs nor I or any other entity mentioned represent or speak on behalf of the Optimism Foundation.
This proposal introduces the Isthmus hard fork. The features to be activated have been shared in preview posts:
- Proposal Preview: L2 Withdrawals Root in Block Header
- Proposal Preview: Operator Fee
- Proposal Preview: Implement Prague features in Isthmus
Motivation
Many of the EIPs in the Pectra hard fork are useful to end users and developers on the Superchain, so including features that enable new account abstraction primitives, make proofs more efficient, and other enhancements are important to release as soon as possible after L1 activation. Other features in the Isthmus hard fork enhance the node operator and dev experiences, especially for those working on Alt-DA & ZK chains.
Impacted Stakeholders & Expected Outcomes
- All node operators: will be required to update node software to a new release once the L1 Pectra activation date is finalized.
- Users and developers: changes are backwards compatible, but this release enables new features like EIP-7702 to be leveraged on the Superchain. Some predeploy APIs are updated, see changelog here.
Specifications
-
Blockspace Charter
- This upgrade does not require any changes to the Standard Rollup Charter beyond those in Upgrade 14, which this builds upon.
-
Technical details
-
Pectra Support
Specs for each EIP are implemented in the specs repo under Isthmus. This spec explains how the protocol should change to adopt Pectra EIPs.
-
Included EIPs:
- EIP-7702: Set code transaction
- Added authorization list to span batch format: specs/specs/protocol/isthmus/derivation.md at main · ethereum-optimism/specs · GitHub
- EIP-2537: BLS12-381 precompiles
- Added input limits and specify acceleration: specs/specs/protocol/isthmus/exec-engine.md at a795bb1f8c34410c47f05d4c3614482361db64b1 · ethereum-optimism/specs · GitHub
- EIP-2935: Block hashes contract predeploy
- Added network upgrade transaction: specs/specs/protocol/isthmus/derivation.md at a795bb1f8c34410c47f05d4c3614482361db64b1 · ethereum-optimism/specs · GitHub
- EIP-7251: Increase the MAX_EFFECTIVE_BALANCE
- Only affects execution clients
- EIP-7623: Increase calldata cost
- Only affects execution clients
- EIP-7002: Execution layer triggerable withdrawals
- Not applicable to OP
- Requests sent to this contract are ignored, and the contract is not deployed by default
- EIP-6110: Supply validator deposits on chain
- Not applicable to OP
- Requests sent to this contract are ignored, and the contract is not deployed by default
- EIP-7685: General purpose execution layer requests
- No requests are currently applicable to OP, so the execution requests array is always empty in Isthmus.
Security Considerations
The new BLS precompiles are accelerated in the fault proof program so that they can be executed within the time limit of a dispute game. Unlike their specification in EIP-2537 they have input size limits to limit the amount of gas used to fit within fault proof constraints. This is similar to the bn256Pairing precompile in the granite hardfork .
Links to Specs
- L1 devnet-6 EIP list (latest): https://notes.ethereum.org/@ethpandaops/pectra-devnet-6
- Isthmus upgrade spec: specs/specs/protocol/isthmus/overview.md at main · ethereum-optimism/specs · GitHub
- Pectra support on Isthmus project: ethereum-optimism/pm#23
- EIP-7702: Set code transaction
-
-
Operator Fee
We propose the addition of 2 new rollup operator configured scalars, collectively named the Operator Fee Parameters. These scalars are named
operatorFeeScalar
andoperatorFeeConstant
, and they factor in the fee calculation as follows:operatorFee = operatorFeeConstant + operatorFeeScalar * gasUsed / 1e6 totalFee = operatorFee + gasUsed * (baseFee + priorityFee) + l1Fee
These scalars will be updated via the SystemConfig L1 contract. A new fee vault, the OperatorFeeVault, is added to store the operator fee.
Upgrade 14 already prepares the SystemConfig with support for setting the operator fee parameters. So this proposal doesn’t include an upgrade of the SystemConfig contract.
This feature has the potential to adjust the collective fee take requirements in the standard rollup charter. However, the standard rollup configuration requirements are not being updated as a part of this proposal. For all standard OP Stack chains participating in the Superchain, both the
operatorFeeConstant
andoperatorFeeScalar
are required to be configured to0
, effectively deactivating the feature. In a future proposal, governance may approve the activation of this feature on standard OP Stack chains alongside an update to the standard rollup configuration requirements.Resources
-
L2 Withdrawals Root in Block Header
The storage root of the
L2ToL1MessagePasser
contract is added to the block header at thewithdrawalsRoot
field, starting with Isthmus activation. This makes it easier for chain participants to inspect or post the correct output root proposals, since they don’t need to run an archival node any more, but have the info readily available in the block header, which any full node can provide.More implementation details can be found in the proposal review of this feature.
Resources
- The official specification can be found at specs/specs/protocol/holocene/exec-engine.md at 7dcaffd4a30c2b77cb419da30848e331e6c3793d · ethereum-optimism/specs · GitHub.
- FMA PR
-
-
Impact Summaries
-
Pectra Support
Implementing Pectra features in Isthmus will make the next hardfork require upgrades to certain key components.
- The
op-challenger
preimage will need to be upgraded to support new accelerated precompiles and new transaction types proxyd
needs to be updated to handle set code transactions- Span batch format is updated to include the new tx type
All of the typical components that need to be upgraded during a hardfork also need to be upgraded.
- The
-
Operator Fee
This proposal is planned to be included in Isthmus, but the feature is disabled by default. In order to be able to set the
operatorFeeScalar
andoperatorFeeConstant
parameters, theSystemConfig
contract must be upgraded. This upgrade will already have happened with Upgrade 14. -
L2 Withdrawals Root in Block Header
- The OP Stack Specs provides a comprehensive overview of the impact
- Performance changes
- Reduces the requirement to access withdrawals root, which benefits the OP Stack.
- Only performance hit is specifying the withdrawals root during block building which is a very low cost account lookup per block.
-
-
Precommitment impact review:
This Upgrade Proposal only impacts the Collective Fee Take precommitment in the Standard Rollup Charter.
- Collective Fee Take: while the operator fee’s offchain codepath is included in this release, it is still required to be set to 0 for standard chains and thus does not impact the fee take today. However, this upgrade paves the way for the fee calculations to be updated in the future to account for additional costs, e.g. ZK proving.
- Governor/Servicer Role Separation: no change to role structures or authorization patterns.
- Ossified GasLimits: no changes to ossified gasLimits
- Direct Fee Margin Controls: no change to the relevant configuration structure and authorization.
Action Plan
While this upgrade encompasses all code changes required to update to this new version of the OP Stack, one dependency is missing: the L1 Pectra activation date, which at the time of posting is not finalized. To deploy this upgrade, the L1 Pectra activation date needs to be known.
As such, a full action plan for this proposal is not prepared. Instead, we anticipate submitting a subsequent Maintenance Upgrade as a fast follow to this one, which sets the activation date and:
- Commits to a concrete payload which the Security Council can sign
- Tags the correct releases for off-chain software, inclusive of activation date, including:
- op-node
- op-geth
- op-challenger
- op-batcher
Since none of the above changes affect L1 contract implementations, this maintenance upgrade will also not need a new OPCM beyond the one for Upgrade 14.
Conclusion
This proposal outlines the features to be introduced with the Isthmus hard fork. These are key to maintaining parity with L1 and provide the best experience to users and developers of the Superchain that we can. We look forward to your support in implementing these features with your positive votes.