This folder accompanies the Project F blog post: Racing the Beam. These SystemVerilog designs race the beam to create simple demos. You can freely build on these MIT licensed designs. Have fun.
File layout:
ecp5
- designs for ULX3S and other Lattice ECP5 boards with DVI outputice40
- 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.
Jump to build instructions for: Arty | iCEBreaker | Nexys Video | ULX3S | Verilator
- Raster Bars -
rasterbars
- Hitomezashi -
hitomezashi
- Hello -
hello
- Colour Cycle -
colour_cycle
- Bounce -
bounce
Learn more about the designs and demos from Racing the Beam, or read on for build instructions.
Raster Bars running as a Verilator simulation.
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/racing-the-beam/xc7/vivado
source ./create_project.tcl
You can then build the designs as you would for any Vivado project. These designs run at 640x480 on the Arty.
The Arty designs have been tested with:
- Vivado 2022.2
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/racing-the-beam/xc7/vivado
source ./create_project.tcl
Replace <board>
and <fpga-part>
with the actual board and part names.
You can build projects for iCEBreaker using the included Makefile with Yosys, nextpnr, and IceStorm Tools.
You can get pre-built binaries for Linux, Mac, and Windows from YosysHQ.
For example, to build rasterbars
; clone the projf-explore git repo, then:
cd projf-explore/graphics/racing-the-beam/ice40
make rasterbars
After the build completes, you'll have a bin file, such as rasterbars.bin
. Use the bin file to program your board:
iceprog rasterbars.bin
These designs run at 640x480 on the iCEBreaker.
The iCE40 designs have been tested with:
- OSS CAD Suite 2023-03-01
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/racing-the-beam/xc7-dvi/vivado
source ./create_project.tcl
You can then build the designs as you would for any Vivado project. These designs run at 1280x720 on the Nexys Video.
The Nexys Video designs have been tested with:
- Vivado 2022.2
I have tested these designs with recent (late 2024) versions of Yosys and nextpnr. You can get pre-built binaries for Linux, Mac, and Windows from YosysHQ OSS CAD Suite.
Once the tools are installed, it's straightforward to build the designs.
For example, to build rasterbars
; clone the projf-explore git repo, check the correct FPGA model is set near the top of projf-explore/graphics/racing-the-beam/ecp5/Makefile
then:
cd projf-explore/graphics/racing-the-beam/ecp5
make rasterbars
After the build completes, you'll have a bit file, such as rasterbars.bit
. Use the bit file to program your board:
openFPGALoader --board=ulx3s rasterbars.bit
These designs run at 1280x720 on the ULX3S.
For advice on board programming without root, see the FPGA Graphics README.
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.