From f000e37bc0ab62cc359c153a3a424fe72901e326 Mon Sep 17 00:00:00 2001 From: lightclient Date: Tue, 26 Sep 2023 17:12:30 -0600 Subject: [PATCH] 4788: update ring buffer size rationale for new ring buffer size --- EIPS/eip-4788.md | 6 +++--- 1 file changed, 3 insertions(+), 3 deletions(-) diff --git a/EIPS/eip-4788.md b/EIPS/eip-4788.md index 25f8b0f19d7612..cdb4ba5a183b4e 100644 --- a/EIPS/eip-4788.md +++ b/EIPS/eip-4788.md @@ -275,9 +275,9 @@ to store a pair of values necessitates two ring buffers, rather than just one. ### Size of ring buffers -The ring buffer data structures are sized to hold 8192 roots from the consensus layer at current slot timings (`SECONDS_PER_SLOT` is 12 seconds on mainnet, and `8192 * 12 == 98304`). -At mainnet values, 8192 roots provides about a day of coverage of the chain which gives users plenty of time to make a transaction with a verification against a given root in -the chain and get the transaction included. +The ring buffer data structures are sized to hold 8191 roots from the consensus layer. Using a prime number as the ring buffer size ensures that no value is overwritten until the entire ring buffer has been saturated and thereafter, each value will be updated once per iteration. This also means that even if the slot times were to change, we would continue to use at most 8191 storage slots. + +Given the current mainnet values, 8191 roots provides about a day of coverage. This gives users plenty of time to make a transaction with a verification against a specific root and get the transaction included on-chain. ## Backwards Compatibility