Exploring Eclipse's Canonical Ethereum Bridge and Proving System

3/6/2024, 2:06:34 PM
中级
区块链
This article primarily introduces Eclipse's canonical bridge and anti-fraud design, as well as the upcoming release of a monorepo that will contain the canonical bridge smart contracts, relayers, and Docker containers for running local development test networks. Eclipse is Ethereum's fastest Layer 2, powered by the Solana Virtual Machine (SVM). Eclipse combines the best parts of a modular stack: Ethereum as the settlement layer for our cherished verification bridge, Celestia as the data availability layer, RISC Zero for generating our zero-knowledge fraud proofs, and Solana's SVM as the execution environment.

*Forward the Original Title:Exploring Eclipse’s Canonical Ethereum Bridge and Proving System

An Overview of Our Canonical Bridge

Eclipse is composed of three layers:

  1. Execution: A fork of the Solana Labs client (v1.17) for SVM transaction execution
  2. Settlement: Our canonical bridge defining Eclipse’s fork-choice rule exists on Ethereum, where fraud proofs will also be submitted
  3. Data Availability: Eclipse publishes the data necessary to produce fraud proofs as data blobs on Celestia

The diagram below illustrates how these modules interact:

The rest of this article will focus on Eclipse’s Ethereum bridge, as shown in the diagram. Blobstream will relay attestations signed by Celestia’s validator set to certify to Ethereum that the data for a batch of Eclipse’s slots was published correctly. This allows Eclipse’s bridge to verify the data provided for fraud proofs against the signed data roots from Celestia. In the rest of this section, we will outline the processes by which:

  1. funds are deposited via our bridge,
  2. data blobs of batches of Eclipse’s blocks are posted on Celestia,
  3. withdrawals via the bridge are handled, and
  4. fraud proofs are generated in worst-case scenarios.

Depositing via Eclipse’s Native Ethereum Bridge

The flow when a user deposits onto Eclipse via the native Ethereum bridge is summarized as follows:

  1. A user calls Eclipse’s Deposit Bridge contract on Ethereum
  2. From within Eclipse’s SVM executor [1], the relayer [2] observes the user’s deposit and destination address
  3. Next, the relayer calls the SVM bridge program, which is responsible for transferring a user’s deposit to the applicable destination address
  4. The relayer verifies the deposit transaction via a zk-light client (to be implemented)
  5. Finally, the block containing the subsequent post-deposit transfer transaction is finalized and published via a Solana Geyser Plugin

The diagram below shows the interactions between Ethereum, Celestia, and the SVM Executor during the deposit flow described above:

Publishing Eclipse’s Slots to Celestia as Data Blobs

The flow for publishing batches of Eclipse’s slots to Celestia as data blobs is summarized below:

  1. The SVM executor publishes each Eclipse slot to the message queue via Geyser
  2. The SVM executor posts batches of Eclipse’s slots to Celestia as data blobs
  3. The Celestia validator set produces commitments to the data blobs submitted, which can be used to prove the inclusion of a transaction on Eclipse’s chain against the data root
  4. The data roots contained in every single Celestia block header are relayed to Eclipse’s bridge contract on Ethereum via Blobstream

The diagram below from Celestia explains how the commitment of the data within a given Celestia block is stored in the block header:

Withdrawing and Submitting Fraud Proofs to Eclipse’s Ethereum Bridge

Similarly to other L2s that use fraud proofs (Arbitrum, Fuel, and many others), withdrawals from Eclipse require a challenge period during which verifiers can submit fraud proofs in the case of an invalid state transition:

  1. At a regular cadence, the SVM executor posts a commitment to an epoch (a predetermined number of batches) of Eclipse’s slots to Ethereum, along with collateral
  2. Eclipse’s bridge contract conducts some basic checks to ensure that the data posted is well-formed (described in the Fraud Proof Design section)
  3. If the submitted batch passes these basic checks, there is a predefined window during which verifiers can post fraud proofs in the case that the batch commitment implies an invalid state transition
  4. If a verifier posts a successful fraud proof, they win the executor’s collateral, the posted batch is rejected, and the canonical state of the Eclipse L2 is rolled back to the last valid batch commitment. Here, Eclipse’s governance would have the ability to elect a new executor
  5. If the challenge period elapses with no successful fraud proof, the executor recovers its collateral along with a reward
  6. Consequently, the Eclipse bridge contract will now complete any withdrawal transactions that were included in the finalized batch

Fraud Proof Design

In this final section, we will detail Eclipse’s fraud proof system design, inspired by Anatoly Yakovenko and John Adler. Generally, for any fraud proof, a verifier must:

  1. Identify a transaction containing an invalid state transition
  2. Provide the inputs to said transaction with the invalid state transition
  3. Demonstrate that re-executing said transaction with the given inputs results in an output that is not equal to what was committed on-chain

In Eclipse’s case, (1) Celestia merklizes blobs of batches of blocks that Eclipse’s SVM executor posts, allowing transaction inclusion proofs via Merkle witnesses. For (2), unlike EVM-based L2s, which post a Merkle root to the global state tree, for performance reasons Eclipse does not update a global state tree on a transaction-by-transaction basis, but we will explain how we ensure the correctness of inputs in more detail below. Finally, in the case of (3), Eclipse’s verifier generates a zk-proof of the output(s) for a given transaction, unlike the interactive verification game approach common across EVM-based L2s.

All Eclipse transactions can be represented as taking a list of input accounts, executing a transaction, and producing a list of resultant output accounts:

The critical observation for our fraud proof design is that for transaction execution, it is always the case that any S_InputAccount must have been the S_OutputAccount of some previous transaction. This allows us to reference the last transaction in the chain that produced a given input account instead of providing a Merkle witness to a global state tree. As a result of our design, we introduce additional fraud accusation types, such as a reference to the previous transaction not being valid or the input account already being “spent” by some later transaction. We describe this process in more detail below:

Transaction Inputs Posted to Celestia

  1. Transaction data (posted by the sequencer)
  2. Transaction data (posted by the SVM executor) which contains the following:
    1. Transaction count [3]
    2. Celestia namespace location of the transaction data
    3. Account hash [4] for each input, with transaction count resulting in each
    4. List of sysvars used and value of each, with transaction count resulting in each (if applicable) [5]
    5. Transaction output, if the transaction was successful; otherwise, an indicator that the transaction failed (either because it failed to parse or because it was unable to execute)

Batch Commitments Posted to The Ethereum Bridge

In addition, the batches of transaction data posted to Celestia have their commitments relayed to the Ethereum contract. The commitments consist of:

  1. The Celestia namespace location of the transaction data of the last transaction included in the batch
  2. The Celestia namespace location of the execution data [6] of all included transactions
  3. A list of deposits, withdrawals, and overrides, each of which comes with the transaction count of the associated Eclipse transaction

Criteria for an Invalid Batch

As explained above, there are several ways a batch can be found to be incorrect:

  1. One of the linked Celestia namespace locations is malformed or does not point to data of the required type
  2. There is a transaction on Celestia with no associated execution data, which can be due to two reasons:
    1. The transaction, which was supposed to be the most recent in the batch, has no associated execution data.
      1. In such a case, a verifier verifies that this is the case and the Ethereum bridge contract checks that the latest entry in the execution data list does not correspond to the correct transaction data
    2. The execution data of a different transaction is missing
      1. A verifier posts the Celestia namespace location of the transaction data of the offending transaction and the previous and following transactions in the order that was successfully executed. Following this, the bridge contract checks that this transaction was skipped
  3. There is a transaction whose execution data is incorrect, which could be caused by the following:
    1. The transaction count associated with an account hash or sysvar does not produce the claimed output.
      1. In this case, a verifier posts the Celestia namespace location of the execution data for the given transaction with the corresponding count, and the bridge contract checks that the given value is incorrect.
    2. The transaction count associated with an account hash or sysvar is outdated
      1. A verifier posts the Celestia namespace location of the execution data for a newer transaction, modifying the value in question, and the bridge contract checks that this is indeed newer.
    3. The transaction output is incorrect, or the transaction uses an input that is not listed:
      1. In this case, a zk-proof of the correct execution of the transaction or a zk-proof that the transaction uses an input that is not listed is needed. This can be obtained in two ways:
        1. A verifier posts the proof, or
        2. A verifier posts the index of the transaction claimed to be fraudulent, and the Eclipse bridge contract uses this to solicit a zk-proof from RISC Zero’s Bonsai
    4. There was a deposit from Ethereum more than N batches ago, but there is no corresponding deposit in the transaction list (included in the batch commitment posted to the bridge contract) for the N past batches. Alternatively, there is a deposit in the transaction list with no related Ethereum deposit transaction, or the transaction exists but has already been included in another Eclipse batch
      1. The bridge contract in all of these cases can determine that this has happened and regard such a batch as invalid
    5. There is a deposit or withdrawal executed with no corresponding entry in the transaction list
      1. In such a case, a verifier posts the Celestia namespace location of the given execution data, and the bridge contract checks this fact to judge the transaction as invalid
    6. There is a deposit or withdrawal in the transaction list whose associated Eclipse transaction is not performing the expected action or whose transaction count is not within its expected transaction count range. In such a case, either one of the following would happen:
      1. The bridge would automatically determine this is the case and refuse the corresponding batch
      2. A verifier notices the invalid state transition and posts proof of the offending transaction, which is then verified by the bridge contract

If any commitment batch is found to be incorrect, the Eclipse bridge contract will roll back the bridge to that of the last provably correct batch commitment. Note that transactions are never removed from the chain, even in the case of fraud, so only the commitment needs to be re-computed.

Parting Thoughts

This article aimed to give a high-level guide to Eclipse’s trust-minimized bridge on Ethereum and explain some details about our fraud proof design. Given the modular nature of our L2 and the nascence of our technology stack, we will continue to release articles and documentation about various aspects of Eclipse in the coming weeks.

To get involved with Eclipse Testnet, please follow our instructions here. You can contact us on Twitter or Discord with specific inquiries about our Testnet, bridge, or technical questions.

Footnotes

[1]: The node which computes the results of SVM transactions and applies the eventual output to Eclipse’s new state

[2]: An operator which passes on-chain events between Ethereum and Eclipse

[3]: Note that the executor, not the sequencer, posts this. If it were included in the data posted by the sequencer, it would add the complication that the sequencer could skip over a count, making it impossible for the executor to do their job correctly. This could be compensated for in the fraud proof design, but it would add extra complexity. A second advantage of having only the executor post the count is that it makes it easy to allow transaction overrides to be posted to Celestia, if desired.

[4]: SVM accounts can be represented with a unique hash. The only way this hash is modified is via a transaction.

[5]: To do this without an excessive amount of hashing, we will run a trace on each executed program to see which parts of each used sysvar are actually accessed. This is possible, but will require modifying Solana’s BPF interpreter.

[6]: This includes data for attempted transactions that failed to execute.

Disclaimer:

  1. This article is reprinted from [[mirror], All copyrights belong to the original author [Eclipse]. If there are objections to this reprint, please contact the Gate Learn team, and they will handle it promptly.
  2. Liability Disclaimer: The views and opinions expressed in this article are solely those of the author and do not constitute any investment advice.
  3. Translations of the article into other languages are done by the Gate Learn team. Unless mentioned, copying, distributing, or plagiarizing the translated articles is prohibited.

分享

币圈日历
代币解锁
Grass 将于10月28日解锁181,000,000 GRASS代币,约占当前流通供应的74.21%。
GRASS
-5.91%
2025-10-27
主网 v.2.0 启动
DuckChain 代币将在十月推出主网 v.2.0。
DUCK
-8.39%
2025-10-27
StVaults 发布
Lido已宣布,stVaults将在10月作为Lido v.3.0升级的一部分上线主网。与此同时,用户可以在测试网上探索这些功能。此次发布旨在通过新的模块化保险库架构增强以太坊质押基础设施。
LDO
-5.66%
2025-10-27
有问必答
Sidus将在十月举行AMA。
SIDUS
-4.2%
2025-10-27
Forte网络升级
Flow宣布Forte升级,计划在十月推出,介绍工具和性能增强,以改善开发者体验并支持消费者就绪的链上应用程序与AI。此更新包括Cadence语言的新功能、可重用组件库、协议改进和精炼的代币经济学。当前和新的Flow开发者将发布利用最新功能的应用和升级。更多细节将在8月14日于Pragma New York在ETHGlobal黑客马拉松之前分享。
FLOW
-2.81%
2025-10-27
sign up guide logosign up guide logo
sign up guide content imgsign up guide content img
即刻开始交易
注册并交易即可获得
$100
和价值
$5500
理财体验金奖励!
立即注册

相关文章

浅谈合并:什么是以太坊2.0?
中级

浅谈合并:什么是以太坊2.0?

一场可能影响整个加密生态的升级
12/14/2022, 3:56:45 AM
全球加密正当时:一览加密监管世界地图
中级

全球加密正当时:一览加密监管世界地图

文章详细探讨不同国家和地区对加密资产的法律地位、监管框架、执照发放以及交易所落地情况,揭示全球加密监管的复杂性和多样性。
7/2/2025, 10:27:07 AM
不可不知的比特币减半及其重要性
新手

不可不知的比特币减半及其重要性

在比特币网络历史上,最令人期待的事件之一就是比特币减半。当矿工验证交易并添加新区块后获得奖励时,就会创建新的比特币。新铸造的比特币就是奖励的来源。比特币减半减少了矿工的奖励,因此新比特币进入流通的速度也减半。人们认为减半事件对网络以及比特币的价格产生了重大影响。 法币何时发行取决于政府的决定,而比特币则不同,其发行上限为21,000,000枚。减半是一种调节比特币产量的方法,同时有助于抑制通货膨胀,因为减半让比特币的铸造无法超过发行量上限。本文将深入研究比特币减半及其重要性。
12/14/2022, 5:48:29 AM
如何选择比特币钱包?
新手

如何选择比特币钱包?

本文将介绍一些最通用的比特币钱包类型,还将研究每种钱包的优缺点,以及它们的功能、安全性和易用性。阅读完本文,您能更好地了解可用的不同类型的比特币钱包,并明白哪一种更适合您。
5/5/2023, 6:02:11 AM
减半、周期与轮回:一部比特币发展史
中级

减半、周期与轮回:一部比特币发展史

探索比特币的减半历史与未来影响,深入了解其在区块链技术与金融领域的创新应用与投资前景。提供独到见解与分析。
4/23/2024, 7:02:29 AM
CKB:闪电网络促新局,落地场景需发力
中级

CKB:闪电网络促新局,落地场景需发力

在最新发布的闪电网络Fiber Network轻皮书中,CKB介绍了其对传统BTC闪电网络的若干技术改进。Fiber实现了资产在通道内直接转移,采用PTLC技术提高隐私性,解决了BTC闪电网络中多跳路径的隐私问题。
9/10/2024, 7:19:58 AM