data:image/s3,"s3://crabby-images/a502f/a502f7f3c68915a492b4d32ff4461a70115578fd" alt="Designing PCBs for FPGA on FPGA"
Installed various EE design applications (including KiCad) on the Ubuntu 22.04 desktop image on FPGA (Zynq™ UltraScale+™ MPSoC) and designed PCBs with it.
Steps
Download the latest boot firmware for K260 from the Kria SOM wiki (https://xilinx-wiki.atlassian.net/wiki/spaces/A/pages/1641152513/Kria+SOMs+Starter+Kits#K26-Boot-Firmware-Updates) and upload the firmware to the KV260’s QSPI flash memory using the instructions provided with the boot image recovery tool.
data:image/s3,"s3://crabby-images/71ecf/71ecf8f501457da57510394ca11a0b77efc0088d" alt="Designing PCBs for FPGA on FPGA"
data:image/s3,"s3://crabby-images/0668e/0668e48457a7fa0b798259fe2d3c43454dfd664b" alt="Designing PCBs for FPGA on FPGA"
Create Ubuntu 22.04 SD Card for FPGA
After updating the boot firmware, you can directly download the image file for Krias’s Ubuntu 22.04 desktop image from the Canonical website (https://ubuntu.com/download/amd):
data:image/s3,"s3://crabby-images/1889c/1889c7610830640dca36a2dd2b268d3143548bdc" alt="Designing PCBs for FPGA on FPGA"
Then use a tool to flash the SD card image. Here, balenaEtcher is recommended.
data:image/s3,"s3://crabby-images/2d233/2d23363426a65f161af6ccccb1cdab748218b41f" alt="Designing PCBs for FPGA on FPGA"
Choose a larger SD card (>= 32GB), as you will need to install other software later.
Hardware Setup
Connect the keyboard, mouse, and HDMI display to the KV260, and connect the Ethernet to the router:
data:image/s3,"s3://crabby-images/fae4e/fae4e3b19f9dee9f357804586e6ed548f9ef2261" alt="Designing PCBs for FPGA on FPGA"
data:image/s3,"s3://crabby-images/b3cd2/b3cd2087c3f0bfae4d87084e00bcc6af801eae35" alt="Designing PCBs for FPGA on FPGA"
Preparing the Ubuntu Environment
First, the PWM logic in the FPGA bitstream conflicts with the fan control logic in Ubuntu. Therefore, to ensure that the CPU fan runs at full speed continuously, you need to stop the fancontrol service in Ubuntu:
ubuntu@kria:~$ sudo service fancontrol stop
Xlnx -config (https://xilinx-wiki.atlassian.net/wiki/spaces/A/pages/2057043969/Snaps+-+xlnx-config+Snap+for+Certified+Ubuntu+on+Xilinx+Devices) is a command-line tool that needs to be installed to configure the system according to ZynqMP specific requirements (e.g., custom Xilinx gstreamer):
ubuntu@kria:~$ sudo snap install xlnx-config --classic --channel=2.x
ubuntu@kria:~$ sudo xlnx-config.sysinit
Finally, update and upgrade the system:
ubuntu@kria:~$ sudo apt update
ubuntu@kria:~$ sudo apt upgrade
Restart the FPGA to ensure that all changes take effect.
Installing KiCad
Install the entire science-electronics package to try out other commonly used applications such as GnuRadio, Fritzing, etc.
ubuntu@kria:~$ sudo apt-get install science-electronics
data:image/s3,"s3://crabby-images/eb418/eb41852f0db3aca6f42ffa95530baf159426c3cf" alt="Designing PCBs for FPGA on FPGA"
Using KiCad for PCB Design
data:image/s3,"s3://crabby-images/81625/81625e8076785a75638b498a24fad8a23ba1dbd2" alt="Designing PCBs for FPGA on FPGA"
Use the content provided in the KiCad default library to layout a simple common-emitter BJT circuit driving an LED.
data:image/s3,"s3://crabby-images/88e6b/88e6bbf77796faf92471aed78f7b13c363fb9066" alt="Designing PCBs for FPGA on FPGA"
The layout has no issues, although it is not as flexible as on a PC, it is definitely sufficient.
data:image/s3,"s3://crabby-images/27c54/27c548a9d875d6cdb6cf3503812694953bcc17c6" alt="Designing PCBs for FPGA on FPGA"
After completing the layout, the 3D rendering tool takes some time to load:
data:image/s3,"s3://crabby-images/293b8/293b8f9f58ab4f44839b2cadfd1aabf4726678ff" alt="Designing PCBs for FPGA on FPGA"
data:image/s3,"s3://crabby-images/35364/35364c9d0a3ef1195abcad5f7495414f23fc4fc6" alt="Designing PCBs for FPGA on FPGA"
Conclusion
Honestly, this is a start: designing PCBs for FPGA using FPGA. Considering the powerful scalability of FPGA, you can even design acceleration for your software~
data:image/s3,"s3://crabby-images/fecc3/fecc3c1c04171b99080299dea15c23b138d88520" alt="Designing PCBs for FPGA on FPGA"