<?xml version="1.0" encoding="utf-8" standalone="yes"?><rss version="2.0" xmlns:atom="http://www.w3.org/2005/Atom"><channel><title>Tooling on bitwiz</title><link>https://bitwiz.io/tags/tooling/</link><description>Recent content in Tooling on bitwiz</description><generator>Hugo</generator><language>en-us</language><lastBuildDate>Thu, 01 Jan 2026 00:00:00 +0000</lastBuildDate><atom:link href="https://bitwiz.io/tags/tooling/index.xml" rel="self" type="application/rss+xml"/><item><title>constraint-lint</title><link>https://bitwiz.io/projects/constraint-lint/</link><pubDate>Thu, 01 Jan 2026 00:00:00 +0000</pubDate><guid>https://bitwiz.io/projects/constraint-lint/</guid><description>&lt;h2 id="the-problem"&gt;The Problem&lt;/h2&gt;
&lt;p&gt;Your XDC file is code. Vivado doesn&amp;rsquo;t lint it.&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;create_clock&lt;/span&gt; &lt;span class="o"&gt;-&lt;/span&gt;name clk156 &lt;span class="o"&gt;-&lt;/span&gt;period &lt;span class="mf"&gt;6.400&lt;/span&gt; &lt;span class="k"&gt;[&lt;/span&gt;&lt;span class="nv"&gt;get_ports&lt;/span&gt; clk_156&lt;span class="k"&gt;]&lt;/span&gt;
&lt;/span&gt;&lt;/span&gt;&lt;/code&gt;&lt;/pre&gt;&lt;/div&gt;&lt;p&gt;The port is &lt;code&gt;clk156&lt;/code&gt;. The clock attaches to nothing. Vivado warns once. It disappears into 200k lines of logs.&lt;/p&gt;
&lt;p&gt;Your constraint file says the clock exists. Your log has one warning: no valid objects matched. WNS is meaningless because the domain you thought you constrained doesn&amp;rsquo;t exist. You find out in the lab.&lt;/p&gt;
&lt;hr&gt;
&lt;h2 id="what-constraint-lint-does"&gt;What constraint-lint Does&lt;/h2&gt;
&lt;p&gt;Lint for XDC/SDC. Runs in CI. Turns constraint warnings into hard failures.&lt;/p&gt;</description></item></channel></rss>