IP-cores written in SystemVerilog for communicating with numerous FTDI chips using FT245 FIFO protocol.
The protocol exists in the two versions: synchronous and asynchronous, and there are two cores proto245s
and proto245a
to use with the appropriate version.
Table with supported FTDI devices (based on the protocol specifications) below.
FTDI Chip | USB Speed | Asynchronous FIFO | Synchronous FIFO |
---|---|---|---|
FT245R | FullSpeed | ❌ | |
FT240X | FullSpeed | ❌ | |
FT2232D | FullSpeed | ❌ | |
FT232H | HighSpeed | ||
FT2232H | HighSpeed | ||
FT232HP/FT233HP | HighSpeed | ||
FT2232HP/FT2233HP | HighSpeed | ||
FT600Q | SuperSpeed | ❌ | |
FT601Q | SuperSpeed | ❌ | |
FT602Q | SuperSpeed | ❌ |
Implements asynchronous FT245 protocol from the one side and provides RX & TX FIFO interfaces from the other side.
Features:
- configurable RX & TX FIFO size
- configurable
RD#
&WR#
assertion time to adapt to any clock frequency - flexible clock domains - FSM and FIFOs might share the same clock or use separate clocks
Notes:
- Send Immediate / Wake Up signal (SIWU) tied to inactive state
Single clock domain:
proto245a (proto245a.sv)
├── rxfifo (fifo_sync.sv)
│ └── dpram (dpram.sv)
└── txfifo (fifo_sync.sv)
└── dpram (dpram.sv)
Multiple clock domains:
proto245a (proto245a.sv)
├── rxfifo (fifo_async.sv)
│ └── dpram (dpram.sv)
└── txfifo (fifo_async.sv)
└── dpram (dpram.sv)
From FT2232H datasheet.
Implements synchronous FT245 protocol from the one side and provides RX & TX FIFO interfaces from the other side.
Features:
- configurable data size (e.g. 8 bits needed for HS devices, 16/32 bits for SS devices)
- configurable RX & TX FIFO size
- configurable RX & TX burst size - maximum number of words per one read/write burst (optional)
- configurable RX & TX FIFO thresholds - transaction will start only if FIFO is filled below/above the threshold
- configurable pause between transactions
- flexible clock domains - FSM and FIFOs might share the same clock or use separate clocks
Notes:
- FT2xx chips: Send Immediate / Wake Up signal (SIWU) tied to inactive state
- FT60x chips: Byte Enable signals (BE) are not supported at the moment, so, all transactions have to be word aligned
Single clock domain:
proto245s (proto245s.sv)
├── rxfifo (fifo_sync.sv)
│ └── dpram (dpram.sv)
├── txfifo (fifo_sync.sv)
│ └── dpram (dpram.sv)
└── txovrbuf (fifo_sync.sv)
└── dpram (dpram.sv)
Multiple clock domains:
proto245s (proto245s.sv)
├── rxfifo (fifo_async.sv)
│ └── dpram (dpram.sv)
├── txfifo (fifo_async.sv)
│ └── dpram (dpram.sv)
└── txovrbuf (fifo_sync.sv)
└── dpram (dpram.sv)
From FT2232H datasheet.
From FT600Q/FT601Q datasheet.
The same as for proto245a
core.
Project | FPGA/Board | FTDI chip | Software |
---|---|---|---|
ft2232h_de10lite | DE10-Lite | FT2232H | Python (ftd2xx, pylibftdi, pyusb, ftdi1) |
For more details please follow README files inside examples/$PROJNAME$
directories.
Environment is built around Python pytest framework - it offers some nice and easy to use tools for test execution control and parametrization out of the box.
Current workflow is based on the pyhdlsim example - sim.py
is a wrapper around HDL simulators and test_*.py
files contain tests.
Tested on:
- Windows 10, Python 3.8, Modelsim 10.6d
- Ubuntu 20.04, Python 3.8, Modelsim 2020.02
For more details please follow testing README.