The Design and Implementation of the FreeBSD Operating System, Second Edition
Now available: The Design and Implementation of the FreeBSD Operating System (Second Edition)


[ source navigation ] [ diff markup ] [ identifier search ] [ freetext search ] [ file search ] [ list types ] [ track identifier ]

FreeBSD/Linux Kernel Cross Reference
sys/contrib/device-tree/Bindings/fpga/fpga-region.txt

Version: -  FREEBSD  -  FREEBSD-13-STABLE  -  FREEBSD-13-0  -  FREEBSD-12-STABLE  -  FREEBSD-12-0  -  FREEBSD-11-STABLE  -  FREEBSD-11-0  -  FREEBSD-10-STABLE  -  FREEBSD-10-0  -  FREEBSD-9-STABLE  -  FREEBSD-9-0  -  FREEBSD-8-STABLE  -  FREEBSD-8-0  -  FREEBSD-7-STABLE  -  FREEBSD-7-0  -  FREEBSD-6-STABLE  -  FREEBSD-6-0  -  FREEBSD-5-STABLE  -  FREEBSD-5-0  -  FREEBSD-4-STABLE  -  FREEBSD-3-STABLE  -  FREEBSD22  -  l41  -  OPENBSD  -  linux-2.6  -  MK84  -  PLAN9  -  xnu-8792 
SearchContext: -  none  -  3  -  10 

    1 FPGA Region Device Tree Binding
    2 
    3 Alan Tull 2016
    4 
    5  CONTENTS
    6  - Introduction
    7  - Terminology
    8  - Sequence
    9  - FPGA Region
   10  - Supported Use Models
   11  - Device Tree Examples
   12  - Constraints
   13 
   14 
   15 Introduction
   16 ============
   17 
   18 FPGA Regions represent FPGA's and partial reconfiguration regions of FPGA's in
   19 the Device Tree.  FPGA Regions provide a way to program FPGAs under device tree
   20 control.
   21 
   22 This device tree binding document hits some of the high points of FPGA usage and
   23 attempts to include terminology used by both major FPGA manufacturers.  This
   24 document isn't a replacement for any manufacturers specifications for FPGA
   25 usage.
   26 
   27 
   28 Terminology
   29 ===========
   30 
   31 Full Reconfiguration
   32  * The entire FPGA is programmed.
   33 
   34 Partial Reconfiguration (PR)
   35  * A section of an FPGA is reprogrammed while the rest of the FPGA is not
   36    affected.
   37  * Not all FPGA's support PR.
   38 
   39 Partial Reconfiguration Region (PRR)
   40  * Also called a "reconfigurable partition"
   41  * A PRR is a specific section of an FPGA reserved for reconfiguration.
   42  * A base (or static) FPGA image may create a set of PRR's that later may
   43    be independently reprogrammed many times.
   44  * The size and specific location of each PRR is fixed.
   45  * The connections at the edge of each PRR are fixed.  The image that is loaded
   46    into a PRR must fit and must use a subset of the region's connections.
   47  * The busses within the FPGA are split such that each region gets its own
   48    branch that may be gated independently.
   49 
   50 Persona
   51  * Also called a "partial bit stream"
   52  * An FPGA image that is designed to be loaded into a PRR.  There may be
   53    any number of personas designed to fit into a PRR, but only one at at time
   54    may be loaded.
   55  * A persona may create more regions.
   56 
   57 FPGA Bridge
   58  * FPGA Bridges gate bus signals between a host and FPGA.
   59  * FPGA Bridges should be disabled while the FPGA is being programmed to
   60    prevent spurious signals on the cpu bus and to the soft logic.
   61  * FPGA bridges may be actual hardware or soft logic on an FPGA.
   62  * During Full Reconfiguration, hardware bridges between the host and FPGA
   63    will be disabled.
   64  * During Partial Reconfiguration of a specific region, that region's bridge
   65    will be used to gate the busses.  Traffic to other regions is not affected.
   66  * In some implementations, the FPGA Manager transparantly handles gating the
   67    buses, eliminating the need to show the hardware FPGA bridges in the
   68    device tree.
   69  * An FPGA image may create a set of reprogrammable regions, each having its
   70    own bridge and its own split of the busses in the FPGA.
   71 
   72 FPGA Manager
   73  * An FPGA Manager is a hardware block that programs an FPGA under the control
   74    of a host processor.
   75 
   76 Base Image
   77  * Also called the "static image"
   78  * An FPGA image that is designed to do full reconfiguration of the FPGA.
   79  * A base image may set up a set of partial reconfiguration regions that may
   80    later be reprogrammed.
   81 
   82     ----------------       ----------------------------------
   83     |  Host CPU    |       |             FPGA               |
   84     |              |       |                                |
   85     |          ----|       |       -----------    --------  |
   86     |          | H |       |   |==>| Bridge0 |<==>| PRR0 |  |
   87     |          | W |       |   |   -----------    --------  |
   88     |          |   |       |   |                            |
   89     |          | B |<=====>|<==|   -----------    --------  |
   90     |          | R |       |   |==>| Bridge1 |<==>| PRR1 |  |
   91     |          | I |       |   |   -----------    --------  |
   92     |          | D |       |   |                            |
   93     |          | G |       |   |   -----------    --------  |
   94     |          | E |       |   |==>| Bridge2 |<==>| PRR2 |  |
   95     |          ----|       |       -----------    --------  |
   96     |              |       |                                |
   97     ----------------       ----------------------------------
   98 
   99 Figure 1: An FPGA set up with a base image that created three regions.  Each
  100 region (PRR0-2) gets its own split of the busses that is independently gated by
  101 a soft logic bridge (Bridge0-2) in the FPGA.  The contents of each PRR can be
  102 reprogrammed independently while the rest of the system continues to function.
  103 
  104 
  105 Sequence
  106 ========
  107 
  108 When a DT overlay that targets an FPGA Region is applied, the FPGA Region will
  109 do the following:
  110 
  111  1. Disable appropriate FPGA bridges.
  112  2. Program the FPGA using the FPGA manager.
  113  3. Enable the FPGA bridges.
  114  4. The Device Tree overlay is accepted into the live tree.
  115  5. Child devices are populated.
  116 
  117 When the overlay is removed, the child nodes will be removed and the FPGA Region
  118 will disable the bridges.
  119 
  120 
  121 FPGA Region
  122 ===========
  123 
  124 FPGA Regions represent FPGA's and FPGA PR regions in the device tree.  An FPGA
  125 Region brings together the elements needed to program on a running system and
  126 add the child devices:
  127 
  128  * FPGA Manager
  129  * FPGA Bridges
  130  * image-specific information needed to to the programming.
  131  * child nodes
  132 
  133 The intended use is that a Device Tree overlay (DTO) can be used to reprogram an
  134 FPGA while an operating system is running.
  135 
  136 An FPGA Region that exists in the live Device Tree reflects the current state.
  137 If the live tree shows a "firmware-name" property or child nodes under an FPGA
  138 Region, the FPGA already has been programmed.  A DTO that targets an FPGA Region
  139 and adds the "firmware-name" property is taken as a request to reprogram the
  140 FPGA.  After reprogramming is successful, the overlay is accepted into the live
  141 tree.
  142 
  143 The base FPGA Region in the device tree represents the FPGA and supports full
  144 reconfiguration.  It must include a phandle to an FPGA Manager.  The base
  145 FPGA region will be the child of one of the hardware bridges (the bridge that
  146 allows register access) between the cpu and the FPGA.  If there are more than
  147 one bridge to control during FPGA programming, the region will also contain a
  148 list of phandles to the additional hardware FPGA Bridges.
  149 
  150 For partial reconfiguration (PR), each PR region will have an FPGA Region.
  151 These FPGA regions are children of FPGA bridges which are then children of the
  152 base FPGA region.  The "Full Reconfiguration to add PRR's" example below shows
  153 this.
  154 
  155 If an FPGA Region does not specify an FPGA Manager, it will inherit the FPGA
  156 Manager specified by its ancestor FPGA Region.  This supports both the case
  157 where the same FPGA Manager is used for all of an FPGA as well the case where
  158 a different FPGA Manager is used for each region.
  159 
  160 FPGA Regions do not inherit their ancestor FPGA regions' bridges.  This prevents
  161 shutting down bridges that are upstream from the other active regions while one
  162 region is getting reconfigured (see Figure 1 above).  During PR, the FPGA's
  163 hardware bridges remain enabled.  The PR regions' bridges will be FPGA bridges
  164 within the static image of the FPGA.
  165 
  166 Required properties:
  167 - compatible : should contain "fpga-region"
  168 - fpga-mgr : should contain a phandle to an FPGA Manager.  Child FPGA Regions
  169         inherit this property from their ancestor regions.  An fpga-mgr property
  170         in a region will override any inherited FPGA manager.
  171 - #address-cells, #size-cells, ranges : must be present to handle address space
  172         mapping for child nodes.
  173 
  174 Optional properties:
  175 - firmware-name : should contain the name of an FPGA image file located on the
  176         firmware search path.  If this property shows up in a live device tree
  177         it indicates that the FPGA has already been programmed with this image.
  178         If this property is in an overlay targeting an FPGA region, it is a
  179         request to program the FPGA with that image.
  180 - fpga-bridges : should contain a list of phandles to FPGA Bridges that must be
  181         controlled during FPGA programming along with the parent FPGA bridge.
  182         This property is optional if the FPGA Manager handles the bridges.
  183         If the fpga-region is  the child of an fpga-bridge, the list should not
  184         contain the parent bridge.
  185 - partial-fpga-config : boolean, set if partial reconfiguration is to be done,
  186         otherwise full reconfiguration is done.
  187 - external-fpga-config : boolean, set if the FPGA has already been configured
  188         prior to OS boot up.
  189 - encrypted-fpga-config : boolean, set if the bitstream is encrypted
  190 - region-unfreeze-timeout-us : The maximum time in microseconds to wait for
  191         bridges to successfully become enabled after the region has been
  192         programmed.
  193 - region-freeze-timeout-us : The maximum time in microseconds to wait for
  194         bridges to successfully become disabled before the region has been
  195         programmed.
  196 - config-complete-timeout-us : The maximum time in microseconds time for the
  197         FPGA to go to operating mode after the region has been programmed.
  198 - child nodes : devices in the FPGA after programming.
  199 
  200 In the example below, when an overlay is applied targeting fpga-region0,
  201 fpga_mgr is used to program the FPGA.  Two bridges are controlled during
  202 programming: the parent fpga_bridge0 and fpga_bridge1.  Because the region is
  203 the child of fpga_bridge0, only fpga_bridge1 needs to be specified in the
  204 fpga-bridges property.  During programming, these bridges are disabled, the
  205 firmware specified in the overlay is loaded to the FPGA using the FPGA manager
  206 specified in the region.  If FPGA programming succeeds, the bridges are
  207 reenabled and the overlay makes it into the live device tree.  The child devices
  208 are then populated.  If FPGA programming fails, the bridges are left disabled
  209 and the overlay is rejected.  The overlay's ranges property maps the lwhps
  210 bridge's region (0xff200000) and the hps bridge's region (0xc0000000) for use by
  211 the two child devices.
  212 
  213 Example:
  214 Base tree contains:
  215 
  216         fpga_mgr: fpga-mgr@ff706000 {
  217                 compatible = "altr,socfpga-fpga-mgr";
  218                 reg = <0xff706000 0x1000
  219                        0xffb90000 0x20>;
  220                 interrupts = <0 175 4>;
  221         };
  222 
  223         fpga_bridge0: fpga-bridge@ff400000 {
  224                 compatible = "altr,socfpga-lwhps2fpga-bridge";
  225                 reg = <0xff400000 0x100000>;
  226                 resets = <&rst LWHPS2FPGA_RESET>;
  227                 clocks = <&l4_main_clk>;
  228 
  229                 #address-cells = <1>;
  230                 #size-cells = <1>;
  231                 ranges;
  232 
  233                 fpga_region0: fpga-region0 {
  234                         compatible = "fpga-region";
  235                         fpga-mgr = <&fpga_mgr>;
  236                 };
  237         };
  238 
  239         fpga_bridge1: fpga-bridge@ff500000 {
  240                 compatible = "altr,socfpga-hps2fpga-bridge";
  241                 reg = <0xff500000 0x10000>;
  242                 resets = <&rst HPS2FPGA_RESET>;
  243                 clocks = <&l4_main_clk>;
  244         };
  245 
  246 Overlay contains:
  247 
  248 /dts-v1/;
  249 /plugin/;
  250 
  251 &fpga_region0 {
  252         #address-cells = <1>;
  253         #size-cells = <1>;
  254 
  255         firmware-name = "soc_system.rbf";
  256         fpga-bridges = <&fpga_bridge1>;
  257         ranges = <0x20000 0xff200000 0x100000>,
  258                  <0x0 0xc0000000 0x20000000>;
  259 
  260         gpio@10040 {
  261                 compatible = "altr,pio-1.0";
  262                 reg = <0x10040 0x20>;
  263                 altr,ngpio = <4>;
  264                 #gpio-cells = <2>;
  265                 clocks = <2>;
  266                 gpio-controller;
  267         };
  268 
  269         onchip-memory {
  270                 device_type = "memory";
  271                 compatible = "altr,onchipmem-15.1";
  272                 reg = <0x0 0x10000>;
  273         };
  274 };
  275 
  276 
  277 Supported Use Models
  278 ====================
  279 
  280 In all cases the live DT must have the FPGA Manager, FPGA Bridges (if any), and
  281 a FPGA Region.  The target of the Device Tree Overlay is the FPGA Region.  Some
  282 uses are specific to an FPGA device.
  283 
  284  * No FPGA Bridges
  285    In this case, the FPGA Manager which programs the FPGA also handles the
  286    bridges behind the scenes.  No FPGA Bridge devices are needed for full
  287    reconfiguration.
  288 
  289  * Full reconfiguration with hardware bridges
  290    In this case, there are hardware bridges between the processor and FPGA that
  291    need to be controlled during full reconfiguration.  Before the overlay is
  292    applied, the live DT must include the FPGA Manager, FPGA Bridges, and a
  293    FPGA Region.  The FPGA Region is the child of the bridge that allows
  294    register access to the FPGA.  Additional bridges may be listed in a
  295    fpga-bridges property in the FPGA region or in the device tree overlay.
  296 
  297  * Partial reconfiguration with bridges in the FPGA
  298    In this case, the FPGA will have one or more PRR's that may be programmed
  299    separately while the rest of the FPGA can remain active.  To manage this,
  300    bridges need to exist in the FPGA that can gate the buses going to each FPGA
  301    region while the buses are enabled for other sections.  Before any partial
  302    reconfiguration can be done, a base FPGA image must be loaded which includes
  303    PRR's with FPGA bridges.  The device tree should have an FPGA region for each
  304    PRR.
  305 
  306 Device Tree Examples
  307 ====================
  308 
  309 The intention of this section is to give some simple examples, focusing on
  310 the placement of the elements detailed above, especially:
  311  * FPGA Manager
  312  * FPGA Bridges
  313  * FPGA Region
  314  * ranges
  315  * target-path or target
  316 
  317 For the purposes of this section, I'm dividing the Device Tree into two parts,
  318 each with its own requirements.  The two parts are:
  319  * The live DT prior to the overlay being added
  320  * The DT overlay
  321 
  322 The live Device Tree must contain an FPGA Region, an FPGA Manager, and any FPGA
  323 Bridges.  The FPGA Region's "fpga-mgr" property specifies the manager by phandle
  324 to handle programming the FPGA.  If the FPGA Region is the child of another FPGA
  325 Region, the parent's FPGA Manager is used.  If FPGA Bridges need to be involved,
  326 they are specified in the FPGA Region by the "fpga-bridges" property.  During
  327 FPGA programming, the FPGA Region will disable the bridges that are in its
  328 "fpga-bridges" list and will re-enable them after FPGA programming has
  329 succeeded.
  330 
  331 The Device Tree Overlay will contain:
  332  * "target-path" or "target"
  333    The insertion point where the contents of the overlay will go into the
  334    live tree.  target-path is a full path, while target is a phandle.
  335  * "ranges"
  336     The address space mapping from processor to FPGA bus(ses).
  337  * "firmware-name"
  338    Specifies the name of the FPGA image file on the firmware search
  339    path.  The search path is described in the firmware class documentation.
  340  * "partial-fpga-config"
  341    This binding is a boolean and should be present if partial reconfiguration
  342    is to be done.
  343  * child nodes corresponding to hardware that will be loaded in this region of
  344    the FPGA.
  345 
  346 Device Tree Example: Full Reconfiguration without Bridges
  347 =========================================================
  348 
  349 Live Device Tree contains:
  350         fpga_mgr0: fpga-mgr@f8007000 {
  351                 compatible = "xlnx,zynq-devcfg-1.0";
  352                 reg = <0xf8007000 0x100>;
  353                 interrupt-parent = <&intc>;
  354                 interrupts = <0 8 4>;
  355                 clocks = <&clkc 12>;
  356                 clock-names = "ref_clk";
  357                 syscon = <&slcr>;
  358         };
  359 
  360         fpga_region0: fpga-region0 {
  361                 compatible = "fpga-region";
  362                 fpga-mgr = <&fpga_mgr0>;
  363                 #address-cells = <0x1>;
  364                 #size-cells = <0x1>;
  365                 ranges;
  366         };
  367 
  368 DT Overlay contains:
  369 
  370 /dts-v1/;
  371 /plugin/;
  372 
  373 &fpga_region0 {
  374         #address-cells = <1>;
  375         #size-cells = <1>;
  376 
  377         firmware-name = "zynq-gpio.bin";
  378 
  379         gpio1: gpio@40000000 {
  380                 compatible = "xlnx,xps-gpio-1.00.a";
  381                 reg = <0x40000000 0x10000>;
  382                 gpio-controller;
  383                 #gpio-cells = <0x2>;
  384                 xlnx,gpio-width= <0x6>;
  385         };
  386 };
  387 
  388 Device Tree Example: Full Reconfiguration to add PRR's
  389 ======================================================
  390 
  391 The base FPGA Region is specified similar to the first example above.
  392 
  393 This example programs the FPGA to have two regions that can later be partially
  394 configured.  Each region has its own bridge in the FPGA fabric.
  395 
  396 DT Overlay contains:
  397 
  398 /dts-v1/;
  399 /plugin/;
  400 
  401 &fpga_region0 {
  402         #address-cells = <1>;
  403         #size-cells = <1>;
  404 
  405         firmware-name = "base.rbf";
  406 
  407         fpga-bridge@4400 {
  408                 compatible = "altr,freeze-bridge-controller";
  409                 reg = <0x4400 0x10>;
  410 
  411                 fpga_region1: fpga-region1 {
  412                         compatible = "fpga-region";
  413                         #address-cells = <0x1>;
  414                         #size-cells = <0x1>;
  415                         ranges;
  416                 };
  417         };
  418 
  419         fpga-bridge@4420 {
  420                 compatible = "altr,freeze-bridge-controller";
  421                 reg = <0x4420 0x10>;
  422 
  423                 fpga_region2: fpga-region2 {
  424                         compatible = "fpga-region";
  425                         #address-cells = <0x1>;
  426                         #size-cells = <0x1>;
  427                         ranges;
  428                 };
  429         };
  430 };
  431 
  432 Device Tree Example: Partial Reconfiguration
  433 ============================================
  434 
  435 This example reprograms one of the PRR's set up in the previous example.
  436 
  437 The sequence that occurs when this overlay is similar to the above, the only
  438 differences are that the FPGA is partially reconfigured due to the
  439 "partial-fpga-config" boolean and the only bridge that is controlled during
  440 programming is the FPGA based bridge of fpga_region1.
  441 
  442 /dts-v1/;
  443 /plugin/;
  444 
  445 &fpga_region1 {
  446         #address-cells = <1>;
  447         #size-cells = <1>;
  448 
  449         firmware-name = "soc_image2.rbf";
  450         partial-fpga-config;
  451 
  452         gpio@10040 {
  453                 compatible = "altr,pio-1.0";
  454                 reg = <0x10040 0x20>;
  455                 clocks = <0x2>;
  456                 altr,ngpio = <0x4>;
  457                 #gpio-cells = <0x2>;
  458                 gpio-controller;
  459         };
  460 };
  461 
  462 Constraints
  463 ===========
  464 
  465 It is beyond the scope of this document to fully describe all the FPGA design
  466 constraints required to make partial reconfiguration work[1] [2] [3], but a few
  467 deserve quick mention.
  468 
  469 A persona must have boundary connections that line up with those of the partion
  470 or region it is designed to go into.
  471 
  472 During programming, transactions through those connections must be stopped and
  473 the connections must be held at a fixed logic level.  This can be achieved by
  474 FPGA Bridges that exist on the FPGA fabric prior to the partial reconfiguration.
  475 
  476 --
  477 [1] www.altera.com/content/dam/altera-www/global/en_US/pdfs/literature/ug/ug_partrecon.pdf
  478 [2] tspace.library.utoronto.ca/bitstream/1807/67932/1/Byma_Stuart_A_201411_MAS_thesis.pdf
  479 [3] https://www.xilinx.com/support/documentation/sw_manuals/xilinx14_1/ug702.pdf

Cache object: 1e8c2dc9c169f717eee50a873d1d1b3b


[ source navigation ] [ diff markup ] [ identifier search ] [ freetext search ] [ file search ] [ list types ] [ track identifier ]


This page is part of the FreeBSD/Linux Linux Kernel Cross-Reference, and was automatically generated using a modified version of the LXR engine.