EDA

Mastering Resolved Signals in VHDL: A Comprehensive Guide for Digital Design

I asked Gemini to teach me about the VHDL resolved signals. What you read below is the result.

Jul 14, 2025

How to shoot yourself in the foot with inout signals

They say that no good deed goes unpunished. Here’s an example of a footgun in VHDL which stems from in my view an eminently reasonable desire to keep the entity interface definitions compact.

Jul 7, 2025

VHDL IEEE Libraries and Numeric Type Conversion: A Definitive Reference

I asked Gemini to teach me the VHDL type conversions. What you read below is the result. An annoying generated podcast will be available for a while.

Jun 29, 2025

Packaging AMD Xilinx Vivado ML Standard edition 2025.1 in a Docker container

I updated the repository https://github.com/filmil/vivado-docker/ with the changes required to package Vivado 2025.1. As of this writing, version 2025.1 is the last published version. I hope that the updated version will remove some of the bugs I discovered in the previous version I dockerized, which was 2023.2.

Jun 19, 2025

Using glbl.v module in a Verilog simulation in Vivado

A quick note about correct use of glbl.v in a Verilog simulation in Vivado. This note is way less confusing than any notes you may find elsewhere on the Internet.

Nov 16, 2024

From zero to RISC-V in hardware, in 6 minutes

Program your FPGA with a one-liner command. It’s a kind of magic.

Oct 5, 2024

bazel rules for GHDL

I present to you https://github.com/filmil/bazel_rules_ghdl: a set of bazel rules for converting VHDL into Verilog.

Sep 3, 2024

Remote programming of an AMD (fka Xilinx) Artix-7 device

Here is how you can set up a hardware server (hw_server) in AMD Vivado 2023.2.

Jul 8, 2024

Packaging AMD Xilinx Vivado ML Standard edition in a Docker container

A while back I wanted to make a hermetic environment for repeatably running Docker tooling.

Nov 20, 2023