Table of Contents

flink, Universal Interface to FPGA's

Downloads

flink is ..

flink can be read as fast link or as the German “flink” meaning fast. It enables any processors to communicate with an external FPGA over a parallel interface (e.g. PCI, EIM, LPB, AXI) or serial interface (e.g. SPI). The FPGA may contain several blocks such as counters or pulse-width modulation. Such blocks are extensively used in robotics for control applications.
flink was developed at and is maintained by the Institute of Computer Science at OST.

Overview

flink can be used on a multitude of targets and with various setups.
flink includes the following modules

Typical use with C/C++ under an operating system

Implement all necessary hardware modules with flink VHDL modules and interfaces and choose a suitable interconnection with the available flink Linux Kernel Modules. Develop your application using the flink Userspace Library. The following picture shows the system setup.

flink with OS and C/C++ programming

System Architecture

An external FPGA contains hardware modules, which provide certain functions such as a pwm generator or an analog input channel. Such an external FPGA is represented by a flink device. Every flink device contains one or more subdevices. A subdevice represents a function. At last every subdevice has one or more channels.

System architecture for an example system with a motor drive. The drive controlled by an analog output signal. The motor position is determined with a counter module.

Memory Mapping

Every subdevice which is specified in a device offers a standardised memory interface towards the driver library. The first 16 bytes comprise the header information which is read-only.

OffsetSize [byte] Namer/wConstDescription
0x004functionryesfunction, which this subdevice implements
0x044memory sizeryestotal memory size of this device, including header, subheader and subdevice specific information
0x084nof channelsryesnumber of channels of this subdevice
0x0c4unique idryesid identifying this subdevice

The field function has the following meaning:

31302928272625242322212019181716
function id
1514131211109876543210
subtype id interface version

All the available functions can be found in Available Subdevices. Next comes a subheader. It contains a configuration and status register. The meaning of the single bits of these registers can vary according to the function of the subdevice.

OffsetSize [byte] Namer/wConstDescription
0x104statusrnostatus of subdevice
0x144configuration r/wnoconfiguration word for subdevice
0x184 reserved
0x1c4 reserved

Header and subheader is followed by a subdevice specific part. The content varies according to the function and is listed in Available Subdevices