What is this EIP about?
EIP-7840 proposes adding a blobSchedule
object to Ethereum client configuration files to define the target and maximum blob counts per block for each network fork.
It aims to provide a dynamic and straightforward way to adjust blob limits for forks without relying on constant updates via APIs.
Problem: Managing these blob limits solely on the consensus layer or through frequent communication with the execution layer is inefficient and complex.
Why is this EIP needed?
Currently, execution clients depend on blob configuration data (like max
counts) for features like the eth_feeHistory
RPC method. Storing this data only in the consensus client makes frequent updates cumbersome and requires additional API calls between clients for each block.
This EIP addresses performance optimization within Ethereum's client architecture by offloading the need for execution and consensus layers to perform excessive data handshakes. It improves client efficiency by statically defining fork-specific limits in configuration files.
What does this EIP propose, and how does it function?
The EIP introduces a blobSchedule
configuration object that includes target
and max
blob counts for each fork. The object is defined as:
"blobSchedule": {
"cancun": {
"target": 3,
"max": 6
},
"prague": {
"target": 6,
"max": 9
}
}
If a fork does not explicitly specify limits, the values from the last fork are used. If no values exist, both are set to zero.
How it functions:
- Adds a simple, per-fork configuration to execution client files.
- Reduces the need for frequent client communication over APIs by directly referencing configuration files for blob limits.
data:image/s3,"s3://crabby-images/26f1b/26f1b1a78cbf26b34af1cc64e8d0787bc02005a0" alt=""%20(1).png)
What are the security implications of this EIP?
- Potential risks: Misconfigured or outdated client files could result in incorrect blob limits for execution clients.
- Mitigation measures: This can be minimized by ensuring that client files are properly updated during forks. The static configuration model reduces runtime errors compared to dynamic APIs, and fallbacks prevent undefined states.