Collection of examples for the ice40 ultraplus fpga, each example tests a feature of the fpga (such as spram) and is independent from the others.
All the examples are running on the ice40 ultraplus breakout board from lattice (https://www.latticesemi.com/Products/DevelopmentBoardsAndKits/iCE40UltraPlusBreakoutBoard) which contains a ice40 ultraplus fpga (iCE40UP5K), a flash, a ftdi usb-to-spi chip and a rgb led.
Some of the examples include:
SB_MAC16
) example with MAC (multiply and accumulate) operationsAll the examples are synthetized and programmed on the breakout board using the open souce tools from the icestorm project (http://www.clifford.at/icestorm/).
Most of the examples use the 12MHz external clock from the breakout board. The PLL example shows how to use the internal 48MHz clock.
Each example can be compiled with a make
which will create the
bitstream using the icestorm opensource tools, once the breakout board
is plugged.
make prog
will program the fpga using the internal sram based condiguration memory in
the Ice40 Ultraplus device. Since this memory is volatile, it will get
erased every time the board is powered down.
make prog_flash
will write the FPGA configuration to the separate
flash chip on the breakout board. However the FPGA will not be able to
communicate with the host through the USB using the SPI in this mode. A
power cycle may be also be needed for the FPGA to read the configuration
from the flash memory.
Note that the access to the Flash memory and the SPI interface is controlled by jumpers on the breakout board. The jumper settings are described in the Lattice iCE40 UltraPlus Breakout Board User Guide (pdf).
For make prog
to work, the jumpers at J6 should be in vertically
oriented. For make prog_flash
to work, the jumpers at J6 should be in
horizontal orientation.
Built on Linux Mint 20.0