This folder accompanies the Project F blog post: 2D Shapes. These SystemVerilog designs draw circles, rectangles, and filled shapes in a framebuffer. You can freely build on these MIT licensed designs. Have fun.
File layout:
160x90
- render modules for 160x90 with 4 colours320x180
- render modules for 320x180 with 16 coloursice40
- designs for iCEBreaker and other Lattice iCE40 boardssim
- simulation with Verilator and LibSDL; see the Simulation READMExc7
- designs for Arty and other Xilinx 7 Series boards with VGA outputxc7-dvi
- designs for Nexys Video and other Xilinx 7 Series boards with DVI output
These designs make use of modules from the Project F library. Check the included iCE40 Makefile or Vivado create_project.tcl to see the list of modules.
There is one demo top module that can draw different things.
To switch between the different demos, change the render instance near line 125 in top_demo
:
render_rects
- many rectangles inside rectanglesrender_rects_fill
- overlapping filled rectanglesrender_triangles_fill
- three filled trianglesrender_cube_fill
- filled cube from six trianglesrender_circles
- circles inside circlesrender_circles_fill
- filled circles inside circles
Learn more about the designs and demo from the 2D Shapes blog post, or read on for build instructions. New to graphics development on FPGA? Check out Beginning FPGA Graphics.
Circles drawn by an iCE40 FPGA on an HDMI monitor.
You can build projects for iCEBreaker using the included Makefile with Yosys, nextpnr, and IceStorm Tools.
You can get pre-built tool binaries for Linux, Mac, and Windows from YosysHQ. If you want to build the tools yourself, check out Building iCE40 FPGA Toolchain on Linux.
To build the demo
project, clone the projf-explore git repo, then:
cd projf-explore/graphics/2d-shapes/ice40
make demo
After the build completes, you'll have a bin file called demo.bin
. Use the bin file to program your board:
iceprog demo.bin
If you get the error Can't find iCE FTDI USB device
, try running iceprog
with sudo
.
If Yosys reports "syntax error, unexpected TOK_ENUM", then your version is too old to support Project F designs. Try building the latest version of Yosys from source (see above for links).
To create a Vivado project for the Digilent Arty (original or A7-35T); clone the projf-explore git repo, then start Vivado and run the following in the Tcl console:
cd projf-explore/graphics/2d-shapes/xc7/vivado
source ./create_project.tcl
You can then build top_demo
as you would for any Vivado project.
This design includes a test bench for the new drawing modules. You can run the test bench simulations from the GUI under the "Flow" menu or from the Tcl console with:
launch_simulation
run all
By default the draw_rectangle
test bench is simulated, but you can switch to another test bench, such as draw_rectangle_fill
with:
set fs_sim_obj [get_filesets sim_1]
set_property -name "top" -value "draw_rectangle_fill" -objects $fs_sim_obj
relaunch_sim
run all
It's straightforward to adapt the project for other Xilinx 7 Series boards:
- Create a suitable constraints file named
<board>.xdc
within thexc7
directory - Make a note of your board's FPGA part, such as
xc7a35ticsg324-1L
- Set the board and part names in Tcl, then source the create project script:
set board_name <board>
set fpga_part <fpga-part>
cd projf-explore/graphics/2d-shapes/xc7/vivado
source ./create_project.tcl
Replace <board>
and <fpga-part>
with the actual board and part names.
To create a Vivado project for the Digilent Nexys Video; clone the projf-explore git repo, then start Vivado and run the following in the Tcl console:
cd projf-explore/graphics/2d-shapes/xc7-dvi/vivado
source ./create_project.tcl
You can then build top_demo
as you would for any Vivado project.
The Nexys Video designs have been tested with:
- Vivado 2022.2
You can simulate these designs on your computer using Verilator and SDL. The Simulation README has build instructions.
If you have Verilator installed, you can run the linting shell script lint.sh
to check the designs. Learn more from Verilog Lint with Verilator.
These designs use a little SystemVerilog to make Verilog more pleasant. See the Library README for details of SV features used.