Hybrid Data Availability: Enforcing BitVM Withdrawals on BOB

2/10/2025, 12:44:06 PM
BOB is creating a hybrid solution that lets users withdraw assets via Bitcoin transactions without relying on Ethereum. It uses Ethereum for data availability and Bitcoin for censorship resistance. Users store withdrawal data in Bitcoin’s Taproot outputs and complete transactions with a two-phase commit/reveal process.

Bitcoin users should only need BTC on Bitcoin to force a withdrawal of their BTC from BOB back to Bitcoin. We are working on a hybrid solution: defaulting to Ethereum as DA while allowing users to force include transactions on BOB via a special transaction on Bitcoin. We are excited to share our work in progress in this blog post.

tl;dr

  • L2s should have the same censorship resistance as the L1s they are based on
  • On BOB, users can already force withdraw their assets from BOB to Ethereum via an Ethereum transaction
  • For its BitVM bridge, BOB is working on integrating Bitcoin as a way for users to enforce transactions on BOB
  • Bitcoin users will be able to withdraw their BTC from BOB without having to send a transaction to BOB

One of the core properties of L2s is that their state needs to progress even when the sequencer is offline. L2s achieve this by reading and writing their state from a Data Availability (DA) layer that can be updated independently of the L2 being online. This way, users can force the inclusion of their transactions even when the sequencer is offline, or the sequencer does not accept their transactions directly.

For BOB’s BitVM bridge, this poses an interesting problem. BOB currently uses Ethereum EIP-4844 blobs as its DA layer. Users on Ethereum can easily trigger withdrawals back to Bitcoin via the BitVM bridge. However, it requires users to have ETH on Ethereum.

This is not good enough for us: Bitcoin users should only need BTC on Bitcoin to force a withdrawal of their BTC from BOB back to Bitcoin. We are working on a hybrid solution: defaulting to Ethereum as DA while allowing users to force include transactions on BOB via a special transaction on Bitcoin. We are excited to share our work in progress in this blog post.

A Background on DA and Derivation

The process of derivation is quite important for L2s: the entire L2 state of BOB needs to be constructed from the L1 and the DA layer. It allows L2s to enjoy the same censorship resistance as the DA layer, in our case, Ethereum.

Simplified, in rollups (specifically OP Stack chains), we have two types of data on the L1:

  • Deposit transactions made to the “OptimismPortal” contract. These are the transactions that are made by users on Ethereum typically to deposit their assets into BOB. These deposit transactions can also be used to execute other transactions on BOB.
  • Batches submitted by the sequencer (or op-batcher to be more precise) from L2 transactions. These include all transactions made directly by users on BOB and are eventually included back to Ethereum blobs.

Bitcoin as DA Layer

If we want Bitcoin as a DA layer, why not fully switch to using Bitcoin completely as a DA layer? The answer is mostly cost. Bitcoin has very little storage available (about 4MB roughly every 10 minutes), and thus, storage cost is high.

However, in our case, BOB can still use Ethereum as its “main” DA layer where it posts its entire transaction data, but add Bitcoin as a highly censorship-resistant fallback layer if Ethereum DA is unavailable. Essentially, Ethereum becomes the optimistic DA layer while Bitcoin becomes the expensive but fault-tolerant last resort.

Hybrid Derivation Pipeline

The basic solution is to add Bitcoin to BOB as a part of the derivation pipeline, such that BOB (and specifically the “op-node”) processes inputs in this order:

  1. Bitcoin forced withdrawal transactions (newly added specifically for BOB)
  2. Ethereum deposits to BOB’s OptimismPortal contract (OP Stack standard)
  3. Ethereum batches from op-batcher (OP Stack standard)

Let’s jump into a possible solution to encode the Bitcoin-forced withdrawal transactions into the BOB derivation pipeline. Note that this is still being researched, so changes are possible.

Bitcoin Forced Withdrawal Transactions

We will need three parts to create a forced withdrawal transaction:

  1. Construct the forced withdrawal transaction on Bitcoin.
  2. Store the forced withdrawal transaction on Bitcoin within the size limits of Bitcoin.
  3. Handle gas costs for the forced withdrawal transaction on Bitcoin.

1. Construct the Forced Withdrawal Transaction

An OP stack deposit transaction has the following structure:

  • bytes32 sourceHash: the source-hash, uniquely identifies the origin of the deposit.
  • address from: The address of the sender account.
  • address to: The address of the recipient account, or the null (zero-length) address if the deposited transaction is a contract creation.
  • uint256 mint: The ETH value to mint on L2.
  • uint256 value: The ETH value to send to the recipient account.
  • uint64 gas: The gas limit for the L2 transaction.
  • bool isSystemTx: If true, the transaction does not interact with the L2 block gas pool.
  • bytes data: The calldata.

A forced withdrawal transaction requires including the encoded withdrawal transaction in the data field of the deposit transaction. This is done by creating the transaction on BOB that triggers the withdrawal from BOB to Bitcoin and would work exactly the same as if the transaction was sent from Ethereum.

We can then store a (compressed) version of the forced withdrawal transaction on Bitcoin that includes all the above data.

2. Store the Forced Withdrawal Transaction on Bitcoin

As the data for the forced withdrawal transaction is larger than what typically should be stored in an OP_RETURN output, we will likely use a Taproot output to store the data.

While it’s easy to identify a deposit transaction (that may include a withdrawal) on Ethereum due to it being sent to BOB’s OptimismPortal contract, it’s not as easy to identify a forced withdrawal transaction on Bitcoin.

Data Serialization: The forced withdrawal transaction is serialized using Taproot scripts within an “envelope” structure. These are noops on the Bitcoin network and are used, e.g., for Ordinals as well. We adjust the structure to fit our needs.

Unset
OP_FALSE OP_IF
OP_PUSH “bob”
OP_1
OP_PUSH “transaction”
OP_0
OP_PUSH $WITHDRAWAL_TRANSACTION_DATA
OP_ENDIF
Two-Phase Commit/Reveal Scheme:
As with Ordinals, users will have to submit two transactions to Bitcoin:

  • Commit Transaction: Creates a Taproot output committing to the script containing the inscription content. This transaction does not yet reveal the data and we’ll need the second transaction for BOB full nodes and sequencers to include the withdrawal transaction.
  • Reveal Transaction: Spends the output from the commit transaction, revealing the inscription on-chain, i.e., revealing the user’s withdrawal transaction for inclusion in BOB.

3. Handle Gas Costs for the Forced Withdrawal Transaction

This is the most open problem yet, with two options currently under consideration:

  • Set gas to 0 for the forced withdrawal transaction on Bitcoin and deduct the gas costs from the user’s ETH balance on BOB. That way, only users who have ETH on BOB can force withdrawals. However, this is not a good option as it would require users to have ETH on BOB to force withdrawals, i.e., users that have BTC on Bitcoin cannot force withdrawals.
  • Gas is paid by users in BTC on Bitcoin. The BOB network would need to have an address on Bitcoin that can receive BTC and would effectively exchange the BTC received by the user to ETH on BOB to pay for the L1 part of the gas costs plus execution costs. This option is likely by using BOB Gateway and setting the BOB DAO’s EVM address as the BTC recipient.

We are also experimenting with more ideas, so stay tuned for more updates!

Putting it all Together

Anyone can determine the state of BOB by only having to check the data on Bitcoin and Ethereum:

  1. Read all withdrawal transactions from Bitcoin. These are encoded as two transactions for each withdrawal, i.e., one commit and one reveal transaction. This is the addition we are making to the OP Stack and where we enhance the derivation pipeline.
  2. Read all transactions made to BOB’s OptimismPortal contract on Ethereum. This is already part of the standard OP Stack derivation pipeline.
  3. Read all transactions made directly on BOB and integrated as part of batches on Ethereum. Importantly, full nodes don’t read directly from the sequencer to receive confirmed transactions but they read from Ethereum blobs. This is already part of the standard OP Stack derivation pipeline.

Technical Challenges

Data Consistency: While ensuring data consistency between Ethereum and Bitcoin chains is important, the mere presence of transaction data on both chains does not guarantee validity. Transactions must represent valid state transitions according to the rollup’s state transition function to be considered legitimate. The solution requires implementing validation logic inside op-node (or other consensus layer implementations) that first verifies if a transaction results in a valid state change before accepting it.

Fraud Proofs and Validity: The fraud proof system for both BitVM and Ethereum need to be enhanced to handle data from both chains, which could make dispute resolution more complex. To address this, we need to accurately account the possible transactions from Bitcoin and Ethereum as part of the BitVM bridge and BOB’s settlement on Ethereum.

Storage Increase: Additionally, BOB nodes in the network face increased storage and bandwidth requirements since they need to process and store data from Bitcoin and Ethereum. However, we could mitigate this by requiring that BOB transactions made on Bitcoin need to be included in Ethereum blobs with a reference to the latest Bitcoin blocks. That way, nodes need only synchronize recent Bitcoin blocks.

Next Steps

We are excited to push the frontier of hybrid rollups combining Bitcoin’s security with Ethereum’s innovation. In this concrete problem, we are interested in having Bitcoin’s censorship resistance of transactions combined with BOB’s rollup stack. We will update this blog post with more information as we make progress.

Disclaimer:

  1. This article is reprinted from [BOB]. All copyrights belong to the original author [Dominik Harz]. 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 investment advice.
  3. The Gate Learn team translated the article into other languages. Copying, distributing, or plagiarizing the translated articles is prohibited unless mentioned.
* The information is not intended to be and does not constitute financial advice or any other recommendation of any sort offered or endorsed by Gate.
* This article may not be reproduced, transmitted or copied without referencing Gate. Contravention is an infringement of Copyright Act and may be subject to legal action.

Share

Crypto Calendar
Tokenların Kilidini Aç
Grass, 28 Ekim'de mevcut dolaşım arzının yaklaşık %74,21'ini oluşturan 181.000.000 GRASS tokeni açığa çıkaracak.
GRASS
-5.91%
2025-10-27
Ana Ağ v.2.0 Lansmanı
DuckChain Token, Ekim ayında ana ağ v.2.0'ı başlatacak.
DUCK
-8.39%
2025-10-27
StVaults Lansmanı
Lido, Lido v.3.0 güncellemesinin bir parçası olarak stVaults'ın Ekim ayında ana ağda kullanılmaya başlayacağını duyurdu. Bu arada, kullanıcılar testnet'te özellikleri keşfedebilirler. Yayın, yeni modüler kasa mimarisi aracılığıyla Ethereum staking altyapısını geliştirmeyi amaçlıyor.
LDO
-5.66%
2025-10-27
MA
Sidus, Ekim ayında bir AMA düzenleyecek.
SIDUS
-4.2%
2025-10-27
Forte Ağı Yükseltmesi
Flow, Ekim ayında başlayacak Forte yükseltmesini duyurdu. Bu yükseltme, geliştirici deneyimini iyileştirmek ve AI ile tüketiciye hazır on-chain uygulamalarını mümkün kılmak için araçlar ve performans iyileştirmeleri sunacak. Güncelleme, Cadence diline yönelik yeni özellikler, yeniden kullanılabilir bileşenler için bir kütüphane, protokol iyileştirmeleri ve rafine tokenomi içermektedir. Flow'daki mevcut ve yeni geliştiriciler, en son yetenekleri kullanarak uygulamalar ve yükseltmeler yayınlayacak. Ek detaylar, ETHGlobal hackathonu öncesinde 14 Ağustos'ta Pragma New York'ta paylaşılacak.
FLOW
-2.81%
2025-10-27
sign up guide logosign up guide logo
sign up guide content imgsign up guide content img
Start Now
Sign up and get a
$100
Voucher!
Create Account

Related Articles

In-depth Explanation of Yala: Building a Modular DeFi Yield Aggregator with $YU Stablecoin as a Medium
Beginner

In-depth Explanation of Yala: Building a Modular DeFi Yield Aggregator with $YU Stablecoin as a Medium

Yala inherits the security and decentralization of Bitcoin while using a modular protocol framework with the $YU stablecoin as a medium of exchange and store of value. It seamlessly connects Bitcoin with major ecosystems, allowing Bitcoin holders to earn yield from various DeFi protocols.
11/29/2024, 10:10:11 AM
BTC and Projects in The BRC-20 Ecosystem
Beginner

BTC and Projects in The BRC-20 Ecosystem

This article introduces BTC ecological related projects in detail.
1/25/2024, 7:37:36 AM
What Is a Cold Wallet?
Beginner

What Is a Cold Wallet?

A quick overview of what a Cold Wallet is, taking into account its different types and advantages
1/9/2023, 10:43:03 AM
Blockchain Profitability & Issuance - Does It Matter?
Intermediate

Blockchain Profitability & Issuance - Does It Matter?

In the field of blockchain investment, the profitability of PoW (Proof of Work) and PoS (Proof of Stake) blockchains has always been a topic of significant interest. Crypto influencer Donovan has written an article exploring the profitability models of these blockchains, particularly focusing on the differences between Ethereum and Solana, and analyzing whether blockchain profitability should be a key concern for investors.
6/17/2024, 3:14:00 PM
Notcoin & UXLINK: On-chain Data Comparison
Advanced

Notcoin & UXLINK: On-chain Data Comparison

In this article, Portal Ventures introduces Bitcoin's history of innovation and controversy, the latest initiatives, and Portal's argument for making Bitcoin more "capital efficient" rather than "programmable."
6/12/2024, 1:46:49 AM
What is the Altcoin Season Index?
Intermediate

What is the Altcoin Season Index?

The altcoin season index is a tool that signifies when the altcoin season starts. When traders can interpret the data, it helps them know when to buy altcoins for profit.
8/16/2023, 3:45:13 PM