

# **AN 826: Hierarchical Partial Reconfiguration Tutorial**

for Intel® Stratix® 10 GX FPGA Development Board

Updated for Intel® Quartus® Prime Design Suite: 20.3



AN-826 | 2021.01.05 Latest document on the web: PDF | HTML



#### **Contents**

| lierarchical Partial Reconfiguration Tutorial for Intel <sup>®</sup> Stratix <sup>®</sup> 10 GX FPGA  Development Board | -  |
|-------------------------------------------------------------------------------------------------------------------------|----|
| Reference Design Requirements                                                                                           |    |
| Reference Design Overview                                                                                               |    |
| Reference Design Files                                                                                                  |    |
| Reference Design Walkthrough                                                                                            |    |
| Step 1: Getting Started                                                                                                 |    |
| Step 2: Creating a Child Level Sub-module                                                                               |    |
| Step 3: Creating Design Partitions                                                                                      |    |
| Step 4: Allocating Placement and Routing Region for PR Partitions                                                       |    |
| Step 5: Defining Personas                                                                                               |    |
| Step 6: Creating Revisions                                                                                              |    |
| Step 7: Compiling the Base Revision                                                                                     |    |
| Step 8: Preparing the PR Implementation Revisions for Parent PR Partition                                               |    |
| Step 9: Preparing the PR Implementation Revisions for Child PR Partitions                                               |    |
| Step 10: Programming the Board                                                                                          |    |
| Modifying an Existing Persona                                                                                           |    |
| Adding a New Persona to the Design                                                                                      |    |
| Document Revision History for AN 826: Hierarchical Partial Reconfiguration Tutorial for                                 |    |
| Intel Stratix 10 GX FPGA Development Board                                                                              | 22 |







## Hierarchical Partial Reconfiguration Tutorial for Intel® Stratix® 10 GX FPGA Development Board

This application note demonstrates transformation of a simple design into a hierarchical partial reconfiguration design and implementation of the design on the Intel® Stratix® 10 GX FPGA development board.

The partial reconfiguration (PR) feature allows you to reconfigure a portion of the FPGA dynamically, while the remaining FPGA design continues to function. Hierarchical partial reconfiguration (HPR) is an extension of partial reconfiguration (PR) that allows you to contain a child PR partition within another parent PR partition. You can create multiple personas for both the child and parent partitions. You can nest the child partitions within their parent partitions. Reconfiguring a parent partition does not impact the operation in the static region, but replaces the child partitions of the parent region with default child partition personas. This methodology is effective in systems where multiple functions time-share the same FPGA device resources.

Partial reconfiguration provides the following advancements to a flat design:

- Allows run-time design reconfiguration
- Increases scalability of the design
- Reduces system down-time
- Supports dynamic time-multiplexing functions in the design
- Lowers cost and power consumption through efficient use of board space

Implementation of this reference design requires basic familiarity with the Intel Quartus® Prime FPGA implementation flow and knowledge of the primary Intel Quartus Prime project files. This tutorial uses the Intel Stratix 10 GX FPGA development board on the bench, outside of the PCIe\* slot in your workstation.

#### **Related Information**

- Intel Stratix 10 FPGA Development Kit User Guide
- Intel Quartus Prime Pro Edition User Guide: Partial Reconfiguration

#### **Reference Design Requirements**

This reference design requires the following:

- Intel Quartus Prime Pro Edition software version 20.3 for the design implementation.
- Intel Stratix 10 GX FPGA development kit (DK-DEV-1SGX-L-A or DK-DEV-1SGX-H-A) for the FPGA implementation.

Intel Corporation. All rights reserved. Agilex, Altera, Arria, Cyclone, Enpirion, Intel, the Intel logo, MAX, Nios, Quartus and Stratix words and logos are trademarks of Intel Corporation or its subsidiaries in the U.S. and/or other countries. Intel warrants performance of its FPGA and semiconductor products to current specifications in accordance with Intel's standard warranty, but reserves the right to make changes to any products and services at any time without notice. Intel assumes no responsibility or liability arising out of the application or use of any information, product, or service described herein except as expressly agreed to in writing by Intel. Intel customers are advised to obtain the latest version of device specifications before relying on any published information and before placing orders for products or services.

ISO 9001:2015 Registered



#### **Reference Design Overview**

This reference design consists of one 32-bit counter. At the board level, the design connects the clock to a 50MHz source, and connects the output to four LEDs connected to the FPGA. Selecting the output from particular counter bits causes the LEDs to blink at a specific frequency.

Figure 1. Flat Reference Design without PR Partitioning



#### **Reference Design Files**

The partial reconfiguration tutorial reference design is available in the following location:

https://github.com/intel/fpga-partial-reconfig

To download the tutorial:

- 1. Click Clone or download.
- 2. Click **Download ZIP**. Unzip the fpga-partial-reconfig-master.zip file.
- 3. Navigate to the tutorials/s10\_pcie\_devkit\_blinking\_led\_hpr sub-folder to access the reference design.

The flat folder consists of the following files:

**Table 1.** Reference Design Files

| File Name        | Description                                                                                                                                                             |
|------------------|-------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| top.sv           | Top-level file containing the flat implementation of the design. This module instantiates the blinking_led sub-partition and the top_counter module.                    |
| top_counter.sv   | Top-level 32-bit counter that controls LED[1] directly. The registered output of the counter controls LED[0], and powers LED[2] and LED[3] via the blinking_led module. |
| blinking_led.sdc | Defines the timing constraints for the project.                                                                                                                         |
|                  | continued                                                                                                                                                               |





| File Name        | Description                                                                                                                                                              |
|------------------|--------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| blinking_led.sv  | In this tutorial, you convert this module into a parent PR partition. The module receives the registered output of top_counter module, which controls LED[2] and LED[3]. |
| blinking_led.qpf | Intel Quartus Prime project file containing the list of all the revisions in the project.                                                                                |
| blinking_led.qsf | Intel Quartus Prime settings file containing the assignments and settings for the project.                                                                               |

Note:

The  $\mathtt{hpr}$  folder contains the complete set of files you create using this application note. Reference these files at any point during the walkthrough.

Figure 2. Reference Design Files







#### Reference Design Walkthrough

The following steps describe the application of partial reconfiguration to a flat design. The tutorial uses the Intel Quartus Prime Pro Edition software for the Intel Stratix 10 GX FPGA development board:

- Step 1: Getting Started on page 6
- Step 2: Creating a Child Level Sub-module on page 6
- Step 3: Creating Design Partitions on page 8
- Step 4: Allocating Placement and Routing Region for PR Partitions on page 9
- Step 5: Defining Personas on page 10
- Step 6: Creating Revisions on page 12
- Step 7: Compiling the Base Revision on page 14
- Step 8: Preparing the PR Implementation Revisions for Parent PR Partition on page 15
- Step 9: Preparing the PR Implementation Revisions for Child PR Partitions on page 17
- Step 10: Programming the Board on page 20

Note:

Unlike AN 806: Hierarchical Partial Reconfiguration a Design Tutorial for Intel Arria® 10 GX FPGA Development Board, this tutorial does not require the addition of a Partial Reconfiguration Controller IP core. This difference is because Intel Stratix 10 supports PR over JTAG using the hard JTAG pins of the FPGA.

#### **Related Information**

AN 806: Hierarchical Partial Reconfiguration a Design Tutorial for Intel Arria 10 GX FPGA Development Board

#### **Step 1: Getting Started**

To copy the reference design files to your working environment and compile the blinking\_led flat design:

- Create a directory in your working environment, s10\_pcie\_devkit\_blinking\_led\_hpr.
- Copy the downloaded tutorials/s10\_pcie\_devkit\_blinking\_led\_hpr/ flat sub-folder to the directory, s10\_pcie\_devkit\_blinking\_led\_hpr.
- 3. In the Intel Quartus Prime Pro Edition software, click **File ➤ Open Project** and select blinking\_led.qpf.
- 4. To elaborate the hierarchy of the flat design, click Processing ➤ Start ➤ Start Analysis & Synthesis. Alternatively, at the command-line, run the following command:

quartus\_syn blinking\_led -c blinking\_led

#### Step 2: Creating a Child Level Sub-module

To convert the flat design into a hierarchical PR design, you create a child sub-module (blinking\_led\_child.sv) within the parent sub-module (blinking\_led.sv).





 Create a new design file, blinking\_led\_child.sv, and add the following lines of code to this file:

```
`timescale 1 ps / 1 ps
`default_nettype none

module blinking_led_child (

    // clock
    input wire clock,
    input wire [31:0] counter,

    // Control signals for the LEDs
    output wire led_three_on

);
    localparam COUNTER_TAP = 23;
    reg led_three_on_r;
    assign led_three_on = led_three_on_r;

always_ff @(posedge clock) begin
        led_three_on_r <= counter[COUNTER_TAP];
    end

endmodule</pre>
```

2. Modify blinking\_led.sv to connect led\_two\_on to bit 23 of the counter from the static region, and instantiate the blinking\_led\_child module. blinking\_led.sv must appear as follows:

```
`timescale 1 ps / 1 ps
`default_nettype none
module blinking_led(
   // clock
   input wire clock,
   input wire [31:0] counter,
   // Control signals for the LEDs
   output wire led_two_on,
   output wire led_three_on
   localparam COUNTER_TAP = 23;
   reg led_two_on_r;
   assign led_two_on
                       = led_two_on_r;
   // The counter:
   always_ff @(posedge clock) begin
         led_two_on_r <= counter[COUNTER_TAP];</pre>
   end
   \verb|blinking_led_child| u_blinking_led_child| (
         .led_three_on
                                 (led_three_on),
         .counter
                                  (counter),
         .clock
                                 (clock)
   );
endmodule
```

- 3. Save all files, retaining the **Add file to current project** option.
- 4. Click Processing ➤ Start ➤ Start Analysis & Synthesis





#### **Step 3: Creating Design Partitions**

You must create design partitions for each PR region that you want to partially reconfigure. You can create any number of independent partitions or PR regions in your design. This tutorial creates two design partitions for the u blinking led child and u blinking led instances.

To create design partitions for hierarchical partial reconfiguration:

 Right-click the u\_blinking\_led\_child instance in the Project Navigator and click Design Partition ➤ Reconfigurable.

#### Figure 3. Create Design Partition



- 2. Click **Assignments** ➤ **Design Partitions Window**. The window displays all design partitions in the project.
- 3. Edit the default partition name in the Design Partitions Window by double-clicking the name. Rename the partition to pr partition.
- 4. Repeat steps 1 and 2 to assign reconfigurable design partitions to the u blinking led instance. Rename this partition to pr parent partition.
- 5. In the Design Partitions Window, click (...) at the farthest right column header and enable the **Post Final Export File** column.
- 6. To export the finalized static region from the base revision compile, double-click the entry for root\_partition in the **Post Final Export File** column, and type blinking\_led\_static.qdb. This file is for the subsequent PR implementation compiles.
- 7. To export the finalized parent PR partition from the base revision compile, double-click the entry for pr\_parent\_partition in **Post Final Export File**, and type pr\_parent\_partition\_default\_final.qdb. This file is for the subsequent PR implementation compiles.





#### Figure 4. Design Partitions Window



Verify that the blinking\_led.qsf contains the following assignments, corresponding to your reconfigurable design partitions:

#### Step 4: Allocating Placement and Routing Region for PR Partitions

When you create the base revision, the PR design flow uses your PR partition region allocation to place the corresponding persona core in the reserved region. To locate and assign the PR region in the device floorplan for your base revision:

- Right-click the u\_blinking\_led\_child instance in the Project Navigator and click Logic Lock Region ➤ Create New Logic Lock Region. The region appears on the Logic Lock Regions Window.
- 2. Specify a region **Width** of 13 and **Height** of 6.
- 3. Specify the placement region coordinates for blinking\_led\_child in the **Origin** column. The origin corresponds to the lower-left corner of the region. Specify the **Origin** as X174\_Y415. The Compiler calculates (X187\_Y421) as the top-right coordinate.

Note: This tutorial uses the (X1 Y1) co-ordinates - (174 415), a height of 6 and a width of 13 for the placement region. Define any value for the placement region. Ensure that the region covers the blinking\_led\_child logic.

- 4. Enable the **Reserved** and **Core-Only** options.
- Double-click the Routing Region option. The Logic Lock Routing Region Settings dialog box appears.
- 6. Select **Fixed with expansion** for the **Routing type**. Selecting this option automatically assigns an expansion length of 1. The routing region must be larger than the placement region to accommodate the routing of different personas.
- 7. Repeat steps 1 -6 for the u\_blinking\_led instance. The parent-level placement region must fully enclose the corresponding child-level placement and routing regions, while allowing sufficient space for the parent-level logic placement. Specify a **Height** of 6, and **Width** of 17. Specify the **Origin** as X173 Y411. The Compiler calculates the top-right coordinate.

AN-826 | 2021.01.05

Figure 5. Logic Lock Regions Window

| X<br>3 | Region Name          | Members                             | Width | Height | Origin    | Reserved | Core-Only | Size/State   | Routing Region         |
|--------|----------------------|-------------------------------------|-------|--------|-----------|----------|-----------|--------------|------------------------|
| 1      | ∆ Logic Lock Regions |                                     |       |        |           |          |           |              |                        |
| :      | u_blinking_led       | u_blinking_led                      | 17    | 6      | X173_Y411 | On       | On        | Fixed/Locked | Fixed with expansion 1 |
| Ą      | u_blinking_led_child | u_blinking_led u_blinking_led_child | 13    | 6      | X174_Y415 | On       | On        | Fixed/Locked | Fixed with expansion 1 |
| ٩      | < <new>&gt;</new>    |                                     |       |        |           |          |           |              |                        |
| Logic  |                      |                                     |       |        |           |          |           |              |                        |
| 2      | 1                    |                                     |       |        |           |          |           |              | <b>&gt;</b>            |

Verify that the blinking\_led.qsf contains the following assignments, corresponding to your floorplanning:

```
set_instance_assignment -name PLACE_REGION "X174 Y415 X186 Y420" -to \
     u_blinking_led|u_blinking_led_child
set_instance_assignment -name RESERVE_PLACE_REGION ON \
     -to u_blinking_led|u_blinking_led_child
set_instance_assignment -name CORE_ONLY_PLACE_REGION ON -to \
     u_blinking_led|u_blinking_led_child
set_instance_assignment -name REGION_NAME u_blinking_led_child -to \
    u\_blinking\_led | u\_blinking\_led\_child
set instance assignment -name ROUTE REGION "X173 Y414 X187 Y421" -to \
     u_blinking_led|u_blinking_led_child
set_instance_assignment -name RESERVE_ROUTE_REGION OFF -to \
     u\_blinking\_led | u\_blinking\_led\_child
set_instance_assignment -name PLACE_REGION "X173 Y411 X189 Y416" \
     -to u_blinking_led
set_instance_assignment -name RESERVE_PLACE_REGION ON -to \
     u_blinking_led
set_instance_assignment -name CORE_ONLY_PLACE_REGION ON -to \
    u_blinking_led
set_instance_assignment -name REGION_NAME u_blinking_led -to \
     u_blinking_led
set_instance_assignment -name ROUTE_REGION "X172 Y410 X190 Y417" -to \
    u_blinking_led
```

#### **Related Information**

- Floorplan the Partial Reconfiguration Design
- Applying Floorplan Constraints Incrementally

#### **Step 5: Defining Personas**

This reference design defines five separate personas for the parent and child PR partitions. To define and include the personas in your project:

1. Create four SystemVerilog files, blinking\_led\_child.sv, blinking\_led\_child\_slow.sv, blinking\_led\_child\_empty.sv, and blinking\_led\_slow.sv in your working directory for the five personas.

Note: If you create the SystemVerilog files from the Intel Quartus Prime Text Editor, disable the **Add file to current project** option when saving the files.

**Table 2.** Reference Design Personas

| File Name             | Description                                       | Code                                                                                                                                                 |
|-----------------------|---------------------------------------------------|------------------------------------------------------------------------------------------------------------------------------------------------------|
| blinking_led_child.sv | Default persona<br>for the child-<br>level design | <pre>`timescale 1 ps / 1 ps `default_nettype none  module blinking_led_child (     // clock    input wire clock,    input wire [31:0] counter,</pre> |
|                       |                                                   | continued                                                                                                                                            |





| File Name                   | Description                 | Code                                                                                                                                                                                                                                                                                                                                                                                                                                                   |
|-----------------------------|-----------------------------|--------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
|                             |                             | <pre>// Control signals for the LEDs output wire led_three_on );   localparam COUNTER_TAP = 23;   reg led_three_on_r;   assign led_three_on = led_three_on_r;   always_ff @(posedge clock) begin     led_three_on_r &lt;= counter[COUNTER_TAP];   end endmodule</pre>                                                                                                                                                                                  |
| blinking_led_child_slow.sv  | The LED_THREE blinks slower | <pre>`timescale 1 ps / 1 ps `default_nettype none  module blinking_led_child_slow (     // clock     input wire clock,     input wire [31:0] counter,     // Control signals for the LEDs     output wire led_three_on );  localparam COUNTER_TAP = 27;     reg led_three_on_r;     assign led_three_on = led_three_on_r;  always_ff @(posedge clock) begin     led_three_on_r &lt;= counter[COUNTER_TAP];     end endmodule</pre>                     |
| blinking_led_child_empty.sv | The LED_THREE stays ON      | <pre>`timescale 1 ps / 1 ps `default_nettype none  module blinking_led_child_empty (     // clock     input wire clock,     input wire [31:0] counter,     // Control signals for the LEDs     output wire led_three_on );     // LED is active low     assign led_three_on = 1'b0; endmodule</pre>                                                                                                                                                    |
| blinking_led_slow.sv        | The LED_TWO blinks slower.  | <pre>`timescale 1 ps / 1 ps `default_nettype none  module blinking_led_slow(     // clock     input wire clock,     input wire [31:0] counter,     // Control signals for the LEDs     output wire led_two_on,     output wire led_three_on );  localparam COUNTER_TAP = 27;  reg led_two_on_r;     assign led_two_on = led_two_on_r;  // The counter:     always_ff @(posedge clock) begin     led_two_on_r &lt;= counter[COUNTER_TAP];     end</pre> |
|                             |                             | continued                                                                                                                                                                                                                                                                                                                                                                                                                                              |



| File Name | Description | Code                                                                  |
|-----------|-------------|-----------------------------------------------------------------------|
|           |             | <pre>blinking_led_child u_blinking_led_child(     .led_three_on</pre> |

#### **Related Information**

Step 3: Creating Design Partitions on page 8

#### **Step 6: Creating Revisions**

The PR design flow uses the project revisions feature in the Intel Quartus Prime software. Your initial design is the base revision, where you define the static region boundaries and reconfigurable regions on the FPGA.

From the base revision, you create multiple revisions. These revisions contain the different implementations for the PR regions. However, all PR implementation revisions use the same top-level placement and routing results from the base revision.

To compile a PR design, you must create a PR implementation revision for each persona. In addition, you must a specify the Partial Reconfiguration - Base or Partial Reconfiguration - Persona Implementation revision type for each of the revisions.

The following lists the revision name and type for each revision you create:

#### Table 3. Revision Names and Types

| Revision Name                     | Revision Type                                    |
|-----------------------------------|--------------------------------------------------|
| blinking_led.qsf                  | Partial Reconfiguration - Base                   |
| hpr_child_default.qsf             | Partial Reconfiguration - Persona Implementation |
| hpr_child_slow.qsf                | Partial Reconfiguration - Persona Implementation |
| hpr_child_empty.qsf               | Partial Reconfiguration - Persona Implementation |
| hpr_parent_slow_child_default.qsf | Partial Reconfiguration - Persona Implementation |
| hpr_parent_slow_child_slow.qsf    | Partial Reconfiguration - Persona Implementation |

#### Table 4. Parent and Child Persona Revisions

| <b>Revision Name</b>              | Parent Persona Behavior | Child Persona Behavior  |
|-----------------------------------|-------------------------|-------------------------|
| hpr_child_default.qsf             | Fast Blinking           | Fast Blinking           |
| hpr_child_slow.qsf                | Fast Blinking           | Slow Blinking           |
| hpr_child_empty.qsf               | Fast Blinking           | No Blinking (Always ON) |
| hpr_parent_slow_child_default.qsf | Slow Blinking           | Fast Blinking           |
| hpr_parent_slow_child_slow.qsf    | Slow Blinking           | Slow Blinking           |





#### **Setting the Base Revision Type**

- 1. Click **Project** ➤ **Revisions**.
- In Revision Name, select the blinking\_led revision.
- 3. For Revision Type, select Partial Reconfiguration Base, and then click OK.
- 4. Verify that the blinking led.qsf now contains the following assignment:

```
##blinking_led.qsf
set_global_assignment -name REVISION_TYPE PR_BASE
```

#### **Creating Implementation Revisions**

- Double-click << new revision>>.
- For Revision name, specify hpr\_child\_default and select blinking\_led for Based on revision.
- 3. Select Partial Reconfiguration Persona Implementation for Revision type.

#### Figure 6. Creating Revisions



Note: You can add the static region .qdb by enabling **This project uses a**Partition Database (.qdb) file for the root partition and specifying the static region .qdb file.

- 4. Turn off **Set as current revision**.
- 5. Repeat steps 1 through 4 to create these implementation revisions:
  - hpr\_child\_slow
  - hpr\_child\_empty
  - hpr\_parent\_slow\_child\_default
  - hpr parent slow child slow





#### Figure 7. New Implementation Revisions



6. Verify that the .qsf file for each revision contains the following assignment:

```
set_global_assignment -name REVISION_TYPE PR_IMPL
set_instance_assignment -name ENTITY_REBINDING place_holder -to
u_blinking_led
```

where, place\_holder is the default entity name for the newly created PR implementation revision.

#### **Step 7: Compiling the Base Revision**

To compile the base revision, click Processing ➤ Start Compilation.
 Alternatively, the following command compiles the base revision:

```
quartus_sh --flow compile blinking_led -c blinking_led
```

2. Inspect the bitstream files generated to the output\_files directory:

#### Table 5. Generated Files

| Name                                               | Туре                                      | Description                                                                                                          |
|----------------------------------------------------|-------------------------------------------|----------------------------------------------------------------------------------------------------------------------|
| blinking_led.sof                                   | Base programming file                     | For programming the FPGA with the static logic, along with the default personas for the parent and child PR regions. |
| blinking_led.pr_parent_partit ion.rbf              | PR bitstream file for parent PR partition | For programming the default persona of the parent PR region.                                                         |
| blinking_led.pr_parent_partit ion.pr_partition.rbf | PR bitstream file for child PR partition  | For programming the default persona of the child PR region.                                                          |
| blinking_led_static.qdb                            | . qdb database file                       | Finalized database file for importing the static region.                                                             |
| <pre>pr_parent_partition_default_f inal.qdb</pre>  | . qdb database file                       | Finalized database file for importing the default parent PR partition.                                               |





## Step 8: Preparing the PR Implementation Revisions for Parent PR Partition

You must prepare the parent and child PR implementation revisions before you can generate the PR bitstream for device programming. This setup includes mapping the new PR logic to the preexisting parent PR partition.

- To set the current revision, click Project ➤ Revisions, select hpr\_parent\_slow\_child\_default as the Revision name, and then click Set Current.
- To verify the correct source for this implementation revision, click Project ➤
   Add/Remove Files in Project. The blinking\_led\_child.sv file appears in
   the file list.

Figure 8. Add/Remove Files in Project



3. Use **Add/Remove Files in Project** to add the appropriate parent and child persona source files for each implementation revision. Remove any source files that don't apply to the implementation.

| Implementation Revision Name  | Parent Persona Source File | Child Persona Source File |  |
|-------------------------------|----------------------------|---------------------------|--|
| hpr_parent_slow_child_default | blinking_led_slow.sv       | blinking_led_child.sv     |  |

4. To specify the .qdb file associated with the root partition, click Assignments > Design Partitions Window. Specify the .qdb file associated with the static region by double-clicking the Partition Database File cell and navigating to the blinking\_led\_static.qdb file.

Figure 9. Specify Partition Database File







Alternatively, the following command assigns this file:

```
set_instance_assignment -name QDB_FILE_PARTITION \
    blinking_led_static.qdb -to |
```

- 5. In the **Entity Re-binding** cell, specify the entity name for the PR parent partition. For this implementation revision, the entity name is blinking\_led\_slow. blinking\_led\_slow is the name of the entity that you are partially reconfiguring. u\_blinking\_led is the name of the instance that your entity overwrites during PR.
- 6. Verify that the following line now exists in the .qsf:

```
#hpr_parent_slow_child_default.qsf
set_instance_assignment -name ENTITY_REBINDING \
    blinking_led_slow -to u_blinking_led
```

Note: Because the child PR logic is already defined by the parent PR partition, whose entity name is rebound, do not use an entity rebinding assignment for the child PR partition.

#### Figure 10. Entity Re-binding



 To compile the design, click Processing > Start Compilation. Alternatively, the following command compiles this project:

```
quartus_sh --flow compile blinking_led -c hpr_parent_slow_child_default
```

8. To export this new parent PR partition as a finalized .qdb file, click **Project** > **Export Design Partition**. Specify the following options for the partition:

#### Table 6. Export Design Partition Options

| Option                         | Setting                                                                     |
|--------------------------------|-----------------------------------------------------------------------------|
| Partition name                 | pr_parent_partition                                                         |
| Partition database file        | <pre><pre><pre><pre>parent_partition_slow_final.qdb</pre></pre></pre></pre> |
| Include entity-bound SDC files | Enable                                                                      |
| Snapshot                       | Final                                                                       |

Alternatively, the following command exports the parent PR region:

```
quartus_cdb -r blinking_led -c blinking led --export_block root_partition \
    --snapshot final --file --include_sdc_entity_in_partition \
    pr_parent_partition_slow_final.qdb
```

9. Inspect the files generated to the output\_files directory:





**Table 7. Generated Files** 

| Name                                                               | Туре                                        | Description                                                                                                        |
|--------------------------------------------------------------------|---------------------------------------------|--------------------------------------------------------------------------------------------------------------------|
| hpr_parent_slow_child_default.pr_parent_partitio n.rbf             | PR bitstream file for parent PR partition   | For programing the default persona for the parent PR region. Causes the led_two_on to blink at a lower rate.       |
| hpr_parent_slow_child_default.pr_parent_partition.pr_partition.rbf | PR bitstream file for child<br>PR partition | For programming the default persona for the child PR region. Causes the led_three_on to blink at the default rate. |
| pr_parent_partition_slow_final.qdb                                 | Finalized .qdb database file                | For import of the slow parent PR partition.                                                                        |

#### Step 9: Preparing the PR Implementation Revisions for Child PR Partitions

This setup includes adding the static region .qdb file as the source file for each implementation revision. In addition, you must import the parent PR partition .qdb file and specify the corresponding entity of the PR region.

- To set the current revision, click Project ➤ Revisions, select hpr\_child\_default
  as the Revision name, and then click Set Current.
- To specify the correct child persona source file for each implementation revision, click Project ➤ Add/Remove Files in Project. Verify that blinking\_led\_child.sv appears in the file list.

Figure 11. Add/Remove Files in Project



3. Repeat steps 1 through 2 to specify the following child persona source files for the other implementation revisions:



#### **Table 8.** Implementation Revision Source Files

| Implementation Revision Name | Child Persona Source File   |
|------------------------------|-----------------------------|
| hpr_child_default            | blinking_led_child.sv       |
| hpr_child_slow               | blinking_led_child_slow.sv  |
| hpr_child_empty              | blinking_led_child_empty.sv |
| hpr_parent_slow_child_slow   | blinking_led_child_slow.sv  |

4. To verify the .qdb file associated with the root partition, click Assignments ➤ Design Partitions Window. Specify the .qdb file associated with the static region by double-clicking the Partition Database File cell and navigating to the blinking\_led\_static.qdb file.

#### Figure 12. Specify Partition Database File



Alternatively, the following command assigns this file:

```
set_instance_assignment -name QDB_FILE_PARTITION \
    blinking_led_static.qdb -to |
```

5. To specify the parent PR partition .qdb file, click Assignments ➤ Design Partitions Window. Double-click the Partition Database File for the pr\_parent\_partition and specify the respective .qdb file in the project directory.

#### Table 9. Specify the Parent PR Partition .qdb File

| Implementation Revision Name | Parent Persona .qdb File              |
|------------------------------|---------------------------------------|
| hpr_child_default            | pr_parent_partition_default_final.qdb |
| hpr_child_slow               | pr_parent_partition_default_final.qdb |
| hpr_child_empty              | pr_parent_partition_default_final.qdb |
| hpr_parent_slow_child_slow   | pr_parent_partition_slow_final.qdb    |

#### verify the following line exists in the .qsf:

```
# To use the default parent PR persona:
set_instance_assignment -name QDB_FILE_PARTITION \
    pr_parent_partition_default_final.qdb -to u_blinking_led

# To use the slow parent PR persona:
set_instance_assignment -name QDB_FILE_PARTITION \
    pr_parent_partition_slow_final.qdb -to u_blinking_led
```

6. In the **Entity Re-binding** cell, specify the entity name of the child PR partition. For the default persona, the entity name is blinking\_led. For this implementation revision, blinking\_led\_child is the name of the entity that





you are partially reconfiguring.  $u\_blinking\_led|u\_blinking\_led\_child$  is the name of the instance that your entity overwrites during PR. Verify that the following line now exists in the .qsf:

#### Figure 13. Entity Rebinding Assignment



7. To compile the design, click **Processing** > **Start Compilation**. Alternatively, the following command compiles this project:

```
quartus_sh --flow compile blinking_led -c hpr_child_default
```

Repeat the above steps to prepare hpr\_child\_slow, hpr\_child\_empty, and hpr parent slow child slow revisions.

Note: You can specify any Fitter specific settings that you want to apply during the PR implementation compilation. Fitter specific settings impact only the fit of the persona, without affecting the imported static region.

9. Inspect the bitstream files generated to the output\_files directory.

Note: Since you imported the parent PR partition as a finalized .qdb file, and used entity-rebinding only on the child PR region, the software generates the PR bitstream only for the child PR partition.

Verify that the output\_files directory contains the following generated .rbf files after compiling all the implementation revisions:

- hpr\_child\_default.pr\_parent\_partition.pr\_partition.rbf
- hpr\_child\_slow.pr\_parent\_partition.pr\_partition.rbf
- hpr\_child\_empty.pr\_parent\_partition.pr\_partition.rbf
- hpr\_parent\_slow\_child\_slow.pr\_parent\_partition.pr\_partition .rbf



#### **Step 10: Programming the Board**

#### Before you begin:

- 1. Connect the power supply to the Intel Stratix 10 GX FPGA development board.
- 2. Connect the Intel FPGA Download Cable between your PC USB port and the Intel FPGA Download Cable port on the development board.

Note:

This tutorial utilizes the Intel Stratix 10 GX FPGA development board on the bench, outside of the PCIe slot in your host machine.

To run the design on the Intel Stratix 10 GX FPGA development board:

- 1. Open the Intel Quartus Prime software and click **Tools** ➤ **Programmer**.
- 2. In the Programmer, click **Hardware Setup** and select **USB-Blaster**.
- 3. Click **Auto Detect** and select the appropriate device for your development kit.
- 4. Click **OK**. The Intel Quartus Prime software detects and updates the Programmer with the three FPGA chips on the board.
- 5. Select the Intel Stratix 10 GX device, click **Change File** and load the blinking led.sof file.
- 6. Enable **Program/Configure** for blinking\_led.sof file.
- 7. Click **Start** and wait for the progress bar to reach 100%.
- 8. Observe the LEDs on the board blinking at the same frequency as the original flat design.
- 9. To program only the child PR region, right-click the blinking\_led.sof file in the Programmer and click **Add PR Programming File**.
- 10. Select the hpr child slow.pr parent partition.pr partition.rbf file.
- 11. Disable Program/Configure for blinking\_led.sof file.
- 12. Enable **Program/Configure** for hpr\_child\_slow.pr\_parent\_partition.pr\_partition.rbf file and click **Start**. On the board, observe LED[0] and LED[1] continuing to blink. When the progress bar reaches 100%, LED[2] blinks at the same rate, and LED[3] blinks slower.
- 13. To program both the parent and child PR region, right-click the .rbf file in the Programmer and click **Change PR Programing File**.
- 14. Select the hpr\_parent\_slow\_child\_slow.pr\_parent\_partition.rbf file.
- 15. Click **Start**. On the board, observe that LED[0] and LED[1] continuing to blink. When the progress bar reaches 100%, both LED[2] and LED[3] blink slower.
- 16. Repeat the above steps to dynamically re-program just the child PR region, or both the parent and child PR regions simultaneously.





Figure 14. Programming the Intel Stratix 10 GX FPGA Development Board



If you face any PR programming errors, refer to the *Avoiding PR Programming Errors* section in the Partial Reconfiguration User Guide.

#### **Related Information**

**Avoiding PR Programming Errors** 

#### **Programming the Child PR Region**

The current version of the Intel Quartus Prime Pro Edition software does not provide a mechanism to check for incompatible child PR bitstreams for Intel Stratix 10 devices. So, it is very important that you program the correct child persona to match the parent persona. Programming an incompatible bitstream on Intel Stratix 10 FPGA can result in one of the following:

- Successful PR programming, but corrupted FPGA functionality
- Unsuccessful PR programming, and corrupted FPGA functionality

If you wish to reprogram a child PR region on the FPGA, you must ensure that the child PR .rbf is generated from an implementation revision compile whose parent PR persona matches the persona currently on the FPGA. For example, when you program the base blinking\_led.sof onto the FPGA, the parent PR persona is default. The child PR persona is default as well. To change the child PR persona to slow persona, you have the choice of using the following bitstreams:

- 1. hpr\_child\_slow.pr\_parent\_partition.pr\_partition.rbf
- hpr\_parent\_slow\_child\_slow.pr\_parent\_partition.pr\_partition.rb





In this case, you must choose the

hpr\_child\_slow.pr\_parent\_partition.pr\_partition.rbf bitstream, because the hpr\_child\_slow.pr\_parent\_partition.pr\_partition.rbf is generated by an implementation revision that has the default parent persona. Choosing

hpr\_parent\_slow\_child\_slow.pr\_parent\_partition.pr\_partition.rbf results in unsuccessful PR programming, corrupted FPGA functionality, or both.

#### **Modifying an Existing Persona**

You can change an existing persona, even after fully compiling the base revision.

For example, to cause the blinking\_led\_child\_slow persona to blink even slower:

- In the blinking\_led\_child\_slow.sv file, modify the COUNTER\_TAP parameter from 27 to 28.
- 2. Recompile any implementation revision that uses this source file, such as hpr\_child\_slow or hpr\_parent\_slow\_child\_slow.
- 3. Regenerate the PR bitstreams from the .pmsf files.
- 4. Follow the steps in Step 10: Programming the Board on page 20 to program the resulting RBF file into the FPGA.

#### Adding a New Persona to the Design

After fully compiling your base revisions, you can still add new personas and individually compile these personas.

For example, to define a new persona that causes led\_two (parent) to blink at a slower rate, while keeping led three (child) on:

- 1. Create an implementation revision, hpr\_parent\_slow\_child\_empty, by following the steps in Creating Implementation Revisions on page 13.
- 2. Compile the revision by clicking **Processing** ➤ **Start Compilation**.

#### **Related Information**

- Creating a Partial Reconfiguration Design
- Partial Reconfiguration Online Training

## Document Revision History for AN 826: Hierarchical Partial Reconfiguration Tutorial for Intel Stratix 10 GX FPGA Development Board

| <b>Document Version</b> | Intel Quartus Prime<br>Version | Changes                                                                                                                                                                                                                                                                                                                |
|-------------------------|--------------------------------|------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| 2021.01.05              | 20.3                           | <ul> <li>Updated Intel Quartus Prime software version number in "Reference Design Requirements" topic.</li> <li>Updated figures in "Step 3: Creating a Design Partition" topic.</li> <li>Updated figures and QSF assignments in "Step 4: Allocating Placement and Routing Region for a PR Partition" topic.</li> </ul> |
|                         |                                | continued                                                                                                                                                                                                                                                                                                              |



### Hierarchical Partial Reconfiguration Tutorial for Intel® Stratix® 10 GX FPGA Development Board AN-826 | 2021.01.05



| <b>Document Version</b> | Intel Quartus Prime<br>Version | Changes                                                                                                                                                                                                                                                                                                                                                                                                     |
|-------------------------|--------------------------------|-------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
|                         |                                | <ul> <li>Updated figures and steps in "Creating Implementation Revisions" topic.</li> <li>Corrected typo in "Step 8: Preparing PR Implementation Revisions for Parent PR Partitions" topic.</li> <li>Corrected typo in "Step 9: Preparing PR Implementation Revisions for Child PR Partitions" topic.</li> <li>Indicated support for all Intel Stratix 10 FPGA tiles.</li> </ul>                            |
| 2019.07.15              | 19.1.0                         | Changed default file export location from output_files to project directory.  Described new reserved core partition type and related GUI.  Corrected the persona type for hpr_parent_slow_child_slow.qsf in "Creating Revisions."  Updated Design Partition Window descriptions and screenshots for column display button and new partition properties.                                                     |
| 2018.09.24              | 18.1.0                         | Updated sections - Step 3: Creating Design Partitions, Step 8: Compiling the Base Revision, Step 8: Preparing the PR Implementation Revisions for Parent PR Partition, and Step 9: Preparing the PR Implementation Revisions for Child PR Partitions with the new PR flow that eliminates the need for manual export of finalized snapshot of the static region.  Other minor text edits and image updates. |
| 2018.05.07              | 18.0.0                         | Compilation flow change     Other minor text edits                                                                                                                                                                                                                                                                                                                                                          |
| 2017.11.06              | 17.1.0                         | Initial release of the document                                                                                                                                                                                                                                                                                                                                                                             |