Bitcoin developer Peter Todd this week argued against integrating Zcash-style privacy features into Bitcoin's base layer, warning that the cryptographic risk is far higher than what Bitcoin's system can safely handle. The debate was sparked by a recent bug disclosure from ZODL developers affecting Zcash's Orchard shielded pool. Todd said that while Bitcoin has historically handled visible bugs with rollbacks, shielded systems introduce risks that are harder to detect and reverse.
A bug reignites a privacy debate
ZODL developers disclosed an issue affecting the Zcash Orchard shielded pool during routine auditing, prompting fresh discussion about whether Bitcoin should adopt similar privacy tech. Todd responded by arguing that adding Zcash-style cryptography to Bitcoin's consensus layer would be a mistake. He emphasized that even though Bitcoin has survived bugs before, the nature of shielded transactions makes problems much harder to observe and fix.
Rollbacks and risk profiles
Todd noted that rolling back the Bitcoin chain is feasible for visible bugs, as only a small subset of coins were affected in past incidents. He cited the 2010 value overflow bug and the 2018 bug CVE-2018-17144, saying neither had a chance of destroying the currency. But with shielded systems, damage may be harder to attribute and reverse compared to transparent accounting. “Zcash-style cryptography has much higher risk than Bitcoin's, reflected in more serious issues in Zcash,” Todd said, paraphrasing his view.
Zcash defenders point to the turnstile
Defenders of Zcash pushed back, arguing that a 'turnstile construct' prevents bugs from affecting the total ZEC supply. That means even if a shielded pool is compromised, the overall supply remains capped. Todd countered that 30% of Zcash supply is shielded, and destruction of that supply could wipe out holdings of a high percentage of Zcash users. The disagreement highlights a fundamental trade-off: privacy versus the ability to audit and recover from errors.
At press time, ZEC traded at $532.




