

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

for Intel® Arria® 10 GX FPGA Development Board

Updated for Intel® Quartus® Prime Design Suite: 20.3



AN-806 | 2021.02.04 Latest document on the web: PDF | HTML



#### **Contents**

| Hier | rarchical Partial Reconfiguration Tutorial for Intel Arria® 10 GX FPGA                |    |
|------|---------------------------------------------------------------------------------------|----|
|      | Development Board                                                                     | 3  |
|      | Reference Design Requirements                                                         | 3  |
|      | 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                                                    | 7  |
|      | Step 4: Allocating Placement and Routing Region for PR Partitions                     |    |
|      | Step 5: Adding the Partial Reconfiguration Controller IP                              |    |
|      | Step 6: Defining Personas                                                             |    |
|      | Step 7: Creating Revisions                                                            | 15 |
|      | Step 8: Compiling the Base Revision                                                   | 17 |
|      | Step 9: Preparing the PR Implementation Revisions for Parent PR Partition             | 18 |
|      | Step 10: Preparing the PR Implementation Revisions for Child PR Partitions            | 21 |
|      | Step 11: Programming the Board                                                        | 24 |
|      | Modifying an Existing Persona                                                         | 26 |
|      | Adding a New Persona to the Design                                                    | 26 |
|      | Document Revision History for Hierarchical Partial Reconfiguration Tutorial for Intel |    |
|      | Arria 10 GX FPGA Development Board                                                    | 27 |







# Hierarchical Partial Reconfiguration Tutorial for Intel Arria<sup>®</sup> 10 GX FPGA Development Board

This application note demonstrates transforming a simple design into a hierarchically partially reconfigurable design, and implementing the design on the Intel Arria $^{\otimes}$  10 GX FPGA development board.

Hierarchical partial reconfiguration (HPR) is an extension of the traditional partial reconfiguration (PR), where you contain a PR region within another PR region. You can create multiple personas for both the child and parent partitions. You 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 Arria 10 GX FPGA development board on the bench, outside of the PCIe\* slot in your workstation.

#### **Related Information**

- Intel Arria<sup>®</sup> 10 FPGA Development Kit User Guide
- Partial Reconfiguration Concepts
- Partial Reconfiguration Design Flow
- Partial Reconfiguration Design Considerations
- Partial Reconfiguration Design Guidelines

#### **Reference Design Requirements**

This reference design requires the following:

- Intel Quartus Prime Pro Edition software version 20.3 for the design implementation.
- Intel Arria 10 GX FPGA development kit 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 on the FPGA. Selecting the output from the counter bits in a specific sequence causes the LEDs to blink at a specific frequency.

Figure 1. Flat Reference Design without PR Partitioning



#### **Reference Design Files**

The partial reconfiguration tutorial 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/al0\_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 also powers LED[2] and LED[3] via the blinking_led module. |
| blinking_led.sdc | Defines the timing constraints for the project.                                                                                                                              |
| 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].     |
|                  | continued                                                                                                                                                                    |





| File Name            | Description                                                                                |
|----------------------|--------------------------------------------------------------------------------------------|
| 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. |
| prpof_id_mif_gen.tcl | Script file to enable bitstream compatibility checks for child PR regions.                 |

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 Arria 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 7
- Step 4: Allocating Placement and Routing Region for PR Partitions on page 10
- Step 5: Adding the Partial Reconfiguration Controller IP on page 11
- Step 6: Defining Personas on page 13
- Step 7: Creating Revisions on page 15
- Step 8: Compiling the Base Revision on page 17
- Step 9: Preparing the PR Implementation Revisions for Parent PR Partition on page 18
- Step 10: Preparing the PR Implementation Revisions for Child PR Partitions on page 21
- Step 11: Programming the Board on page 24

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

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

- Create a a10\_pcie\_devkit\_blinking\_led\_hpr directory in your working environment.
- Copy the downloaded tutorials/a10\_pcie\_devkit\_blinking\_led\_hpr/ flat sub-folder to the a10\_pcie\_devkit\_blinking\_led\_hpr directory.
- 3. In the Intel Quartus Prime Pro Edition software, click **File ➤ Open Project** and select blinking\_led.qpf.
- 4. To compile the flat design, click **Processing** ➤ **Start Compilation**.

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

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

 Create a new blinking\_led\_child.sv design file. 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 the blinking\_led.sv file to connect the led\_two\_on to bit 23 of the counter from the static region, and instantiate the blinking\_led\_child module. After modifications, your blinking\_led.sv file 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>
  blinking_led_child u_blinking_led_child (
        .led_three_on (led_three_on),
         .counter
                                 (counter),
         clock
                                 (clock)
   );
endmodule
```

 On modifying all the design files, recompile the project by clicking Processing ➤ Start Compilation

#### **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.



AN-806 | 2021.02.04

To create design partitions for hierarchical partial reconfiguration:

1. Right-click the u\_blinking\_led\_child instance in the **Project Navigator** and click **Design Partition** ➤ **Reconfigurable**. A design partition icon appears next to each instance that is set as a partition.

#### Figure 3. Creating Design Partitions from Project Navigator



2. Repeat step 1 to assign a reconfigurable design partition to the u\_blinking\_led instance.

Note: When you create a partition, the Intel Quartus Prime software automatically generates a partition name, based on the instance name and hierarchy path. This default partition name varies with each instance.

 To view and edit all design partitions in the project, click Assignments ➤ Design Partitions Window. The design partition appears on the Assignments View tab of the Design Partitions Window.

#### Figure 4. Design Partitions Window



4. Edit the blinking\_led\_child partition name in the Design Partitions Window by double-clicking the name. Rename the blinking\_led\_child partition to pr\_partition. Similarly, rename blinking\_led partition to pr\_parent\_partition.





#### Figure 5. Renaming Partitions

| Design Partitions Window |                                     |                |                    |       |                         |
|--------------------------|-------------------------------------|----------------|--------------------|-------|-------------------------|
| Assignments View         | Compilation View                    |                |                    |       |                         |
| Partition Name           | Hierarchy Path                      | Type           | Preservation Level | Empty | Partition Database File |
| < <new>&gt;</new>        |                                     |                |                    |       |                         |
| root_partition           |                                     |                |                    |       |                         |
| pr_partition             | u_blinking_led u_blinking_led_child | Reconfigurable | Not Set            | No    |                         |
| pr_parent_partition      | u_blinking_led                      | Reconfigurable | Not Set            | No    |                         |

- 5. To display the **Post Final Export File** column, click the **(...)** button next to the far right column in Design Partitions Window.
- 6. To export the finalized static region from the base revision compile, double-click the **Post Final Export File** cell for the root\_partition, and then type blinking\_led\_static.qdb. You use this file for the PR implementation revision compilation later.
- 7. To export the finalized parent PR partition from the base revision compile, double-click the **Post Final Export File** cell for the pr\_parent\_partition, and then type pr\_parent\_partition\_default\_final.qdb. You use this file for PR implementation revision compilation later.

#### Figure 6. Exporting Partitions



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

```
set_instance_assignment -name PARTITION pr_partition -to \
    u_blinking_led|u_blinking_led_child -entity top
set_instance_assignment -name PARTIAL_RECONFIGURATION_PARTITION ON -to \
    u_blinking_led|u_blinking_led_child -entity top

set_instance_assignment -name PARTITION pr_parent_partition -to \
    u_blinking_led -entity top
set_instance_assignment -name PARTIAL_RECONFIGURATION_PARTITION ON -to \
    u_blinking_led -entity top
set_instance_assignment -name EXPORT_PARTITION_SNAPSHOT_FINAL
blinking_led_static.qdb\
    -to | -entity top
set_instance_assignment -name EXPORT_PARTITION_SNAPSHOT_FINAL \
    pr_parent_partition_default_final.qdb -to \
    u_blinking_led -entity top
```



#### 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. A lock icon appears next to the instance.
- 2. In the Logic Lock Regions window, specify the placement region co-ordinates in the **Origin** column. The origin corresponds to the lower-left corner of the region. For example, to set a placement region with (X1 Y1) co-ordinates as (69 10), specify the **Origin** as X69\_Y10. The Intel Quartus Prime software automatically calculates the (X2 Y2) co-ordinates (top-right) for the placement region, based on the height and width you specify.

Note: This tutorial uses the (X1 Y1) co-ordinates - (69 10), and a height and width of 20 for the placement region. You can define any value for the placement region, provided that the region covers the blinking\_led\_child logic.

- 3. Enable the **Reserved** and **Core-Only** options.
- 4. Double-click the **Routing Region** option. The **Logic Lock Routing Region Settings** dialog box appears.
- 5. Select **Fixed with expansion** for the **Routing type**. Selecting this option automatically assigns an expansion length of 1.
  - *Note:* The routing region must be larger than the placement region, to provide extra flexibility for the Fitter when the engine routes different personas.
- 6. Repeat steps 1-5 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. For this tutorial, specify the **Origin** as X66 Y7, a **Height** of 47, and **Width** of 26 for the placement region of the u\_blinking\_led instance.

#### Figure 7. Logic Lock Regions Window



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





```
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 ROUTE_REGION "X65 Y6 X113 Y33" -to u_blinking_led
```

#### **Related Information**

- Floorplan the Partial Reconfiguration Design
- Applying Floorplan Constraints Incrementally

#### Step 5: Adding the Partial Reconfiguration Controller IP

Add the partial reconfiguration controller IP core to your project to reconfigure the PR partition. This IP core allows you to reconfigure the PR partition over a JTAG connection. Follow these steps to add the IP core to your project:

- In the Intel Quartus Prime IP catalog, Type Partial Reconfiguration Controller.
- 2. Double-click the Partial Reconfiguration Controller Intel Arria® 10/Cyclone 10 FPGA IP from the IP library. The parameter editor appears.

Figure 8. Partial Reconfiguration Controller IP Core Parameters



- 3. In the **New IP Variant** dialog box, type pr\_ip as the file name and click **Create**. Retain the following default parameterization for pr ip:
  - Use as partial reconfiguration internal host is on.
  - Enable JTAG debug mode is on.
  - Enable freeze interface is on.





- Enable Avalon-MM slave interface option is off.
- Enable hierarchical PR support option is on.
- Enable bitstream compatibility check option is on.
- 4. In the parameter editor, click the **Generate HDL** button, and then exit the parameter editor without generating the system. The parameter editor creates the pr\_ip.ip IP variation file, and adds the file to the project.

Note:

1. If you are copying the pr\_ip.ip file from the hpr folder, manually edit the blinking\_led.qsf file to include the following line:

```
set_global_assignment -name IP_FILE pr_ip.ip
```

2. Place the IP\_FILE assignment after the SDC\_FILE assignments (jtag.sdc and blinking\_led.sdc) in your blinking\_led.qsf file. This ordering ensures appropriate constraining of the Partial Reconfiguration IP core.

Note: To detect the clocks, the .sdc file for the PR IP must follow any .sdc that creates the clocks that the IP core uses. You facilitate this order by ensuring the .ip file for the PR IP core comes after any .ip files or .sdc files used to create these clocks in the .qsf file for your Intel Quartus Prime project revision. For more information, refer to Timing Constraints section in the Partial Reconfiguration IP Core User Guide.

#### **Updating the Top-Level Design**

To update the top.sv file with the PR\_IP instance:

1. To add the PR\_IP instance to the top-level design, uncomment the following code block in the top.sv file:

```
pr_ip u_pr_ip
        .clk
                       (clock),
                       (1'b1),
        .nreset
        .freeze
                       (freeze).
                                           // ignored for JTAG
        .pr_start
                       (1'b0),
        .status
                       (pr_ip_status),
                       (16'b0),
        .data_valid
                       (1'b0),
        .data_ready
                       ( )
```

2. To force the output ports to logic 1 during reconfiguration, use the freeze control signal output from PR\_IP. However, to observe continuous blinking of the LED from the parent PR partition while PR programming the child partition, the freeze control signal does not turn off led\_two\_on. Ensure that the pr\_led\_two\_on is directly assigned to led\_two\_on\_w. led\_three\_on\_w must choose between logic 1 and pr\_led\_three\_on, based on the freeze signal. Uncomment the following lines of code:

```
assign led_two_on_w = ? 1'b1 : pr_led_two_on;
assign led_three_on_w = freeze ? 1'b1 : pr_led_three_on;
```

3. To assign an instance of the default parent persona (blinking\_led), update the top.sv file with the following block of code:





```
.counter (count_d),
.led_two_on (pr_led_two_on),
.led_three_on (pr_led_three_on)
);
```

Figure 9. Partial Reconfiguration IP Core Integration



#### **Step 6: 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,      // 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</pre> |
|                       |                                                   | continued                                                                                                                                                                                                                                                                                                                                                            |



**File Name Description** Code led\_three\_on\_r <= counter[COUNTER\_TAP];</pre> end endmodule blinking\_led\_child\_slow.sv The `timescale 1 ps / 1 ps `default\_nettype none LED\_THREE blinks slower 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 <= counter[COUNTER\_TAP];
end</pre> endmodule The blinking\_led\_child\_empty.sv `timescale 1 ps / 1 ps `default\_nettype none LED\_THREE stays ON 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 The LED\_TWO blinking\_led\_slow.sv blinks slower. `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 <= counter[COUNTER\_TAP]; 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 7

#### **Step 7: Creating Revisions**

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

From this base revision, you create other revisions each implementation of the PR region. All PR implementation revisions must use the same top-level placement and routing results from the base revision.

To compile the PR design, you must create a PR implementation revision of the correct type for each PR persona. The following revision types are available:

- Partial Reconfiguration Base
- Partial Reconfiguration Persona Implementation

The following table lists the revision name and the revision type for each of the revisions you create in this tutorial:

#### 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**

| Revision Name                      | 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.qs f    | Slow blinking           | Slow blinking           |



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

- 1. Click **Project** ➤ **Revisions**.
- 2. 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**

- 1. To open the **Revisions** dialog box, click **Project** ➤ **Revisions**.
- 2. To create a new revision, double-click << new revision>>.
- In Revision name, specify hpr\_child\_default and select blinking\_led for Based on revision.
- 4. For the Revision type, select Partial Reconfiguration Persona Implementation.

#### Figure 10. Creating Revisions







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

- Enable This project uses a Partition Database (.qdb) file for the root partition. You do not need to specify the Root Partition Database file at this point. You can input this name at a later stage from the Design Partitions Window.
- 6. Turn off, Set as current revision.
- 7. Repeat steps 1-6 to create these implementation revisions:
  - hpr\_child\_slow
  - hpr\_child\_empty
  - hpr\_parent\_slow\_child\_default
  - hpr\_parent\_slow\_child\_slow

#### Figure 11. New Implementation Revisions



8. Verify that the .qsf file for each revision now 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 8: Compiling the Base Revision**

#### Before you begin:

1. Run the PR bitstream ID init script using the following command:

quartus\_sh -t prpof\_id\_mif\_gen.tcl init





This command allows the Intel Quartus Prime software to assign bitstream IDs to child PR regions, for bitstream compatibility check.

2. Add the following assignments to blinking\_led.qsf:

```
set_global_assignment -name GENERATE_PR_RBF_FILE ON set_global_assignment -name ON_CHIP_BITSTREAM_DECOMPRESSION OFF
```

These assignments allow the Assembler to automatically generate the required PR bitstreams.

To compile 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
```

On successful compilation, the blinking\_led\_static.qdb file is generated in the output\_files directory.

2. To regenerate the base .sof file with the proper bitstream IDs for the child PR regions, run the PR bitstream ID update script using the following command:

```
quartus_sh -t prpof_id_mif_gen.tcl update
```

3. Verify generation of the following the bitstream files:

#### Table 5. Generated Files

| Name                                                                                                             | Туре                                      | Description                                                                                                          |
|------------------------------------------------------------------------------------------------------------------|-------------------------------------------|----------------------------------------------------------------------------------------------------------------------|
| output_files/blinking_led.sof                                                                                    | Base programming file                     | Used to program the FPGA with the static logic, along with the default personas for the parent and child PR regions. |
| <pre>output_files/ blinking_led.pr_parent_partit ion.rbf</pre>                                                   | PR bitstream file for parent PR partition | Used to program the default persona for the parent PR region.                                                        |
| <pre>output_files/ blinking_led.pr_parent_partit ion.pr_partition.rbf</pre>                                      | PR bitstream file for child PR partition  | Used to program the default persona for the child PR region.                                                         |
| <pre><pre><pre><pre><pre><pre><pre><pre></pre></pre></pre></pre></pre></pre></pre></pre>                         | . qdb database file                       | Finalized database file used to import the static region.                                                            |
| <pre><pre><pre><pre><pre><pre><pre>parent_partition_default_f</pre> inal.qdb</pre></pre></pre></pre></pre></pre> | . qdb database file                       | Finalized database file used to import the default parent PR partition.                                              |

#### **Related Information**

- Floorplan the Partial Reconfiguration Design
- Applying Floorplan Constraints Incrementally

### Step 9: 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.



AN-806 | 2021.02.04



- 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 each implementation revision, click Project ➤
   Add/Remove Files in Project. Confirm that the blinking\_led\_child.sv file
   appears in the file list.

Figure 12. Confirming Correct Source File



3. To specify the .qdb file associated with the static region, click Assignments ➤ Design Partitions Window. Double-click the Partition Database File cell for root\_partition and select the cproject\_directory>/
blinking led static.qdb file.

Figure 13. Assigning the Partition Database File



Alternatively, the following command assigns this file:

set\_instance\_assignment -name QDB\_FILE\_PARTITION \
 blinking\_led\_static.qdb -to |

- 4. In the **Entity Re-binding** cell for **pr\_parent\_partition**, specify the entity name 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.
- 5. Verify that the following line now exists in the .qsf:





#### Figure 14. Entity Rebinding



#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.

6. In the Logic Lock Regions window, define the same Logic Lock region for the child PR partition as the parent PR partition.

#### Figure 15. Defining Logic Lock Regions



*Note:* There is no requirement to redefine the Logic Lock region for the parent PR partition.

7. Before compiling the implementation revision, ensure the corresponding .qsf file contains the following assignments:

```
set_global_assignment -name GENERATE_PR_RBF_FILE ON set_global_assignment -name ON_CHIP_BITSTREAM_DECOMPRESSION OFF
```

These assignments allow the Assembler to automatically generate the required PR bitstreams.

8. 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
```

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

| 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 \
   pr_parent_partition_slow_final.qdb
```

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

#### **Table 6.** Generated Bitstream Files

| Name                                                                | Туре                                      | Description                                                                                                        |
|---------------------------------------------------------------------|-------------------------------------------|--------------------------------------------------------------------------------------------------------------------|
| hpr_parent_slow_child_default .pr_parent_partition.rbf              | PR bitstream file for parent PR partition | Used to program 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 PR partition  | Used to program the default persona for the child PR region. Causes the led_three_on to blink at the default rate. |

### Step 10: 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 verify the correct source for each implementation revision, click Project ➤
   Add/Remove Files in Project. Confirm that the blinking\_led\_child.sv file
   appears in the file list.

Figure 16. Confirming Source File



3. Repeat steps 1 through 2 to verify the other 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 17. Specifying the QDB 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 parent\_pr\_partition and specify the respective .qdb file in the project directory.

#### **Table 7. Implementation Revisions**

| 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 that the following line exists in the .qsf:

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 18. Entity Rebinding



7. Before compiling the implementation revision, ensure that the corresponding .qsf file contains the following assignments:

```
set_global_assignment -name GENERATE_PR_RBF_FILE ON set_global_assignment -name ON_CHIP_BITSTREAM_DECOMPRESSION OFF
```

These assignments allow the Assembler to automatically generate the required PR bitstreams.

8. 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
```

9. Repeat the steps 1-8 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.

- 10. Inspect the bitstream files generated to the output\_files directory. Verify that the output\_files directory contains the following generated .rbf files after compiling all the implementation revisions:
  - hpr\_child\_default.pr\_parent\_partition.rbf
  - hpr\_child\_slow.pr\_parent\_partition.rbf
  - hpr\_child\_empty.pr\_parent\_partition.rbf
  - hpr\_parent\_slow\_child\_slow.pr\_parent\_partition.rbf
  - hpr\_child\_default.pr\_parent\_partition.pr\_partition.rbf





AN-806 | 2021.02.04

- 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 11: Programming the Board**

#### Before you begin:

- 1. Connect the power supply to the Intel Arria 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 Arria 10 GX FPGA development board on the bench, outside of the PCIe slot in your host machine.

To run the design on the Intel Arria 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 device, 10AX115S2.
- 4. Click **OK**. The Intel Quartus Prime software detects and updates the Programmer with the three FPGA chips on the board.
- 5. Select the 10AX115S2 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 the blinking\_led.sof file.
- 12. Enable **Program/Configure** for the hpr\_child\_slow.pr\_parent\_partition.pr\_partition.rbf file and click **Start**. On the board, observe LED[0], LED[1], and LED[2] continuing to blink. When the progress bar reaches 100%, 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\_child\_empty.pr\_parent\_partition.rbf file.
- 15. Click **Start**. On the board, observe that LED[0], LED[1] and LED[2] continue to blink. When the progress bar reaches 100%, LED[3] turns off.
- 16. Repeat the above steps to dynamically re-program just the child PR region, or both the parent and child PR regions simultaneously.





Figure 19. Programming the Intel Arria 10 GX FPGA Development Board



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

You must ensure that you program the correct child persona to match the parent persona. Running the prpof\_id\_mif\_gen.tcl script before and after the base revision compile checks for incompatible bitstreams for Intel Arria 10 devices, and outputs a PR\_ERROR message for incorrect bitstreams. The following errors are possible unless you run the scripts as the tutorial describes:

- 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, ensure that the child PR .rbf generates 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 the 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



AN-806 | 2021.02.04

In this case, you must choose

hpr\_child\_slow.pr\_parent\_partition.pr\_partition.rbf , as this file 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.

#### **Troubleshooting PR Programming Errors**

Ensuring proper setup of the Intel Quartus Prime Programmer and connected hardware helps to avoid any errors during PR programming.

If you face any PR programming errors, refer to "Troubleshooting PR Programming Errors" in the *Intel Quartus Prime Pro Edition User Guide: Partial Reconfiguration* for step-by-step troubleshooting tips.

#### **Related Information**

Troubleshooting PR Programming Errors

#### **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 11: Programming the Board on page 24 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 16.
- 2. Compile the revision by clicking **Processing** ➤ **Start Compilation**.

For complete information on hierarchical partial reconfiguration for Intel Arria 10 devices, refer to *Intel Quartus Prime Pro Edition User Guide: Partial Reconfiguration*.

#### **Related Information**

- Intel Quartus Prime Pro Edition User Guide: Partial Reconfiguration
- Partial Reconfiguration Online Training





## **Document Revision History for Hierarchical Partial Reconfiguration Tutorial for Intel Arria 10 GX FPGA Development Board**

| <b>Document Version</b> | Intel Quartus Prime<br>Version | Changes                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                        |
|-------------------------|--------------------------------|------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| 2021.02.04              | 20.3                           | <ul> <li>Updated version support to 20.3.</li> <li>Updated design partitions screenshot in Creating Design Partitions topic.</li> <li>Updated step 2 in Allocating Placement and Routing Regions for PR Partitions topic.</li> <li>Updated step 1 and step 4 in Adding the Partial Reconfiguration Controller IP topic.</li> <li>Updated step 2 code sample in Updating the Top-Level Design topic.</li> <li>Updated Design Partitions Window screenshot in Step 9: Preparing PR Implementation Revisions topic.</li> </ul>                    |
| 2019.07.15              | 19.1                           | Updated version support to 19.1. Updated default .qdb export location from output_files to project directory. Updated for changes to Design Partition command submenu changes, including change of "periphery reuse core" to "reserved core." Updated references to the official name of Partial Reconfiguration Controller Intel Arria 10/Cyclone 10 FPGA IP. Updated QSF examples for latest version. Updated all screenshots for latest version. Updated references to Intel Quartus Prime Pro Edition User Guide: Partial Reconfiguration. |
| 2018.09.24              | 18.1                           | Updated sections - Step 3: Creating Design Partitions, Step 8: Compiling the Base Revision and Exporting the Static Region, Step 9: Preparing the PR Implementation Revisions for Parent PR Partition, and Step 10: 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                           | Compilation flow change     Other minor text edits                                                                                                                                                                                                                                                                                                                                                                                                                                                                                             |
| 2017.11.06              | 17.1                           | Updated the Reference Design Requirements section with software version  Updated the Flat Reference Design without PR Partitioning figure with design block changes  Updated the Reference Design Files table with information on the Top_counter.sv module  Updated the Partial Reconfiguration IP Core Integration figure with design block changes  Updated the figures - Design Partitions Window and Logic Lock Regions Window to reflect the new GUI  File name changes  Text edits                                                      |
| 2017.05.08              | 17.0                           | Initial release of the document                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                |