Skip to content
Go to file

Latest commit


Git stats


Failed to load latest commit information.
Latest commit message
Commit time

PIF_Z - FPGA on a Raspberry Pi

This is the software for Bugblat's PIF_Z Raspberry Pi FPGA board.

The PIF_Z stacks neatly on a Pi Zero, though it is 100% compatible with all Pi boards with a 40-pin connector - all reasonably recent Raspberry Pi models.

What is the PIF_Z board?

A pif board, which plugs into a Raspberry Pi, carries a non-volatile Lattice Semiconductor MachXO2 FPGA.

To program the FPGA, you start by writing a firmware program, usually in VHDL or Verilog though there are other options. The firmware program can be simulated and compiled to a JEDEC bitstream with Lattice's free Diamond software.

Then you have to inject the bitstream into the pif's FPGA, and that's the job of the software in this repo. Primarily in Python, there are programs to

  • program the onboard FPGA with a compiled bitstream
  • control the FPGA firmware from the Raspberry Pi processor

Example FPGA firmware programs are also included, plus an example of controlling the FPGA from a web application.

Many flavors of Linux are available for the Raspberry Pi. This software is written for the Raspbian/jessie distribution.

More Information

The pif product pages, including links to the full documentation, are here.


FPGA on a Raspberry PiZero



No releases published
You can’t perform that action at this time.