<?xml version="1.0" encoding="utf-8" standalone="yes"?><rss version="2.0" xmlns:atom="http://www.w3.org/2005/Atom"><channel><title>CDC on bitwiz</title><link>https://bitwiz.io/tags/cdc/</link><description>Recent content in CDC 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/cdc/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><item><title>Constraints: The Contract You Forgot to Sign</title><link>https://bitwiz.io/articles/constraints-the-contract-you-forgot-to-sign/</link><pubDate>Tue, 23 Dec 2025 15:04:00 +0000</pubDate><guid>https://bitwiz.io/articles/constraints-the-contract-you-forgot-to-sign/</guid><description>&lt;p&gt;&lt;em&gt;Timing Series: Part 1 of 6&lt;/em&gt;&lt;/p&gt;
&lt;p&gt;&lt;em&gt;Previous: &lt;a href="https://bitwiz.io/articles/your-fpga-lives-a-lifetime-while-you-blink/"&gt;Your FPGA Lives a Lifetime While You Blink&lt;/a&gt;&lt;/em&gt;&lt;/p&gt;
&lt;hr&gt;
&lt;h2 id="signoff-gates-build-must-fail-if"&gt;Signoff Gates: Build Must Fail If&amp;hellip;&lt;/h2&gt;
&lt;p&gt;Before reading further, know this: your build should fail if any of these checks fail.&lt;/p&gt;
&lt;p&gt;&lt;strong&gt;Gate 1: Unconstrained endpoints must be zero&lt;/strong&gt;&lt;/p&gt;
&lt;div class="highlight"&gt;&lt;pre tabindex="0" class="chroma"&gt;&lt;code class="language-tcl" data-lang="tcl"&gt;&lt;span class="line"&gt;&lt;span class="cl"&gt;&lt;span class="nv"&gt;check_timing&lt;/span&gt; &lt;span class="o"&gt;-&lt;/span&gt;verbose
&lt;/span&gt;&lt;/span&gt;&lt;span class="line"&gt;&lt;span class="cl"&gt;&lt;span class="nv"&gt;report_exceptions&lt;/span&gt; &lt;span class="o"&gt;-&lt;/span&gt;verbose
&lt;/span&gt;&lt;/span&gt;&lt;/code&gt;&lt;/pre&gt;&lt;/div&gt;&lt;p&gt;Fail if: Any constraint-related issue about clocks, unconstrained endpoints, or missing I/O delays. Also fail if any exception matches zero objects (silent no-op) or hits an unexpectedly large set.&lt;/p&gt;</description></item></channel></rss>