A KiCad to Verilog Generator #KiCad #Verilog #FPGA
The KiCad to Verilog Generator a KiCad plugin for generating Verilog code from a KiCad 6.0 (or later) schematic by Bob Alexander. It’s under a permissive MIT License.
I’m designing a homebrew CPU. I wanted to simulate it before fabricating the PCB. Generating Verilog, and using one of the many Verilog simulators that are available, seemed like the best approach.
There are some Verilog design packages, like Quartus II and Icestudio, that allow you to draw a schematic. But their schematic tools are not as powerful as KiCad’s. And once you’re done drawing and testing in those packages, you need to go through the tedious and error-prone process of re-drawing the schematic in a PCB CAD program anyway.
Unfortunately, my KiCadVerilog plugin is not a one-step solution. It generates a framework for a working Verilog program, with Verilog modules for all the components, and Verilog wires for all the connections. But it doesn’t know the behavior of the components in the schematic. So the user is still responsible for writing Verilog for each component. For example, if there’s a 7402 quad NAND gate in the design, or a 74181 Arithmetic Logic Unit, the user has to write (or find on the web) Verilog code to implement it.
It does some other cool things though: it recognizes pull-up and pull-down resistors, and generates Verilog appropriately; it recognizes bypass capacitors and knows not to generate Verilog code for them; and it provides a mechanism to integrate your Verilog module implementations into the generated code safely, so that you can modify your schematic, re-generate the Verilog, and your implementations will be preserved.
Read more from the author and see the tool on GitHub.
Adafruit publishes a wide range of writing and video content, including interviews and reporting on the maker market and the wider technology world. Our standards page is intended as a guide to best practices that Adafruit uses, as well as an outline of the ethical standards Adafruit aspires to. While Adafruit is not an independent journalistic institution, Adafruit strives to be a fair, informative, and positive voice within the community – check it out here: adafruit.com/editorialstandards
Stop breadboarding and soldering – start making immediately! Adafruit’s Circuit Playground is jam-packed with LEDs, sensors, buttons, alligator clip pads and more. Build projects with Circuit Playground in a few minutes with the drag-and-drop MakeCode programming site, learn computer science using the CS Discoveries class on code.org, jump into CircuitPython to learn Python and hardware together, TinyGO, or even use the Arduino IDE. Circuit Playground Express is the newest and best Circuit Playground board, with support for CircuitPython, MakeCode, and Arduino. It has a powerful processor, 10 NeoPixels, mini speaker, InfraRed receive and transmit, two buttons, a switch, 14 alligator clip pads, and lots of sensors: capacitive touch, IR proximity, temperature, light, motion and sound. A whole wide world of electronics and coding is waiting for you, and it fits in the palm of your hand.
Have an amazing project to share? The Electronics Show and Tell is every Wednesday at 7:30pm ET! To join, head over to YouTube and check out the show’s live chat and our Discord!