2018-05-16 18:50:02 -05:00
Introduction
============
The FPGA subsystem supports reprogramming FPGAs dynamically under
Linux. Some of the core intentions of the FPGA subsystems are:
* The FPGA subsystem is vendor agnostic.
* The FPGA subsystem separates upper layers (userspace interfaces and
enumeration) from lower layers that know how to program a specific
FPGA.
* Code should not be shared between upper and lower layers. This
should go without saying. If that seems necessary, there's probably
2018-06-27 20:56:19 -05:00
framework functionality that can be added that will benefit
2018-05-16 18:50:02 -05:00
other users. Write the linux-fpga mailing list and maintainers and
seek out a solution that expands the framework for broad reuse.
2018-06-27 20:56:19 -05:00
* Generally, when adding code, think of the future. Plan for reuse.
2018-05-16 18:50:02 -05:00
The framework in the kernel is divided into:
FPGA Manager
------------
2018-06-27 20:56:19 -05:00
If you are adding a new FPGA or a new method of programming an FPGA,
2018-05-16 18:50:02 -05:00
this is the subsystem for you. Low level FPGA manager drivers contain
the knowledge of how to program a specific device. This subsystem
includes the framework in fpga-mgr.c and the low level drivers that
are registered with it.
FPGA Bridge
-----------
2018-06-27 20:56:19 -05:00
FPGA Bridges prevent spurious signals from going out of an FPGA or a
region of an FPGA during programming. They are disabled before
2018-05-16 18:50:02 -05:00
programming begins and re-enabled afterwards. An FPGA bridge may be
2018-06-27 20:56:19 -05:00
actual hard hardware that gates a bus to a CPU or a soft ("freeze")
2018-05-16 18:50:02 -05:00
bridge in FPGA fabric that surrounds a partial reconfiguration region
of an FPGA. This subsystem includes fpga-bridge.c and the low level
drivers that are registered with it.
FPGA Region
-----------
If you are adding a new interface to the FPGA framework, add it on top
2018-10-15 17:20:04 -05:00
of an FPGA region.
2018-05-16 18:50:02 -05:00
The FPGA Region framework (fpga-region.c) associates managers and
bridges as reconfigurable regions. A region may refer to the whole
FPGA in full reconfiguration or to a partial reconfiguration region.
The Device Tree FPGA Region support (of-fpga-region.c) handles
reprogramming FPGAs when device tree overlays are applied.