Partial reconfiguration (PR) offers you the ability to reconfigure part of the design's core logic such as LABs, MLABs, DSP, and RAM, while the remainder of the design continues running. The PR IP core can be implemented through the Qsys Interface, or via the Quartus® Prime IP Catalog. The Quartus Prime software supports the PR feature for the Stratix® V and Arria® 10 device families as well as Cyclone® V devices whose part number ends in "SC", for example, 5CGXFC9E6F35I8NSC.

Partial reconfiguration is performed through either an internal host residing in the core logic or as an external host via dedicated PR pins. The advantage of the internal host is that you can store all the logic needed for PR on the device, without the need for external devices.

**Figure 1: PR IP core Components**

When you instantiate the PR IP core, the Main Controller module is instantiated. This module includes the Control Block Interface Controller, Freeze/Unfreeze Controller, Bitstream Decoder, and the Data Source Controller. A Data Source Interface module provides you with a JTAG Debug Interface and PR Data Interface. If you choose to use the PR IP core as an internal host, it automatically instantiates the corresponding **crcblock** and **prblock** WYSIWYG atom primitives.

Note:
1. The main controller module handles all the handshaking signals of the CB interface and processes the incoming data, as needed, before sending to the PRBLOCK. It also handles the freeze/un-freeze PR interface.
If it is used as external host (placed in another FPGA or CPLD), the PR IP core provides the `crcblock` and `prblock` WYSIWYG atom primitive as interface ports so that you can connect to the dedicated PR pins and `CRC_ERROR` pin on the target FPGA undergoing partial reconfiguration.

**Figure 2: Managing Partial Reconfiguration with an Internal or External Host**

The figure shows how these blocks should be connected to the PR control block (CB). In your system, you will have either the external host or the internal host, but not both. During PR, the PR Control Block (CB) is in Passive Parallel x16 programming mode.

Related Information

- FPGA Control Block Interface on page 18
- Control Block Interface Controller on page 20
- Freeze and Unfreeze Controls on page 21
- Data Source Controller on page 21
- Standard Partial Reconfiguration Data Interface on page 21
- JTAG Debug Mode for Partial Reconfiguration on page 22

**Instantiating the Partial Reconfiguration IP Core in the Qsys Interface**

Partial Reconfiguration (PR) is available as a Qsys component through the Qsys interface. You can choose to instantiate the core as an internal host or an external host.

When instantiated with Qsys, PR is configured as a Conduit interface, or by enabling the Avalon Memory Map Slave interface. If you use Qsys and want PR included as component, you must instantiate the PR IP core in the Qsys interface.

To instantiate the PR IP core with Qsys:

1. Click Tools > Qsys
2. In the Qsys interface IP Catalog expand Basic Functions > Configuration and Programming and select Partial Reconfiguration.
3. Configure your IP core variation using the settings appropriate to your design.
4. Turn on **Enable Avalon-MM slave interface** to use the Avalon Memory Map Slave interface rather than the Conduit interface.

5. Turn on **Enable enhanced decompression** to use this optional feature.

6. Click **Finish**.

**Related Information**

- [Instantiating the Partial Reconfiguration IP Core in the Quartus Prime IP Catalog](#) on page 4
- [Partial Reconfiguration IP Core Parameters](#) on page 7
- [Enable Enhanced Decompression](#) on page 6
- [Creating a System With Qsys](#)
Instantiating the Partial Reconfiguration IP Core in the Quartus Prime IP Catalog

**Partial Reconfiguration** (PR) is available from the **IP Catalog**. You can choose to instantiate the core as an internal host or an external host.

If you are not using PR as a component of the **Qsys** interface, then you can instantiate PR with the Quartus Prime IP Catalog.

The PR IP core can be instantiated as the internal host for Stratix V devices. When internal host is specified, both **prblock** and **crchblock** WYSIWYG atom primitives are auto-instantiated as part of the design. You can instantiate the PR IP core as the external host on any supported Altera devices as specified in the user selectable device family list.

1. Click **Tools > IP Catalog**.
2. Expand **Installed IP > Library > Basic Functions > Configuration and Programming** and select **Partial Reconfiguration**.
3. In the **Save IP Variation** dialog box, name your partial reconfiguration IP variation. Choose whether to use Verilog or VHDL. Click **OK** to save your variation.
4. Configure your IP core variation using the settings appropriate to your design.
5. Turn on **Enable Avalon-MM slave interface** to use the Avalon Memory Map Slave interface rather than the Conduit interface.

6. Turn on **Enable enhanced decompression** to use this optional feature.

7. Click **Finish**.
   The IP Catalog instantiates your IP core variation and displays a completion dialog box.
8. Click Exit.

Related Information

- Instantiating the Partial Reconfiguration IP Core in the Qsys Interface on page 2
- Partial Reconfiguration IP Core Parameters on page 7
- Enable Enhanced Decompression on page 6

**Enable Enhanced Decompression**

Enhanced compression/decompression can reduce the size of your bitstream at the expense of greater resources use.

**Note:** Enhanced compression cannot be used with bitstream encryption.

Enhanced compression is available for both Stratix V and Arria 10 devices. You can also use enhanced compression with double-compression. Preliminary testing has resulted in compression rates of up to 80%, however your results may vary. The increase in resource usage is approximately 340 ALMs.

You can generate a bitstream with enhanced compression in one of two ways:

- In the **Convert Programming Files** dialog box under the properties of a .pmsf
- From the command line with this command:

```
quartus_cpf -c -o enhanced_bitstream_compression=on <input_filename>.pmsf <output_filename>.rbd
```

Related Information

- Instantiating the Partial Reconfiguration IP Core in the Quartus Prime IP Catalog on page 4
- Instantiating the Partial Reconfiguration IP Core in the Qsys Interface on page 2
Bitstream Compatibility Check

Turn on the **Enable bitstream compatibility check** when instantiating the PR IP core from either Qsys or the IP Catalog to have the Quartus Prime software verify the partial reconfiguration PR Bitstream file (.rbf). If an incompatible bitstream is detected, the PR operation aborts and the status output reports an error.

This prevents you from accidentally corrupting the static region of your design with a bitstream from an incompatible .rbf and risking damage to the chip being programmed.

When **Enable bitstream compatibility check** is turned on, the PR IP core creates a **PR bitstream ID** and displays it in the configuration dialog box.

**Related Information**
- Partial Reconfiguration IP Core Parameters on page 7
- Partial Reconfiguration IP Core Ports on page 10

Partial Reconfiguration IP Core Parameters
<table>
<thead>
<tr>
<th>IP Core Option</th>
<th>Value</th>
<th>Default</th>
<th>Description</th>
</tr>
</thead>
<tbody>
<tr>
<td>Use as PR Internal Host</td>
<td>On or Off</td>
<td>On</td>
<td>Turn on this option to use the PR IP core as an internal host. Both <code>prblock</code> and <code>crcblock</code> WYSIWYG atom primitives are auto-instantiated as part of your design. Disable this option to use the PR IP core as an external host. You must connect additional interface signals to the dedicated PR pins or the external <code>prblock</code> and <code>crcblock</code> WYSIWYG atom primitives interface signals if the PR IP core is used as an external host.</td>
</tr>
<tr>
<td>Enable JTAG debug mode</td>
<td>On or Off</td>
<td>On</td>
<td>Turn on this option to access the PR IP core with the Programmer to perform partial reconfiguration.</td>
</tr>
<tr>
<td>Enable Avalon-MM slave interface</td>
<td>On or Off</td>
<td>Off</td>
<td>Turn on this option to use the Avalon Memory Map slave interface</td>
</tr>
<tr>
<td>Enable interrupt interface</td>
<td>On or Off</td>
<td>Off</td>
<td>Enable this option to use the interrupt interface. This interface can only be enabled if the Avalon-MM slave interface is used.</td>
</tr>
<tr>
<td>Enable bitstream compatibility check</td>
<td>On or Off</td>
<td>Off</td>
<td>Turn on this option to check the bitstream compatibility during PR operations for External Host. The bitstream compatibility check feature is always enabled for PR Internal Host. The PR bitstream ID value must be specified if this option is enabled for PR External Host.</td>
</tr>
<tr>
<td>PR bitstream ID</td>
<td>-2147483648 to 2147483647</td>
<td>0</td>
<td>Specifies a signed 32-bit integer value of the PR bitstream ID for External Host. This value must match the PR bitstream ID generated during compilation for the target PR design. The PR bitstream ID value of the target PR design can be found in the Assembler compilation report (.asm.rpt).</td>
</tr>
<tr>
<td>IP Core Option</td>
<td>Value</td>
<td>Default</td>
<td>Description</td>
</tr>
<tr>
<td>----------------------------------------------------</td>
<td>-------------------</td>
<td>---------</td>
<td>---------------------------------------------------------------------------------------------------------------------------------------------</td>
</tr>
<tr>
<td>Input Data Width</td>
<td>1, 8, 16, or 32</td>
<td>16</td>
<td>Specifies the data width in bits. This option affects the data[] bus width.</td>
</tr>
</tbody>
</table>
| Target device family for partial reconfiguration  | "Arria V", "Arria V GZ", "Arria 10", "Cyclone V", "Stratix V" | "Stratix V" | Select the target device family for partial reconfiguration when the PR IP core is used as External Host.  
**Note:** This option is ignored for PR Internal Host. |
| Clock-to-Data ratio                                | 1, 2, or 4        | 1       | Specifies the ratio between PR clock and PR data. Select '1' for plain PR data, '2' for encrypted PR data, or '4' for compressed PR data (with or without encryption) |
| Divide error detection frequency by                | 1, 2, 4, 8, 16, 32, 64, 128, or 256 | 1       | Only available when the IP core is used as an Internal Host where the crcblock WYSIWYG atom primitive is auto-instantiated as part of the design.  
Specifies the divide value of the internal clock, which determines the frequency of the error detection CRC. The divide value must be a power of two. Refer to the device handbook to find the frequency of the internal clock for the selected device. |
| Auto-instantiate CRCBLOCK                          | On or Off         | On      | This option is only applicable for an internal host. Disable this option to manually instantiate a CRCBLOCK.                               |
| Auto-instantiate PRBLOCK                           | On or Off         | On      | This option is only applicable for an internal host. Disable this option to manually instantiate a PRBLOCK.                               |
| Enable enhanced decompressor                       | On or Off         | Off     | Enable this option is to use the enhanced decompressor. It is required to decompress bitstreams that are compressed with the enhanced compression algorithm. |
Partial Reconfiguration IP Core Ports

I/O Port List for PR IP Core

Table 1: Clock/Reset Ports
These options are always available.

<table>
<thead>
<tr>
<th>Port Name</th>
<th>Width</th>
<th>Direction</th>
<th>Function</th>
</tr>
</thead>
<tbody>
<tr>
<td>nreset</td>
<td>1</td>
<td>Input</td>
<td>Asynchronous reset for the PR IP core. Set high to enable partial reconfiguration. Set low to prevent partial reconfiguration and reset the state machine in the PR IP core.</td>
</tr>
<tr>
<td>clk</td>
<td>1</td>
<td>Input</td>
<td>User input clock to the PR IP core.</td>
</tr>
<tr>
<td></td>
<td></td>
<td></td>
<td>This signal is ignored during JTAG debug operations.</td>
</tr>
</tbody>
</table>

Table 2: Conduit Interface
This option is always available.

<table>
<thead>
<tr>
<th>Port Name</th>
<th>Width</th>
<th>Direction</th>
<th>Function</th>
</tr>
</thead>
<tbody>
<tr>
<td>freeze</td>
<td>1</td>
<td>Output</td>
<td>Active high signal used to freeze the PR interface signals of the region undergoing partial reconfiguration. De-assertion of this signal indicates the end of PR operation.</td>
</tr>
</tbody>
</table>
Table 3: Conduit Interface

These options are available when Enable Avalon-MM slave interface parameter is turned Off.

<table>
<thead>
<tr>
<th>Port Name</th>
<th>Width</th>
<th>Direction</th>
<th>Function</th>
</tr>
</thead>
<tbody>
<tr>
<td>pr_start</td>
<td>1</td>
<td>Input</td>
<td>A signal arriving at this port asserted high initiates a PR event. You must assert this signal high for a minimum of one clock cycle and de-assert it low prior to the end of the PR operation so that the PR IP core is ready to accept the next pr_start trigger event when the freeze signal is low. This signal is ignored during JTAG debug operations.</td>
</tr>
<tr>
<td>data[]</td>
<td>1, 8, 16, or 32</td>
<td>Input</td>
<td>Selectable input PR data bus width, either x1, x8, x16, or x32. Once a PR event is triggered, it is synchronous with the rising edge of the clk signal whenever the data_valid signal is high and the data_read signal is high. This signal is ignored during JTAG debug operations.</td>
</tr>
<tr>
<td>data_valid</td>
<td>1</td>
<td>Input</td>
<td>A signal arriving at this port asserted high indicates the data[] port contains valid data. This signal is ignored during JTAG debug operations.</td>
</tr>
<tr>
<td>data_ready</td>
<td>1</td>
<td>Output</td>
<td>A signal arriving at this port asserted high indicates the PR IP core is ready to read the valid data on the data[] port whenever the data_valid signal is asserted high. The data sender must stop sending valid data if this port is low. This signal deasserted low during JTAG debug operations.</td>
</tr>
<tr>
<td>Port Name</td>
<td>Width</td>
<td>Direction</td>
<td>Function</td>
</tr>
<tr>
<td>------------</td>
<td>-------</td>
<td>-----------</td>
<td>---------------------------------------------------------------------------</td>
</tr>
<tr>
<td>status[2..0]</td>
<td>3</td>
<td>Output</td>
<td>A 3-bit error output used to indicate the status of PR event. Once an error is detected (PR_ERROR, CRC_ERROR, or Incompatible bitstream error), this signal is latched high and only get reset at the beginning of the next PR event, when pr_start is high and freeze is low. For example: 3'b000 – power-up or nreset asserted 3'b001 – PR_ERROR was triggered 3'b010 – CRC_ERROR was triggered 3'b011 – Incompatible bitstream error detected 3'b100 – PR operation in progress 3'b101 – PR operation passed 3'b110 – Reserved 3'b111 – Reserved</td>
</tr>
<tr>
<td>Port Name</td>
<td>Width</td>
<td>Direction</td>
<td>Function</td>
</tr>
<tr>
<td>------------</td>
<td>-------</td>
<td>-----------</td>
<td>----------</td>
</tr>
<tr>
<td>double_pr</td>
<td>1</td>
<td>Input</td>
<td>When the pr_start signal is triggered until the de-assertion of freeze signal, a signal asserted high on this port indicates the PR event requires double PR cycle. A low signal on this port indicates a single PR cycle event. If your PR design targets a Stratix V device and requires the use of double PR because you have initialized RAM in the PR region, you must assert the double_pr input signal high so that the controller can handle double PR properly. If you are instantiating the PR IP in an Arria 10 design, or in a Stratix V design not using initialized on-chip RAMs, connect this port to 0. You must assert this signal high if the PR bitstream (.rbf) is generated with the Write memory contents option turned on. Failure to do so causes a PR_ERROR assertion during partial reconfiguration. This signal is ignored during JTAG debug operations.</td>
</tr>
</tbody>
</table>

Table 4: Avalon-MM Slave Interface

These options are available when Enable Avalon-MM Slave Interface parameter is turned On.

<table>
<thead>
<tr>
<th>Port Name</th>
<th>Width</th>
<th>Direction</th>
<th>Function</th>
</tr>
</thead>
<tbody>
<tr>
<td>avmm_slave_address</td>
<td>1</td>
<td>Input</td>
<td>Avalon-MM address bus. The address bus is in the unit of Word addressing. Refer to the Qsys Component section for more details on the address mapping. This signal is ignored during JTAG debug operations.</td>
</tr>
<tr>
<td>Port Name</td>
<td>Width</td>
<td>Direction</td>
<td>Function</td>
</tr>
<tr>
<td>----------------------</td>
<td>-------</td>
<td>-----------</td>
<td>--------------------------------------------------------------------------</td>
</tr>
<tr>
<td>avmm_slave_read</td>
<td>1</td>
<td>Input</td>
<td>Avalon-MM read control. This signal is ignored during JTAG debug operations.</td>
</tr>
<tr>
<td>avmm_slave_readdata</td>
<td>16 or 32</td>
<td>Output</td>
<td>Avalon-MM read data bus. This signal is ignored during JTAG debug operations.</td>
</tr>
<tr>
<td>avmm_slave_write</td>
<td>1</td>
<td>Input</td>
<td>Avalon-MM write control. This signal is ignored during JTAG debug operations.</td>
</tr>
<tr>
<td>avmm_slave_writedata</td>
<td>16 or 32</td>
<td>Input</td>
<td>Avalon-MM write data bus. This signal is ignored during JTAG debug operations.</td>
</tr>
<tr>
<td>avmm_slave_waitrequest</td>
<td>1</td>
<td>Output</td>
<td>Asserted to indicate that the IP is busy and it is unable to respond to a read or write request. This signal is pulled high during JTAG debug operations.</td>
</tr>
</tbody>
</table>

**Table 5: Interrupt Interface**

This option is available when **Enable interrupt interface** parameter is turned **On**.

<table>
<thead>
<tr>
<th>Port Name</th>
<th>Width</th>
<th>Direction</th>
<th>Function</th>
</tr>
</thead>
<tbody>
<tr>
<td>irq</td>
<td>1</td>
<td>Output</td>
<td>The interrupt signal.</td>
</tr>
</tbody>
</table>

**Table 6: CRCBLOCK Interface**

These options are available when **Use as PR Internal Host** parameter is turned **Off** or the **CRCBLOCK** is instantiated manually for an internal host.

<table>
<thead>
<tr>
<th>Port Name</th>
<th>Width</th>
<th>Direction</th>
<th>Function</th>
</tr>
</thead>
<tbody>
<tr>
<td>crc_error_pin</td>
<td>1</td>
<td>Input</td>
<td>Available when you use the PR IP core as an External Host. Connect this port to the dedicated <strong>CRC_ERROR</strong> pin of the FPGA undergoing partial reconfiguration, or connect directly to the <strong>crcblock</strong> WYSIWYG atom primitive.</td>
</tr>
</tbody>
</table>
Table 7: PRBLOCK Interface

These options are available when **Use as PR Internal Host** parameter is turned **Off** or when the PRBLOCK is instantiated manually for an internal host.

<table>
<thead>
<tr>
<th>Port Name</th>
<th>Width</th>
<th>Direction</th>
<th>Function</th>
</tr>
</thead>
<tbody>
<tr>
<td>pr_ready_pin</td>
<td>1</td>
<td>Input</td>
<td>Available when you use the IP core as an External Host. Connect this port to the dedicated <strong>PR READY</strong> pin of the FPGA undergoing partial reconfiguration, or connect directly to the <strong>prblock</strong> WYSIWYG atom primitive.</td>
</tr>
<tr>
<td>pr_error_pin</td>
<td>1</td>
<td>Input</td>
<td>Available when the IP is used as the External Host. Connect this port to the dedicated <strong>PR_ERROR</strong> pin of the FPGA undergoing partial reconfiguration, or connect directly to the <strong>prblock</strong> WYSIWYG atom primitive.</td>
</tr>
<tr>
<td>pr_done_pin</td>
<td>1</td>
<td>Input</td>
<td>Available when the PR IP core is used as the External Host. Connect this port to the dedicated <strong>PR DONE</strong> pin of the FPGA undergoing partial reconfiguration, or connect directly to the <strong>prblock</strong> WYSIWYG atom primitive.</td>
</tr>
<tr>
<td>pr_request_pin</td>
<td>1</td>
<td>Output</td>
<td>Available when the IP is used as the External Host. Connect this port to the dedicated <strong>PR_REQUEST</strong> pin of the FPGA undergoing partial reconfiguration, or connect directly to the <strong>prblock</strong> WYSIWYG atom primitive.</td>
</tr>
<tr>
<td>pr_clk_pin</td>
<td>1</td>
<td>Output</td>
<td>Available when the IP is used as the External Host. Connect this port to the dedicated <strong>DCLK</strong> of the FPGA undergoing partial reconfiguration, or connect directly to the <strong>prblock</strong> WYSIWYG atom primitive.</td>
</tr>
</tbody>
</table>
### Using the Avalon Memory Mapped Slave Interface

Perform partial reconfiguration through the Avalon® Memory Mapped Slave interface by following these steps:

1. Avalon Memory Mapped Master component writes 16’h0001 (or 16’h0003 if the design requires double PR) to this IP address offset 0x1 to trigger PR operation.
2. Avalon Memory Mapped Master component writes PR bitstream (data width in x16) to this IP address offset 0x0 until all the PR bitstream is written.
3. Avalon Memory Mapped Master component reads the data from this IP address offset 0x1 to check the status[2:0] value. Optionally, the Avalon-MM Master component can read the status[2:0] of this IP during a PR operation to detect any early failure, for example, PR_ERROR.

### Related Information

- Partial Reconfiguration IP Core Parameters on page 7
- Avalon Memory Map Slave Interface Read and Write Transfer Timing on page 20

For more information on the timing specification for the Avalon Memory Mapped Slave interface.
### Table 8: Data/CSR Memory Map Format

<table>
<thead>
<tr>
<th>Name</th>
<th>Address Offset</th>
<th>Width</th>
<th>Access</th>
<th>Description</th>
</tr>
</thead>
<tbody>
<tr>
<td>PR_DATA</td>
<td>0x0</td>
<td>16 or 32</td>
<td>Write</td>
<td>Every data write to this address indicates this bitstream was sent to the IP core. Performing a read on this address returns all 0’s.</td>
</tr>
<tr>
<td>PR_CSR</td>
<td>0x1</td>
<td>16 or 32</td>
<td>Read/Write</td>
<td>Controls and status registers.</td>
</tr>
</tbody>
</table>

### Table 9: PR_CSR Control and Status Registers

<table>
<thead>
<tr>
<th>Bit Offset</th>
<th>Description</th>
</tr>
</thead>
</table>
| 0          | Read and write control register for pr_start signal. Refer to “Input/output Port List” section for more details on pr_start signal.  
pr_start = PR_CSR[0]  
PR_CSR[0] is de-asserted to value “0” by the IP core automatically one clock cycle after it is asserted to streamline the flow so you do not need to manually assert and de-assert this register to control pr_start signal. |
| 1          | Read and write control register for double_pr signal.  
double_pr = PR_CSR[1] |
| 2-4        | Read only status register for status[2:0] signal.  
PR_CSR[4:2] = status[2:0] |
| 5          | Read and write bit for interrupt.  
If the interrupt interface is enabled, reading this bit returns the value of the irq signal. Writing a “1” clears the interrupt.  
If the interrupt interface is disabled, reading this bit always returns a value of “0”. |
| 6-15 or 6-31 | Reserved |

(1) Depending on the Avalon Memory Mapped data bus width.  
(2) When using enhanced compression, Stratix V devices are limited to a width of 16. Arria 10 devices can use widths of 1, 8, 16, or 32.
If you have enabled the Avalon Memory Mapped Slave interface, you can use the optional interrupt interface.

irq is asserted during the following events.

### Table 10: Interrupt Interface Events

<table>
<thead>
<tr>
<th>Status Code</th>
<th>Event</th>
</tr>
</thead>
<tbody>
<tr>
<td>3'b001</td>
<td>PR_ERROR occurred.</td>
</tr>
<tr>
<td>3'b010</td>
<td>CRC_ERROR occurred.</td>
</tr>
<tr>
<td>3'b011</td>
<td>An incompatible bitstream was detected.</td>
</tr>
<tr>
<td>3'b101</td>
<td>The result of a successful PR operation.</td>
</tr>
</tbody>
</table>

After irq is asserted, the master should perform one or more of the following:

- Query for the status of the PR IP core; PR_CSR[4:2]
- Carry out some action, such as error reporting.
- Once the interrupt is serviced, clear the interrupt by writing a "1" to PR_CSR[5].

### FPGA Control Block Interface

When you instantiate the PR IP core, you can choose to use it as either an internal host or external host.

If it is used as an internal host, the PR IP core auto instantiates the corresponding device CRCBLOCK and prblock WYSIWYG atom primitive. If PR is used as external host (placed in another FPGA or CPLD), the PR IP core provides the CRCBLOCK and prblock interface ports so you can connect the host to the dedicated PR pins and CRC_ERROR pin on the target FPGA being partially reconfigured.

You can instantiate an internal host with the PR IP core while choosing to instantiate the CRCBLOCK and/or PRBLOCK manually.

You can also instantiate the PR IP core as the external host so be able to add CRCBLOCK and PRBLOCK WYSIWYG atom primitive instances to SignalTap II for debugging purposes.

### Partial Reconfiguration IP Core Timing Specification

This timing diagram illustrates a successful Partial Reconfiguration IP core operation. Pass or fail can be determined with the status[2:0] output signal.

The PR operation is initiated when you assert the pr_start signal. You can monitor the status[] or freeze signals to detect the end of the PR operation.
Figure 5: Partial Reconfiguration Timing

Note:

1. You must assert `pr_start` signal high for a minimum of one clock cycle to initiate PR and deassert `pr_start` before sending the last data.
2. `status[]` signal is reset when `pr_start` is asserted and changes during a PR operation if any error such as a CRC_ERROR, PR_ERROR, or bitstream incompatibility error is detected.
3. `status[]` signal changes after a PR operation if CRC_ERROR is detected and no error happens during the previous PR operation.
4. The `data_valid` signal is not required to be asserted at the same time as the `pr_start`. You can provided the `data[]` and assert `data_valid` when appropriate.
5. You can either drive the `data_valid` signal low after sending the last data, or continue to assert `data_valid` high with dummy data on `data[]` until the end of PR, when `freeze` is driven low or `status[]` is updated.
6. `data[]` is transferred only when `data_valid` and `data_ready` are asserted on the same cycle. Do not drive new data on the data bus, when both `data_valid` and `data_ready` have not been asserted high.
7. The `data_ready` signal is driven low once the PR IP Core receives the last data.

The `data[]`, `data_valid`, and `data_ready` signals comply with the Avalon-ST specification for Data Transfer with Backpressure. The PR IP Core acts as a sink, with readLatency = 0. For more information, refer to the Avalon Interface Specifications.

If your CDRATIO is not 1, or your `data[]` width is x32 for series-V devices, the `data_ready` alternates between high and low for one or more clock cycles. The PR IP Core requires additional clock cycles to process the data received. You should hold `data[]` when `data_ready` is low.

**Important:** The `PR_CLK` signal has a different nominal maximum frequency for each device. Most Stratix V devices have a nominal maximum frequency of at least 62.5 MHz.

Related Information

link/nik1412467993397/nik1412467975241
Avalon Interface Specifications for data transfer with backpressure
### Avalon Memory Map Slave Interface Read and Write Transfer Timing

The Avalon-MM interface supports read and write transfers with a slave-controlled `waitrequest`. The slave can stall the interconnect for as many cycles as required by asserting the `waitrequest` signal. If a slave uses `waitrequest` for either read or write transfers, it must use `waitrequest` for both.

A slave typically receives `address`, `read` or `write`, and `writedata` after the rising edge of the clock. A slave asserts `waitrequest` before the rising clock edge to hold off transfers. When the slave asserts `waitrequest`, the transfer is delayed. And, the address and control signals are held constant. Transfers complete on the rising edge of the first `clk` after the slave port deasserts `waitrequest`.

**Figure 6: Read and Write Transfers for Avalon-MM Slave Interface**

The numbers in this timing diagram, mark the following transitions:

1. `address` and `read` are asserted after the rising edge of `clk`. `waitrequest` is asserted stalling the transfer.
2. `waitrequest` is sampled. Because `waitrequest` is asserted, the cycle becomes a wait-state. `address`, `read`, and `write` remain constant.
3. The slave presents valid `readdata` and deasserts `waitrequest`.
4. `readdata` and deasserted `waitrequest` are sampled, completing the transfer.
5. `address`, `writedata`, and `write` signals are asserted. The slave responds by asserting `waitrequest` stalling the transfer.
6. Deassert the `waitrequest`.
7. The slave captures `writedata` and ends the transfer.

**Related Information**

**Avalon Memory Mapped Interfaces**
For more information on read and write transfers with Avalon Memory Mapped Interfaces

---

### Control Block Interface Controller

This controller handles all the handshaking signals of the `prblock` WYSIWYG atom primitive and it will monitor `CRC_ERROR` signals of `crcblock` WYSIWYG atom primitives throughout the PR event (before, during, and after PR) to detect any CRAM error.

The controller receives data and sends it to the `prblock` WYSIWYG atom primitive during a PR event with the clock-to-data ratio (CDRATIO) you specify when you instantiate the Partial Reconfiguration IP core.
Table 11: CDRATIO for PR Compression and/or Encryption

The following table lists the range of values for the clock-to-data ratio for bitstreams that are compressed, encrypted, both, or neither.

<table>
<thead>
<tr>
<th>Compressed</th>
<th>Encrypted</th>
<th>Clock-to-Data Ratio</th>
</tr>
</thead>
<tbody>
<tr>
<td>No</td>
<td>No</td>
<td>x1</td>
</tr>
<tr>
<td>No</td>
<td>Yes</td>
<td>x2</td>
</tr>
<tr>
<td>Yes</td>
<td>No</td>
<td>x4</td>
</tr>
<tr>
<td>Yes</td>
<td>Yes</td>
<td>x4</td>
</tr>
</tbody>
</table>

Related Information

Instantiating the Partial Reconfiguration IP Core in the Quartus Prime IP Catalog on page 4

Freeze and Unfreeze Controls

The Freeze/Unfreeze controller logic of the Partial Reconfiguration IP core provides a signal to the user specified PR regions, freezing all input signals during PR operation to avoid current contention.

You begin a PR event by asserting the `pr_start` input port to the PR IP core. The Freeze/Unfreeze Controller then asserts the output freeze signal high and sends it to the PR region you specified. All the input signals coming into that PR region are then pulled high, preventing current contention in the device. The PR IP core does not differentiate between multiple PR regions, so you may need to create custom freeze logic if you are freezing individual PR regions.

Once the PR operation is completed, this controller asserts the output freeze signal low. All the input signals coming into the specified PR region are released and the PR region is ready for normal operation.

Related Information

- Partial Reconfiguration IP Core Timing Specification on page 18
- Partial Reconfiguration IP Core Ports on page 10

Data Source Controller

This controller handles the source of PR data, either from JTAG or standard data interface.

The JTAG interface takes precedence over the standard PR data interface. For example, whenever JTAG is engaged through command from Quartus Prime Programmer tool, the PR data is sourced from the JTAG interface rather than the PR data interface.

Standard Partial Reconfiguration Data Interface

The PR data interface provides you with selectable input data width; x1, x8, x16, and x32. It can be connected to `ASMI_PARALLEL` as well as the Avalon interface to obtain PR data from on-chip RAM, external flash device, or PR over PCIe.
If the input data width is other than \( \times 16 \), the PR IP core includes a data upsize or downsize module so that the data output to the Data Source Controller is always \( \times 16 \).

**JTAG Debug Mode for Partial Reconfiguration**

The JTAG debug mode allows you to configure partial reconfiguration bitstream through the JTAG interface. Use this feature to debug PR bitstream and eventually helping you in your PR design prototyping. This feature is available for internal and external host.

During JTAG debug operation, the JTAG command sent from the Quartus Prime Programmer ignores and overrides most of the Partial Reconfiguration IP core interface signals (\( \text{clk}, \text{pr\_start}, \text{double\_pr}, \text{data[]} \), \( \text{data\_valid} \), and \( \text{data\_read} \)).

**Note:** The \( \text{TCK} \) is the main clock source for PR IP core during this operation.

You can view the status of Partial Reconfiguration operation in the messages box and the Progress bar in the Quartus Prime Programmer. The \( \text{PR\_DONE}, \text{PR\_ERROR}, \) and \( \text{CRC\_ERROR} \) signals will be monitored during PR operation and reported in the Messages box at the end of the operation.

The Quartus Prime Programmer can detect the number of \( \text{PR\_DONE} \) instruction(s) in plain or compressed PR bitstream and, therefore, can handle single or double PR cycle accordingly. However, only single PR cycle is supported for encrypted Partial Reconfiguration bitstream in JTAG debug mode (provided that the specified device is configured with the encrypted base bitstream which contains the PR IP core in the design).

**Note:** Configuring an incompatible PR bitstream to the specified device may corrupt your design, including the routing path and the PR IP core placed in the static region. When this issue occurs, the PR IP core stays in an undefined state, and the Quartus Prime Programmer is unable to reset the IP core. As a result, the Quartus Prime Programmer generates the following error when you try to configure a new PR bitstream:

```
Error (12897): Partial Reconfiguration status: Can't reset the PR megafuction. This issue occurred because the design was corrupted by an incompatible PR bitstream in the previous PR operation. You must reconfigure the device with a good design.
```

**Configuring Partial Reconfiguration Bitstream in JTAG Debug Mode**

To configure the Partial Reconfiguration bitstream in JTAG debug mode, follow these steps:

1. In the Quartus Prime Programmer GUI, right click on a highlighted base bitstream (in \( \text{.sof} \)) and then click **Add PR Programming File** to add the PR bitstream (\( \text{.rbf} \)).
2. After adding the PR bitstream, you can change or delete the Partial Reconfiguration programming file by clicking **Change PR Programming File** or **Delete PR Programming File**.
3. Click **Start** to configure the PR bitstream. The Quartus Prime Programmer generates an error message if the specified device does not contain the PR IP core in the design (you must instantiate the Partial Reconfiguration IP core in your design to use the JTAG debug mode).
4. Configure the valid .rbf in JTAG debug mode with the Quartus Prime Programmer.
5. The JTAG debug mode is also supported if the PR IP core is pre-programmed on the specified device.
6. The Quartus Prime Programmer reports error when you try to configure the corrupted `.rbf` in JTAG debug mode.
Sample Freeze Wrapper for Multiple PR Regions

The following Verilog HDL pseudocode shows an example of how to create a simple freeze wrapper for two PR regions.

The same method can be applied to any number of PR regions.

```verilog
// pseudocode for a simple freeze wrapper for two PR regions
module design_top (...);
// user selects region A or B to be PR'ed
input pr_region_A_or_B;
input pr_start;

assign freeze_A_w = pr_region_A_or_B ? pr_freeze_w : 1'b0;
assign freeze_B_w = pr_region_A_or_B ? 1'b0 : pr_freeze_w;

// freeze output of PR IP core
alt_pr_sv my_alt_pr (.freeze (pr_freeze_w), // always stays low until user asserts pr_start
.pr_start (pr_start),
);
// Freeze wrapper for input signals of single PR region A
// Follow existing recommendations in the PR user guide for the details
freeze_region_A
```
my_freeze_region_A (  
  .freeze(freeze_A_w),  
  ...  
);  

// Freeze wrapper for input signals of single PR region B  
// Follow existing recommendations in the PR user guide for the details  
freeze_region_B my_freeze_region_B (  
  .freeze(freeze_B_w),  
  ...  
);  
endmodule

Related Information

Design Planning for Partial Reconfiguration
For more information on creating a freeze wrapper for partial reconfiguration.

Revision History

<table>
<thead>
<tr>
<th>Date</th>
<th>Version</th>
<th>Changes</th>
</tr>
</thead>
<tbody>
<tr>
<td>Nov 2015</td>
<td>2015.11.20</td>
<td>Revised the following topics:</td>
</tr>
<tr>
<td></td>
<td></td>
<td>• Partial Reconfiguration IP Core Parameters—updated supported data width</td>
</tr>
<tr>
<td></td>
<td></td>
<td>• Partial Reconfiguration IP Core Timing Specification—revised the timing diagram</td>
</tr>
<tr>
<td></td>
<td></td>
<td>• Deprecated the Sample Partial Reconfiguration IP Core as an External Host on the Same Device topic</td>
</tr>
<tr>
<td></td>
<td></td>
<td>• Added Enable Enhanced Compression topic</td>
</tr>
<tr>
<td>May 2015</td>
<td>2015.05.04</td>
<td>Revised the following topics:</td>
</tr>
<tr>
<td></td>
<td></td>
<td>• Partial Reconfiguration IP Core Parameters—added new parameters for device family support</td>
</tr>
<tr>
<td></td>
<td></td>
<td>• Partial Reconfiguration IP Core Ports—added new port options</td>
</tr>
<tr>
<td></td>
<td></td>
<td>• Partial Reconfiguration IP Core Timing Specification—revised the timing diagram</td>
</tr>
<tr>
<td>January 2015</td>
<td>2015.01.29</td>
<td>Minor error corrections.</td>
</tr>
<tr>
<td>August 2014</td>
<td>2014.08.20</td>
<td>• Added Avalon Memory Map slave interface</td>
</tr>
<tr>
<td></td>
<td></td>
<td>• Updated Ports and Parameters to support Avalon Memory Map slave interface</td>
</tr>
<tr>
<td></td>
<td></td>
<td>• Added Bitstream compatibility checking</td>
</tr>
<tr>
<td></td>
<td></td>
<td>• Added sample pseudo-code for creating a freeze wrapper for multiple PR regions and creating an external host on the same device.</td>
</tr>
<tr>
<td>November 2013</td>
<td>2013.11.04</td>
<td>Initial release</td>
</tr>
</tbody>
</table>