<?xml version="1.0" encoding="utf-8" standalone="yes"?><rss version="2.0" xmlns:atom="http://www.w3.org/2005/Atom"><channel><title>Metastability on bitwiz</title><link>https://bitwiz.io/tags/metastability/</link><description>Recent content in Metastability on bitwiz</description><generator>Hugo</generator><language>en-us</language><lastBuildDate>Fri, 02 Jan 2026 05:19:00 +0000</lastBuildDate><atom:link href="https://bitwiz.io/tags/metastability/index.xml" rel="self" type="application/rss+xml"/><item><title>CDC: Two Flip-Flops Are Not Magic</title><link>https://bitwiz.io/articles/cdc-two-flip-flops-are-not-magic/</link><pubDate>Fri, 02 Jan 2026 05:19:00 +0000</pubDate><guid>https://bitwiz.io/articles/cdc-two-flip-flops-are-not-magic/</guid><description>&lt;p&gt;&lt;em&gt;Timing Series: Part 5 of 6&lt;/em&gt;&lt;/p&gt;
&lt;p&gt;&lt;em&gt;Previous: &lt;a href="https://bitwiz.io/articles/silicon-real-estate-your-resource-budget/"&gt;Silicon Real Estate: Your Resource Budget&lt;/a&gt;&lt;/em&gt;&lt;/p&gt;
&lt;hr&gt;
&lt;h2 id="the-bug-you-cant-reproduce"&gt;The Bug You Can&amp;rsquo;t Reproduce&lt;/h2&gt;
&lt;p&gt;You&amp;rsquo;re debugging a data corruption bug. It happens once every few hours under heavy load. Sometimes once a day. The data path looks fine. The control logic looks fine. You add ILA triggers. You wait. You catch it.&lt;/p&gt;
&lt;p&gt;A control signal that pulses for one cycle is sometimes missed entirely. The path crosses clock domains. You have a 2-flop synchronizer.&lt;/p&gt;</description></item></channel></rss>