Pg193 Partial Reconfiguration Controller
Pg193 Partial Reconfiguration Controller
Controller v1.3
Chapter 1: Overview
Feature Summary. . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . 7
Unsupported Features. . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . 10
Licensing and Ordering Information . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . 10
Overview
The Partial Reconfiguration Controller consists of one or more Virtual Socket Managers
which connect to a single fetch path. A Virtual Socket (Figure 1-1) is a term that refers to a
Reconfigurable Partition (RP) plus any logic that exists in the static logic to assist the RP
with partial reconfiguration. For example, this logic could be used to isolate the static
design from the Reconfigurable Partition while reconfiguration occurs, or to ensure
Reconfigurable Modules are in a safe state before they are removed from the device. Some
designs might not require this, in which case a Virtual Socket is equivalent to a
Reconfigurable Partition.
X-Ref Target - Figure 1-1
Static Logic
Virtual Socket
Decoupler Decoupler
Reconfigurable
Partition
Decoupler Decoupler
Shutdown
Handler
The fetch path fetches bitstreams from an external configuration library and sends them to
the Internal Configuration Access Port (ICAP). The partial bitstreams are stored in a
configuration library.
.
AXI4-Lite Register Interface [optional] . Fetch Path
.
Virtual Socket Managers operate in parallel watching for trigger events to occur. Triggers
can be hardware based (signals) or software based (a register write). When a trigger is seen
by a Virtual Socket Manager, the Virtual Socket Manager maps the trigger to a
Reconfigurable Module and manages the reconfiguration of that Reconfigurable Module.
Each Virtual Socket Manager operates independently of the others, so while one Virtual
Socket Manager is partway through the load of a Reconfigurable Module, another can start
processing a trigger. Virtual Socket Managers have to queue for access to the fetch path.
The actual reconfiguration of each module, however, remains sequential.
• Active state: The Virtual Socket Manager is in control of the associated Virtual Socket.
It reacts to triggers and loads Reconfigurable Modules.
• Shutdown state: Something else is in control of the associated Virtual Socket. The
Virtual Socket Manager does not react to triggers and does not load Reconfigurable
Modules.
Each Virtual Socket Manager can have its own AXI4-Stream Status and Control channels
(independently optional) and can share a single AXI4-Lite register interface (also optional).
These interfaces are not required for operation and can be omitted if the Partial
Reconfiguration Controller can be fully independent in a particular system.
Feature Summary
Virtual Sockets and Reconfigurable Modules
The Partial Reconfiguration Controller supports up to 32 Virtual Sockets.
Each Virtual Socket can contain up to 128 Reconfigurable Modules, where each
Reconfigurable Module is defined by one partial bitstream (1). Different Virtual Sockets can
contain different numbers of Reconfigurable Modules. For example, Virtual Socket 0 might
have 32 Reconfigurable Modules, and Virtual Socket 1 might only have 2 Reconfigurable
Modules.
1. If the device being managed is an UltraScale device, each Reconfigurable Module also requires a Clearing bitstream.
The Partial Reconfiguration Controller provides support for all of these tasks and is
configurable on a per-Reconfigurable Module basis.
IMPORTANT: It is vital that only one of these interfaces be used at a time, and that multiple controllers
do not try to control the same Virtual Socket at the same time.
The Partial Reconfiguration Controller IP core offers two mechanisms to support this:
1. A simple arbitration protocol is used to arbitrate the access to the configuration ports.
You must supply an arbiter that is suitable for your system. If arbitration is not required,
the arbitration signals can be tied to constant values. For more information, see ICAP
Sharing Protocol.
2. Each Virtual Socket Manager can be placed into a shutdown state to prevent it from
trying to control the Virtual Socket. This allows other controllers (such as software or
JTAG) to have exclusive control of a Virtual Socket. For more information, see Shutdown
State.
These channels can be configured individually for each Virtual Socket Manager. For
example, the Virtual Socket Managers in an instance of the Partial Reconfiguration
Controller could be configured as follows:
Note: The STARTUP primitive does not support loading of partial bitstreams. IP, such as AXI SPI or AXI EMC
should not be configured to use the STARTUP primitive to clock or deliver partial bitstreams from external flash.
Bitstream Decompression
The Partial Reconfiguration Controller's API can be used to compress partial bitstreams, and
the core configured to decompress them before passing them to the ICAP. This is useful if
bitstream storage space is limited, or if the data path to the Partial Reconfiguration
Controller is bandwidth limited.
If bitstream decompression is selected, then all bitstreams received by the core must be
compressed. It is not possible to mix compressed and uncompressed bitstreams in the same
core instance.
Note: This compression scheme differs from the built-in Multi-Frame-Write (MFW) scheme
supported directly by write_bitstream and the configuration engine. Using
BITSTREAM.GENERAL.COMPRESS TRUE (only) will result in an incorrect format for a partial
bitstream for this decompression scheme (see Partial Bitstream Preparation). Both schemes can be
used together, although using the PRC compression on bitstreams generated with
BITSTREAM.GENERAL.COMPRESS FALSE generally results in smaller bitstreams.
Which scheme (or schemes) to use depends on your design goals. PRC compression reduces the
amount of data that needs to be stored and transported to the PRC but it does not reduce the
amount of data that needs to be passed through the ICAP. MFW compression reduces the amount of
data that has to be passed through the ICAP but it does not compress the bitstreams by as much as
the PRC compression scheme does. If your PR bottleneck is bitstream storage or transport over AXI,
PRC compression should be used. If the bottleneck is the amount of time taken to pass data through
the ICAP then MFW compression should be used. Both schemes can be used together to achieve
both advantages.
Note: It is not possible to predict how much any particular partial bitstream will compress by as the
amount of compression depends on the specifics of each partial bitstream. As a guide, we have
measured between 30% and 70% compression on a suite of partial bitstreams that have 50% or more
LUT and FF utilization. However, there is no guarantee that all partial bitstreams will fall within this
range.
Unsupported Features
• The Partial Reconfiguration Controller cannot be configured using the Vivado
set_property command. Instead, a custom set_property command is provided
with the core. For more information, see Configuring Tcl User Parameters.
• Encrypted bitstreams are not supported when a 7 series device is being controlled.
• Encrypted bitstreams can be used when an UltraScale or UltraScale+ device is being
controlled. However, the PRC may be unable to fully recover if a Fetch error occurs
during the load of an encrypted bitstream.
IP License Type
This Xilinx® LogiCORE™ IP module is provided at no additional cost with the Xilinx Vivado
Design Suite under the terms of the Xilinx End User License. Information about this and
other Xilinx LogiCORE IP modules is available at the Xilinx Intellectual Property page.
Product Specification
Overview
Operational States
Each Virtual Socket Manager can exist in two states:
• Active State
• Shutdown State
Each Virtual Socket Manager can be configured to start in either state after a reset, and
commands can be used to move a Virtual Socket Manager between states. Additionally, a
Virtual Socket Manager enters the shutdown state in the event of an error, unless it has
been configured not to.
Active State
The active state is the main state of each Virtual Socket Manager, and is where partial
reconfiguration is managed. Each Virtual Socket Manager follows a basic set of steps, as
shown in Figure 2-1. Note that dotted steps are optional.
X-Ref Target - Figure 2-1
Shutdown the
Load the new Start up the new
Wait for existing
Reconfigurable Reconfigurable
a Trigger Reconfigurable
Module Module
Module
X14316
Figure 2‐1: Basic Steps for Virtual Socket Manager in Active State
The Virtual Socket Manager starts by waiting for a trigger to arrive. When a trigger is seen,
the Virtual Socket Manager starts to shutdown any Reconfigurable Module found in the
Virtual Socket. This shutdown sequence can be configured on a per-Reconfigurable Module
basis. The valid options are:
• No shutdown is required.
• Hardware-only shutdown is required. The Virtual Socket Manager informs the
Reconfigurable Module that it will be removed, and waits until the Reconfigurable
Module gives permission. This is intended for cases where arbitrarily removing a
Reconfigurable Module could cause deadlock or other system corruption.
• Shutdown of hardware and then software is required. The Virtual Socket Manager
performs hardware shutdown as described above, and then issues an interrupt
informing software that the reconfigurable module will be removed. It then waits until
the software gives permission. This is intended for cases where the system software
may have to unload drivers or make other system changes.
• Shutdown of software and then hardware is required. As above, but with software
shutdown performed first.
See Reconfigurable Module Hardware and Software Shutdown for more information.
After the shutdown of any existing Reconfigurable Module is complete, the Virtual Socket
Manager asserts vsm_<name>_rm_decouple High and starts to process the trigger (1).
The signal vsm_<name>_rm_decouple remains asserted until the reconfigurable module
is successfully loaded, and is intended for use with decoupling logic which can be required
to isolate the Virtual Socket from the static logic while reconfiguration occurs.
1. When the device being managed is an UltraScale device, the clearing bitstream for the current Reconfigurable Module is
loaded before the trigger is processed. vsm_<name>_rm_decouple is asserted High after the Reconfigurable Module is
shutdown and before the clearing bitstream is loaded.
This decoupling logic is design specific and is not provided with the Partial Reconfiguration
Controller core.
The Virtual Socket Manager then requests access to the fetch path (1). When it gains access
to the fetch path, it configures the fetch path to load the correct bitstream for the new
Reconfigurable Module. If this completes with no errors, the Virtual Socket Manager will
start up the new Reconfigurable Module. There are two phases to this, each of which are
optional and can be configured on a per-Reconfigurable Module basis:
• Software startup: If enabled, the Virtual Socket Manager issues an interrupt informing
the software that the Reconfigurable Module has been loaded (if decoupling is
implemented, then the Reconfigurable Module is still decoupled at this stage, and
might not be operational), and waits until the software responds. This is intended for
cases where the system software might have to load drivers or make other system
changes. For more information, see Reconfigurable Module Software Startup.
• Reconfigurable Module Reset: If enabled, the Virtual Socket Manager asserts a reset
signal to the Reconfigurable Module to a configurable level for a configurable number
of clock cycles.
At this stage, the Virtual Socket Manager starts searching for new triggers to process.
Shutdown State
The shutdown state is where the Virtual Socket Manager does not respond to triggers and
does not load Reconfigurable Modules. There are several reasons why a Virtual Socket
Manager should be shutdown:
• There has been an error loading a Reconfigurable Module. In this case, the Virtual
Socket Manager shuts itself down, unless it has been configured not to.
• Something else, such as the Vivado® Design Suite Hardware Debugger or PCIe, needs
to load bitstreams into a Virtual Socket.
• The Virtual Socket Manager needs to be reprogrammed to change the triggers and the
Reconfigurable Modules.
The shutdown state can be entered by sending the Shutdown command to the Virtual
Socket Manager's CONTROL register. This command cannot be canceled. For more
information, see Shutdown Command.
1. When the device being managed is an UltraScale device, the Virtual Socket Manager has previously requested access to
the fetch path in order to load the clearing bitstream. A second request is needed to load the partial bitstream that loads
the new Reconfigurable Module. Other Virtual Socket Managers might have used the fetch path in the interim to load
their own bitstreams.
• Restart with no Status: This command is used when you exit the shutdown state
without having made any changes to the Virtual Socket. The Virtual Socket Manager
will resume with the information it had before shutdown. For more information, see
Restart with no Status Command.
• Restart with Status: This command is used when the user exits the shutdown state
after having made changes to the Virtual Socket. Specifically, this command must be
used if a Reconfigurable Module is loaded into the Virtual Socket when the Virtual
Socket Manager was in shutdown. The Virtual Socket Manager will resume with the
information supplied by you as part of the command. For more information, see Restart
with Status Command.
• vsm_<name>_rm_shutdown_req
• vsm_<name>_rm_decouple
• vsm_<name>_rm_reset
• vsm_<name>_sw_shutdown_req
• vsm_<name>_sw_startup_req
This feature allows the system to take control of the Virtual Socket reconfiguration while
still being able to manage hardware and software shutdown, decoupling, software start-up
and Reconfigurable Module reset. The status of the vsm_<name>_rm_shutdown_ack signal
can be retrieved from the STATUS register using the AXI4-Lite or AXI4-Stream status
channel interfaces. See User Control Command and STATUS Register.
Error Handling
The Partial Reconfiguration Controller detects and handles the following types of errors:
• Fetch Errors: These errors occur in the fetch path when a bitstream is being read from
the configuration library interface. This type of error occurs if the AXI4 Memory
Mapped bus connected to the configuration library returned an AXI response error.
• Bitstream Errors: These errors occur inside the FPGAs configuration interface, and
typically indicate that the bitstream is corrupt.
° Bad Format Errors: These errors occur when a compressed bitstream contains
invalid information.
° Bad Size Errors: These errors occur when a compressed bitstream ends in an invalid
place in the decompression algorithm.
If a fetch error, bitstream error, lost error, bad format error, or bad size error occurs, the
Partial Reconfiguration Controller responds as follows:
• The fetch path continues fetching the bitstream to maintain data path integrity.
• The ICAP interface continues to consume data to ensure the fetch path is drained, but it
does not pass any more data to the ICAP.
• If the error is a fetch error, and it occurred on the first word of the bitstream, the ICAP
interface does not pass anything to the ICAP.
• If the error is a fetch error, and it occurred on the second word of the bitstream, or
beyond, the ICAP interface does not pass anything else to the ICAP. It drains the fetch
path as described above, and then injects a DESYNC sequence into the ICAP.
• The Virtual Socket Manager that was attempting to load the failing bitstream will enter
the shutdown state, and does not process any more triggers until the Virtual Socket
Manager is restarted. This behavior is configurable when the core is generated, in
which case the Virtual Socket Manager will not enter the shutdown state.
• The error will be reported on the status interfaces.
If the error is a bad configuration error, the Partial Reconfiguration Controller responds as
follows:
• If the Virtual Socket Manager is full or empty. A full Virtual Socket is one that contains
a Reconfigurable Module. An empty Virtual Socket does not contain a Reconfigurable
Module.
• If the Virtual Socket Manager is configured to start in the shutdown state.
• If the Reconfigurable Module in the Virtual Socket is configured to have a start-up
phase (software start-up and/or reset).
• If the Virtual Socket Manager is configured to skip Reconfigurable Module start-up
after reset.
Figure 2-2 shows the behavior of the Virtual Socket Manager after leaving reset.
X-Ref Target - Figure 2-2
Is the
Virtual Socket
Empty
Full or
Empty?
Full
Enter the Shutdown State
Yes
Should
Does the
the Virtual Socket
Reconfigurable Module
No Manager start in the
require startup
Shutdown
steps?
state?
No
Yes
Should the Virtual
Socket Manager skip
Reconfigurable Module
startup states?
No
Perform Reconfigurable
Module Startup Steps
X14317
Performance
For details about performance, visit Performance and Resource Utilization.
Resource Utilization
For details about resource utilization, visit Performance and Resource Utilization.
Port Descriptions
In the following table, <name> is a user-defined name. For example,
vsm_<name>_hw_triggers could be:
Register Space
Overview
Each Virtual Socket Manager has a set of registers that can be accessed through the
optional AXI4-Lite interface. Each register is 32-bits wide, although some bits might not be
used in some cases. The registers in each Virtual Socket Manager are split into four banks,
where each bank has its own unique structure:
The General registers are used to control the Virtual Socket Manager, and retrieve its status
information. The remaining banks are used to store information required to load a
Reconfigurable Module.
The Trigger to Reconfigurable Module registers, the Reconfigurable Module registers and the
Bitstream Information registers operate as follows:
• A trigger identifier (1) is decoded and used to select a row in the Trigger to
Reconfigurable Module register bank (Bank 1). The selected register holds the identifier
of the Reconfigurable Module to be loaded by that trigger (RM_ID).
• The RM_ID is used to select a row of registers in the Reconfigurable Module
Information register bank (Bank 2).
• The lower register in the selected row (CONTROL) provides information about how the
Reconfigurable Module is to be shut down and started.
• The upper register in the selected row (BS Index) provides the row number in the
Bitstream Information register bank to access to get information about the bitstream
required to load the Reconfigurable Module. This information is the address in external
memory at which the bitstream is stored, its size in bytes, and its identifier.
Virtual Socket These bits contain the identifier of the Virtual Socket Manager. These identifiers are
Manager Select reported in the Configuration Information text file produced when the IP is
generated.
Bank Select An identifier representing the bank of registers to access.
0 = The General Register bank.
1 = The Trigger to Reconfigurable Module register bank.
2 = The Reconfigurable Module Information register bank.
3 = The Bitstream Information register bank.
Register Select This segment of the address has different interpretations depending on the bank
being accessed. The upper bits give the row of the bank to select, and the lower
bits give the column within the bank to select. If a bank has one column, zero bits
are required to select the column. If a bank has two columns, one bit is required to
select the column, etc. See Figure 2-4.
All slice ranges are identical across all Virtual Socket Managers. These, and each register
address, are available in the configuration information text file that is produced when the IP
is generated. See Output Generation for more details.
1. Only hardware triggers need to be decoded. Software triggers directly specify the row in the Trigger to Reconfigurable
Module register bank
SW Trigger xxx xxx xxx xxx xxx xxx The upper bits of
“Register Select”
xxx xxx xxx xxx xxx xxx select the row
The lower bits of “Register Select” select the column within each bank
X14314
STATUS Register
The STATUS register is read only and is mapped to the same address as the CONTROL
register.
CONTROL Register
The CONTROL register is write only, and is mapped to the same address as the STATUS
register.
SW_TRIGGER Register
The SW_TRIGGER register can be written and read.
The Trigger to Reconfigurable Module registers contain the mapping between the Triggers
and the Reconfigurable Modules to load. There can be more triggers than Reconfigurable
Modules, allowing for the in-field addition of Reconfigurable Modules and/or easier
triggering of the same Reconfigurable Module from multiple sources.
Each register is 32-bits wide, but only the lower X bits are used, where X =
Unused bits are ignored on writes, and return 0 on reads. The Trigger to Reconfigurable
Module registers can only be accessed when the Virtual Socket Manager is in the shutdown
state. If the Virtual Socket Manager is not in the shutdown state, reads return 0 and writes
are ignored.
There are two registers per row in this bank, and the LSB of Register Select is used to select
between them.
All registers in this bank are readable and writable when the Virtual Socket Manager is in
the shutdown state. If the Virtual Socket Manager is not in the shutdown state, reads return
0, and writes are ignored.
RM_BS_INDEX Register
RM_CONTROL Register
There are three registers per row in this bank, and the two LSBs of Register Select are used
to select between them.
• ID Register: LSBs = 0
• Address Register: LSBs = 1
• Size Register: LSBs = 2
When the device to be managed is an UltraScale device, all registers in this bank are
readable and writable when the Virtual Socket Manager is in the shutdown state.
Reconfigurable Modules for this type of device require two bitstreams, so all bitstream
identifiers are 0 or 1.
When the device to be managed is a 7 series or UltraScale+ device, the BS_ADDRESS and
BS_SIZE registers in this bank are readable and writable when the Virtual Socket Manager is
in the shutdown state. Reconfigurable Modules for this type of device only require one
bitstream, so all bitstream identifiers are 0. Writes to the BS_ID registers are ignored and
reads always return 0.
For all managed device types, reads from all registers in this bank return 0 and writes to all
registers in this bank are ignored if the Virtual Socket Manager is not in the shutdown state.
BS_ID Register
BS_ADDRESS Register
Table 2‐13: BS_ADDRESS Register Format
Bits Meaning Details
31:0 ADDRESS The address of the bitstream in the configuration library interface.
BS_SIZE Register
If in-field upgrades are planned for a design, the extra space for these items should be
allocated at core generation time.
Clocking
There are two clock ports: icap_clk for the logic driving the ICAP interface, and clk for
everything else.
The number of synchronization stages used when passing signals between domains is
configurable.
Resets
There are two reset ports: icap_reset for the logic driving the ICAP interface, and reset
for everything else. The exact timing of these resets relative to each other is not important.
However, if one is asserted, both must be asserted. For example, resetting the ICAP
interface without resetting the rest of the Partial Reconfiguration Controller could result in
lockup, and vice versa. Additionally, no triggers should be generated before both resets
have been asserted and released.
RECOMMENDED: It is highly recommended that all Virtual Socket Managers are placed into the
shutdown state (and checked to see that they are in shutdown) before applying a reset.
If this is not possible, then the following conditions must be met before the core is reset:
1. The ICAP interface must not be transferring a bitstream to the ICAP. Interrupting a
bitstream transfer could put the device into an unstable state and could require a full
chip reconfiguration.
2. Virtual Socket Managers that are in the active state must have no pending triggers.
Resetting a Virtual Socket Manager that has started to process a trigger can corrupt the
state of the Virtual Socket Manager. For Virtual Socket Managers that control UltraScale
devices, this could make it impossible to load a new Reconfigurable Module in that
Virtual Socket.
Note: The active reset level is configurable.
Shutdown Command
The Shutdown command instructs the Virtual Socket Manager to enter the shutdown state
at the earliest safe opportunity. There can be a long delay (indeterminate) between the
request and when the Virtual Socket Manager enters the shutdown state. You cannot cancel
the Shutdown command after it has been sent.
This command can only be used if the Virtual Socket Manager is not in the shutdown state.
The BYTE and HALFWORD fields of the control word are not used with this command.
This command should be used to restart a Virtual Socket Manager in shutdown if the
Virtual Socket has not been modified during shutdown.
This command can only be used if the Virtual Socket Manager is in the shutdown state.
The BYTE and HALFWORD fields of the control word are not used with this command.
This command should be used to restart a shutdown Virtual Socket Manager if the Virtual
Socket has been modified during shutdown (that is, a Reconfigurable Module is loaded into
the Virtual Socket by something other than the Virtual Socket Manager).
This command must only be used with a full status if the loaded Reconfigurable Module is
known to the Virtual Socket Manager. If a Reconfigurable Module is loaded that is unknown
to the Virtual Socket Manager, the Virtual Socket must be left in an empty state before the
Virtual Socket Manager is restarted. An empty state means that either there is no
Reconfigurable Module in the Virtual Socket, or that the loaded Reconfigurable Module
does not need any shutdown steps. When the Virtual Socket is on an UltraScale device,
there is an additional requirement that the loaded Reconfigurable Module is unmasked and
does not need its clearing bitstream loaded.
This command can only be used if the Virtual Socket Manager is in the shutdown state.
The BYTE and HALFWORD fields of the control word are used as follows:
Proceed Command
The Proceed command instructs the Virtual Socket Manager to proceed with processing the
Reconfigurable Module. If the Virtual Socket Manager has asserted the
vsm_<name>_sw_shutdown_req or vsm_<name>_sw_startup_req interrupt signals, it will stall
until this command occurs. This command is ignored if neither of these signals is asserted.
This command can only be used if the Virtual Socket Manager is not in the shutdown state.
The BYTE and HALFWORD fields of the control word are not used with this command.
• vsm_<name>_rm_shutdown_req
• vsm_<name>_rm_decouple
• vsm_<name>_rm_reset
• vsm_<name>_sw_shutdown_req
• vsm_<name>_sw_startup_req
When set, the values remain set until another User Control command is sent, or one of the
Restart commands are sent.
This command can only be used if the Virtual Socket Manager is in the shutdown state.
The BYTE and HALFWORD fields of the control word are used as follows:
° 0: Sets vsm_<name>_rm_shutdown_req to 0.
° 1: Sets vsm_<name>_rm_shutdown_req to 1.
• BYTE[1]: Controls rm_decouple.
° 0: Sets vsm_<name>_rm_decouple to 0.
° 1: Sets vsm_<name>_rm_decouple to 1.
• BYTE[2]: Controls sw_shutdown_req.
° 0: Sets vsm_<name>_sw_shutdown_req to 0.
° 1: Sets vsm_<name>_sw_shutdown_req to 1.
• BYTE[3]: Controls sw_startup_req.
° 0: Sets vsm_<name>_sw_startup_req to 0.
° 1: Sets vsm_<name>_sw_startup_req to 1.
• BYTE[4]: Controls rm_reset.
° 0: Sets vsm_<name>_rm_reset to 0.
° 1: Sets vsm_<name>_rm_reset to 1.
• HALFWORD: Not used.
Protocol Description
Hardware Triggers
If a Virtual Socket Manager is configured to have hardware triggers, it has a vector input
signal, vsm_<name>_hw_triggers . Each bit in this signal is processed independently, and
maps directly to a trigger identifier of the same number. For example:
• etc.
When trigger N occurs, the Virtual Socket Manager records that fact and the trigger
becomes available for processing. The trigger is ignored if it occurs again before the
previous activation is selected for processing. Only one instance of a trigger activation is
stored.
X-Ref Target - Figure 3-1
CLK
VSM?NAME?HW?TRIGGERS
VSM?NAME?HW?TRIGGERS
)NTERNAL 4RIGGER "EING 0ROCESSED
Figure 3-1 shows an example of the hardware triggers in operation. Note that the clock
cycle numbers are just for illustration and do not relate to any fixed latency.
At this stage, trigger 1 is both pending and being processed. When the Reconfigurable
Module mapped to trigger 1 loads, the Virtual Socket Manager immediately starts to
remove it and process the pending trigger, which will load the same Reconfigurable
Module. Loading an already loaded Reconfigurable Module might be useful in certain
circumstances so the Partial Reconfiguration Controller allows it. Proper trigger
management can avoid this situation if it is not desired.
Note: It would normally be asserted before the reset, resulting in no visible change. However, its
value may have been changed by the user using the register interface.
2. If the Virtual Socket was full before reset, and the Reconfigurable Module was
configured to have shutdown_required = No then
vsm_<name>_rm_shutdown_req will be deasserted. See Figure 3-10.
3. If the Virtual Socket was full before reset, and the Reconfigurable Module was
configured to have shutdown_required = HW, HW/SW or SW/HW, then
vsm_<name>_rm_shutdown_req will be asserted. See Figure 3-9.
CLK
VSM?NAME?RM?SHUTDOWN?REQ
VSM?NAME?RM?SHUTDOWN?ACK
.O UPPER LIMIT ON TIME FOR 2ECONFIGURABLE -ODULE TO RESPOND
CLK
4RIGGER 4RIGGER %VENT
RM?SHUTDOWN?REQ
RM?SHUTDOWN?ACK
SW?SHUTDOWN?REQ
SW?STARTUP?REQ
#OMMAND 0ROCEED
RM?DECOUPLE
RM?RESET
Figure 3‐3: vsm_<name>_rm_shutdown_req during a Reconfigurable Module load operation when the
existing Reconfigurable Module is configured to have SHUTDOWN_REQUIRED = no
CLK
4RIGGER 4RIGGER %VENT
RM?SHUTDOWN?REQ
RM?SHUTDOWN?ACK
SW?SHUTDOWN?REQ
SW?STARTUP?REQ
#OMMAND 0ROCEED
RM?DECOUPLE
RM?RESET
Figure 3‐4: vsm_<name>_rm_shutdown_req during a Reconfigurable Module load operation when the
existing Reconfigurable Module is configured to have SHUTDOWN_REQUIRED = hw
CLK
4RIGGER 4RIGGER %VENT
RM?SHUTDOWN?REQ
RM?SHUTDOWN?ACK
SW?SHUTDOWN?REQ
SW?STARTUP?REQ
RM?DECOUPLE
RM?RESET
Figure 3‐5: vsm_<name>_rm_shutdown_req during a Reconfigurable Module load operation when the
existing Reconfigurable Module is configured to have SHUTDOWN_REQUIRED = hw/sw
CLK
4RIGGER 4RIGGER %VENT
RM?SHUTDOWN?REQ
RM?SHUTDOWN?ACK
SW?SHUTDOWN?REQ
SW?STARTUP?REQ
RM?DECOUPLE
RM?RESET
Figure 3‐6: vsm_<name>_rm_shutdown_req during a Reconfigurable Module load operation when the
existing Reconfigurable Module is configured to have SHUTDOWN_REQUIRED = sw/hw
Note: vsm_<name>_rm_shutdown_req stays asserted while software for the new Reconfigurable
Module is being set up, and while the new Reconfigurable Module is being reset. This is to prevent
the system trying to interact with the new Reconfigurable Module until it is ready to operate.
CLK
4RIGGER 4RIGGER %VENT
RM?SHUTDOWN?REQ
RM?SHUTDOWN?ACK
SW?SHUTDOWN?REQ
SW?STARTUP?REQ
#OMMAND 0ROCEED
RM?DECOUPLE
RM?RESET
Figure 3‐7: vsm_<name>_rm_shutdown_req during a Reconfigurable Module load operation when all
optional startup steps are disabled
Figure 3-8, Figure 3-9 and Figure 3-10 show how vsm_<name>_rm_shutdown_req
responds to a reset.
Figure 3-8 shows an empty Virtual Socket Manager during a core reset.
X-Ref Target - Figure 3-8
CLK
63- IS &ULL
2ESET 2ESET %VENT
RM?SHUTDOWN?REQ
RM?RESET
RM?DECOUPLE
Figure 3‐8: vsm_<name>_rm_shutdown_req during a core reset while the Virtual Socket Manager is
empty
Figure 3-9 shows a full Virtual Socket Manager during a core reset when the existing
Reconfigurable Module is configured to have SHUTDOWN_REQUIRED = HW, SW/HW or
HW/SW.
X-Ref Target - Figure 3-9
CLK
63- IS &ULL
2ESET 2ESET %VENT
RM?SHUTDOWN?REQ
SW?STARTUP?REQ
RM?RESET
Figure 3‐9: vsm_<name>_rm_shutdown_req during a core reset while the Virtual Socket Manager is
full. The existing Reconfigurable Module is configured to have SHUTDOWN_REQUIRED = HW, SW/HW or
HW/SW (Optional Reconfigurable Module startup steps are enabled).
Figure 3-10 shows a full Virtual Socket Manager during a core reset when the existing
Reconfigurable Module is configured to have SHUTDOWN_REQUIRED = No.
X-Ref Target - Figure 3-10
CLK
63- IS &ULL
2ESET 2ESET %VENT
RM?SHUTDOWN?REQ
RM?RESET
RM?DECOUPLE
Figure 3‐10: vsm_<name>_rm_shutdown_req during a core reset while the Virtual Socket Manager is
full. The existing Reconfigurable Module is configured to have SHUTDOWN_REQUIRED = No
(Optional Reconfigurable Module startup steps are disabled.)
Additionally, software might also need to shut down before a Reconfigurable Module is
removed. For example, a device driver might need to be unloaded. The Partial
Reconfiguration Controller provides the vsm_<name>_sw_shutdown_req signal to aid this
process. This can be attached to an interrupt controller, or any other scheme the design has
for communicating with software. Figure 3-11 shows the protocol. When the
Reconfigurable Module is being removed, vsm_<name>_sw_shutdown_req is set to 1. The
software should put itself into a safe state as soon as possible. There is no time limit for this
to occur. When the software is ready for the Reconfigurable Module to be removed, it must
send the Proceed command to the Virtual Socket Manager.
X-Ref Target - Figure 3-11
CLK
VSM?NAME?SW?SHUTDOWN?REQ
#OMMAND 0ROCEED
.O UPPER LIMIT ON TIME FOR 3OFTWARE TO RESPOND
CLK
VSM?NAME?SW?STARTUP?REQ
#OMMAND 0ROCEED
.O UPPER LIMIT ON TIME FOR 3OFTWARE TO RESPOND
• 0: This turns off arbitration and removes the arbitration protocol ports from the core’s
boundary.
• 1: This turns arbitration on for the case where there is no external latency added to the
arbitration signals.
• 2: This turns arbitration on for the case where there is external latency added to the
arbitration signals.
Protocol versions 1 and 2 are similar so are described together with the minor differences
explained at the end of this section.
The IP sets cap_req to 1 on every clock cycle where it has data to transfer to the ICAP. Data
transfer occurs only when the arbiter sets cap_gnt to 1 as well. The arbiter must keep
cap_gnt as 1 until cap_req becomes 0.
The arbiter can set cap_rel to 1 to signal that something else requires access to the ICAP.
If the Partial Reconfiguration Controller sees cap_rel equal to 1, it completes any
bitstream load that is in progress and then sets cap_req to 0. cap_rel should be asserted
by the arbiter on every clock cycle where something else is requesting access to the ICAP.
When set to 1, this signal should remain at 1 until cap_req returns to 0.
Protocols 1 and 2 differ at the end of a transfer. In the case where there is no latency added
to the arbitration signals (protocol 1), the arbiter can keep cap_gnt asserted and the
Partial Reconfiguration Controller can immediately request a new transfer.
In the case where there is latency added to the arbitration signals (protocol 2), the arbiter
must set cap_gnt to 0. When this occurs, the Partial Reconfiguration Controller will set
cap_req to 0.
.
X-Ref Target - Figure 3-13
ICAP?CLK
CAP?REQ
CAP?GNT
.O DATA TRANSFER $ATA TRANSFER
CAP?REL
3OMETHING ELSE IS REQUESTING )#!0 !CCESS
Decoupling
Each Virtual Socket Manager has an active-high output signal called
vsm_<name>_rm_decouple. This signal is provided to control user supplied decoupling
logic. It is asserted high under the following conditions:
It is deasserted at all other times. vsm_<name>_rm_decouple may change value when the
PRC is reset. The following rules apply:
1. If the Virtual Socket was empty before reset, vsm_<name>_rm_decouple will assert
during reset. See Figure 3-17.
2. If the Virtual Socket was full before reset then vsm_<name>_rm_shutdown_req will
be deasserted. See Figure 3-15 and Figure 3-18.
Note: vsm_<name>_rm_decouple would normally be asserted if the VSM is empty, and
deasserted when full, so a reset would normally result in no visible change. However, the value of
vsm_<name>_rm_decouple may have been changed by the user using the register interface.
Note: vsm_<name>_rm_decouple stays asserted while software for the new Reconfigurable
Module is being set up. This is to stop the Reconfigurable Module operating before the system is
ready.
X-Ref Target - Figure 3-14
CLK
4RIGGER 4RIGGER %VENT
RM?SHUTDOWN?REQ
RM?SHUTDOWN?ACK
SW?SHUTDOWN?REQ
SW?STARTUP?REQ
RM?DECOUPLE
RM?RESET
Figure 3‐14: vsm_<name>_rm_decouple during a Reconfigurable Module load operation (all optional
steps enabled)
As shown in Figure 3-15, if the startup software step (Startup SW) occurs after a core reset,
vsm_<name>_rm_decouple will remain deasserted during this step.
X-Ref Target - Figure 3-15
CLK
63- IS &ULL
2ESET 2ESET %VENT
SW?STARTUP?REQ
RM?RESET
RM?DECOUPLE
Figure 3‐15: vsm_<name>_rm_decouple during a core reset while the Virtual Socket Manager is full.
Optional Reconfigurable Module startup steps are enabled.
CLK
4RIGGER 4RIGGER %VENT
RM?DECOUPLE
Figure 3‐16: vsm_<name>_rm_decouple during a Reconfigurable Module load operation when all
optional steps are disabled
Figure 3-15, Figure 3-17 and Figure 3-18 show how vsm_<name>_rm_decouple responds
to a reset.
CLK
63- IS &ULL
2ESET 2ESET %VENT
SW?STARTUP?REQ
RM?RESET
RM?DECOUPLE
Figure 3‐17: vsm_<name>_rm_decouple during a core reset while the Virtual Socket Manager is
empty
CLK
63- IS &ULL
2ESET 2ESET %VENT
SW?STARTUP?REQ
RM?RESET
RM?DECOUPLE
Figure 3‐18: vsm_<name>_rm_decouple during a core reset while the Virtual Socket Manager is full.
(Optional Reconfigurable Module startup steps are disabled.)
RM_RESET
Each Virtual Socket Manager has an output signal called vsm_<name>_rm_reset. This
signal is provided to reset Reconfigurable Modules just after they are loaded. Its
enablement, active value and duration are configurable for each Reconfigurable Module. It
is only asserted under three conditions:
1. Just after a Reconfigurable Module is loaded, if reset is enabled for that Reconfigurable
Module.
2. When the core has been reset, the Virtual Socket Manager is full, reset is enabled for
that Reconfigurable Module, and Skip Startup After Reset is disabled.
3. When the Virtual Socket Manager is in the shutdown state and
vsm_<name>_rm_reset is directly manipulated through one of the control interfaces.
If software startup is enabled then this occurs before the Reconfigurable Module is reset.
vsm_<name>_rm_reset is deasserted at all other times. It does not change when the
Partial Reconfiguration Controller is reset.
CLK
4RIGGER 4RIGGER %VENT
RM?SHUTDOWN?REQ
RM?SHUTDOWN?ACK
SW?SHUTDOWN?REQ
SW?STARTUP?REQ
RM?DECOUPLE
RM?RESET
Figure 3‐19: vsm_<name>_rm_reset (configured as active high) during a Reconfigurable Module load
operation when all optional steps are enabled.
Figure 3-20 shows vsm_<name>_rm_reset being asserted during the startup steps after a
core reset. These steps are optional. If the Virtual Socket Manager is configured to skip
these steps after reset, vsm_<name>_rm_reset is not asserted.
X-Ref Target - Figure 3-20
CLK
63- IS &ULL
2ESET 2ESET %VENT
SW?STARTUP?REQ
RM?RESET
RM?DECOUPLE
Figure 3‐20: vsm_<name>_rm_reset (configured as active high) during a core reset while the Virtual
Socket Manager is full. Optional Reconfigurable Module startup steps are enabled.
For example:
1. The core's Customize IP dialog box is used to inform the Virtual Socket Manager that
the power-on Reconfigurable Module has an active high reset. The Virtual Socket
Manager will be generated to set vsm_<name>_rm_reset to 0 (deasserted).
2. The core's API is used to change the Virtual Socket Manager directly in the netlist to tell
it that the power-on Reconfigurable Module has an active low reset.
3. When the Virtual Socket Manager exits power-on reset, vsm_<name>_rm_reset will
remain at 0 for approximately 6 clock cycles because it was originally configured to have
a Reconfigurable Module with an active high reset. The Reconfigurable Module will be
inadvertently reset during this time.
• Vivado Design Suite User Guide: Designing IP Subsystems using IP Integrator (UG994)
[Ref 1]
• Vivado Design Suite User Guide: Designing with IP (UG896) [Ref 2]
• Vivado Design Suite User Guide: Getting Started (UG910) [Ref 5]
• Vivado Design Suite User Guide: Logic Simulation (UG900) [Ref 6]
If you are customizing and generating the core in the Vivado IP integrator, see the Vivado
Design Suite User Guide: Designing IP Subsystems using IP Integrator (UG994) [Ref 1] for
detailed information. IP integrator might auto-compute certain configuration values when
validating or generating the design. To check whether the values do change, see the
description of the parameter in this chapter. To view the parameter value, run the
validate_bd_design command in the Tcl console.
You can customize the IP for use in your design by specifying values for the various
parameters associated with the IP core using the following steps:
For details, see the Vivado Design Suite User Guide: Designing with IP (UG896) [Ref 2] and
the Vivado Design Suite User Guide: Getting Started (UG910) [Ref 5].
Note: Figures in this chapter are illustrations of the Vivado Integrated Design Environment (IDE).
The layout depicted here might vary from the current version.
Validation Tab
This tab is available on the left of the Customize IP dialog box and shares space with the IP
Symbol tab, the Address Map tab, and the Trigger Mapping tab. This tab is displayed by
default. The Validation tab lists any errors that remain with the current configuration. The
core cannot be generated until all listed errors are fixed. When the configuration contains
no errors, the text “There are no errors” displays in the tab.
Global Options
This tab is available on the right of the Customize IP dialog box and shares space with the
Virtual Socket Options tab. The Global Options tab is used to configure the parts of the core
that do not depend on the number of Virtual Socket Managers, or their configuration. The
following options are available:
• Enable the AXI Lite Interface: Enables or disables the AXI4-Lite register interface.
• Reset Active Level: Configures the core to respond to an active-High or an active-Low
reset.
• Managed Device Type: Select the type of device to be managed by the core. This is
the device where the Virtual Sockets and connected ICAP primitive reside.
• CAP arbitration protocol: Select the type of CAP arbitration required.
• Bitstream Compression: Select whether the decompression block is required. If
enabled, all partial bitstreams must be compressed (see Partial Bitstream Preparation).
• FIFO Depth: The depth of the FIFO in the fetch path. Valid values are 16, 32, 64, 128,
256, 512, 1024, 2048, 4096, 8192, 16384, 32768, 65536, and 131072. The value 16 is
only available when the number of CDC Stages is set to 2 or 3.
• FIFO Implementation: Configures the FIFO in the fetch path to use Block RAMs or
Distributed RAMs.
• CDC Stages: The number of synchronization stages to use when crossing between
clock domains. Valid values are 2, 3, 4, 5, and 6. Using 4, 5, or 6 requires a minimum
FIFO depth of 32 entries.
Figure 4-1 and Figure 4-2 shows the Virtual Socket Manager Options. The tab is split into
four areas:
1. Control Buttons
2. Virtual Socket Manager Options
3. Reconfigurable Module Options
4. Trigger Options
X-Ref Target - Figure 4-1
2 3
Figure 4‐1: Virtual Socket Manager Options When Managing a 7 Series or UltraScale+ Device
A
X-Ref Target - Figure 4-2
Figure 4‐2: Additional Virtual Socket Manager Options When Managing an UltraScale Device
Control Buttons
There are four control buttons available, three of which are automatically hidden when not
required:
• New Virtual Socket Manager: Click this button to add a new Virtual Socket Manager
to the core.
• New Reconfigurable Module: Click this button to add a new Reconfigurable Module
to the currently selected Virtual Socket Manager. This button is only available when a
Virtual Socket Manager is selected.
• Delete Virtual Socket Manager: Click this button to delete the currently selected
Virtual Socket Manager. This button is only available when a Virtual Socket Manager is
selected.
• Delete Reconfigurable Module: Click this button to delete the currently selected
Reconfigurable Module from the currently selected Virtual Socket Manager. This button
is only available when a Reconfigurable Module is selected.
1. A Reconfigurable Partition in a static bitstream can be implemented as a black box or a pseudo black box (See Vivado
Design Suite User Guide: Partial Reconfiguration (UG909) [Ref 3]). When the device being managed is a 7 series or
UltraScale+ device, this option can be ignored by the Partial Reconfiguration Controller core if the system has no need to
ever revert the Reconfigurable Partition back to being a black box. However, when the device being managed is an
UltraScale device, the black box's clearing bitstream must be loaded before another Reconfigurable Module can be
loaded, so the black box must be defined as a Reconfigurable Module in the core. If there is no need to ever revert the
Reconfigurable Partition back to being a black box, the address and size information for this Reconfigurable Module's
partial bitstream can be left at 0. In this case, it should not be mapped to a trigger.
° Not Required: The Reconfigurable Module does not need to be informed that it
will be removed.
For more information, see Reconfigurable Module Hardware and Software Shutdown,
page 37.
• Startup Type:
° Not Required: The system software does not need to be informed that the
Reconfigurable Module has been loaded.
° Software Only: The system software needs to be informed that the Reconfigurable
Module has been loaded.
For more information, see Reconfigurable Module Software Startup, page 43.
• Reset Type:
° Not Required: The Reconfigurable Module does not need to be reset after it has
been loaded.
• Bitstream 0 Size: The size (in bytes) of this Reconfigurable Module bitstream in the
configuration library interface. This must be a multiple of 32 bits (bottom two bits of
the size must be 0).
• Bitstream 0 is a Clearing Bitstream: Click this option if this bitstream is a clearing
Bitstream. This option is only available when the device to be managed is an UltraScale
device.
• Bitstream 1 Address: The address of this Reconfigurable Module bitstream in the
configuration library interface. This must be aligned to a 32-bit word boundary
(bottom two bits must be 0). This option is only available when the device to be
managed is an UltraScale device.
• Bitstream 1 Size: The size (in bytes) of this Reconfigurable Module bitstream in the
configuration library interface. This must be a multiple of 32 bits (bottom two bits of
the size must be 0). This option is only available when the device to be managed is an
UltraScale device.
• Bitstream 1 is a Clearing Bitstream: Click this option if this bitstream is a clearing
Bitstream. This option is only available when the device to be managed is an UltraScale
device.
Trigger Options
• Number of Hardware Triggers: Specify the number of triggers in the Virtual Socket
Manager that can be activated from dedicated hardware signals. For more information,
see Hardware Triggers, page 36.
• Number of Triggers Allocated: Specify the number of triggers that this Virtual Socket
Manager has.
• First Trigger to display: A Virtual Socket Manager can contain many more triggers
than it is efficient to display in the Customize IP dialog box. A maximum of four
triggers are shown at any one time, with the first trigger shown selected by this
drop-down list.
• Trigger ID: [Read only] The identifier of the trigger in each row of the table.
• Reconfigurable Module to Load: The Reconfigurable Module to load when the
Trigger ID trigger is seen for this Virtual Socket Manager.
• Lock the Trigger: Used to control whether the trigger is locked to the specified
Reconfigurable Module, or whether it will change when Reconfigurable Modules are
added or removed.
By default, trigger T loads the Reconfigurable Module with identifier T, modulus the
number of Reconfigurable Modules in the Virtual Socket Manager. This means that, by
default, every trigger maps to a defined Reconfigurable Module, and all Reconfigurable
Modules can be triggered. Adding a new Reconfigurable Module causes the triggers to
remap without any intervention.
To override this for a trigger, lock it to the value selected by the Reconfigurable
Module to Load option. When a trigger is locked, it will not change if new
Reconfigurable Modules are added. If a trigger’s Reconfigurable Module is
subsequently deleted, the trigger will unlock (if locked) and revert to using its default
value.
User Parameters
Table 4-1 shows the relationship between the fields in the Vivado IDE and the User
Parameters (which can be viewed in the Tcl console).
RM_0
Number of RMs allocated VS.<vsname>.NUM_RMS_ALLOCATED 2
Reconfigurable Module to
No equivalent User Parameter
Configure
No equivalent User Parameter
The name of each Reconfigurable Module is specified
Reconfigurable Module Name
as part of the user parameter name (shown as
<rmname> below)
VS.<vsname>.RM.<rmname>.SHUTDOWN_REQUIRE
Shutdown Type no
D
Not Required no
Hardware Only hw
HW then SW hw/sw
SW then HW sw/hw
Startup Type VS.<vsname>.RM.<rmname>.STARTUP_REQUIRED no
Not Required no
Software Only sw
Reset Type VS.<vsname>.RM.<rmname>.RESET_REQUIRED no
Not Required no
Active High high
Active Low low
Duration of Reset VS.<vsname>.RM.<rmname>.RESET_DURATION 1
Notes:
1. <bsid> can only be 0 when the device to be managed is a 7 series or an UltraScale+ device. <bsid> can be 0 or 1 when the
device being managed is an UltraScale device.
Example:
Output Generation
The Partial Reconfiguration Controller delivers standard synthesis and simulation models.
For details, see the Vivado Design Suite User Guide: Designing with IP (UG896) [Ref 2].
In addition, a configuration information text file is delivered with the core, and located in:
° The Virtual Socket Manager identifiers are required to access the registers in the
Virtual Socket Managers.
° The Reconfigurable Module identifiers are required to access the correct registers
in the Reconfigurable Module information register bank. They are also required if
the triggers are reprogrammed at run-time.
• The MSBs and LSBs of the following address fields:
° Bank Select
° Register Select
• The address of each register in the generated core.
Required Constraints
This section is not application for this IP core.
Clock Frequencies
The ICAP clock has to be constrained to the maximum frequency of the ICAP port, or less.
For the maximum frequency for your device family, see the applicable DC and AC switching
characteristics data sheet (refer to References in Appendix C).
Clock Management
This section is not applicable for this IP core.
Clock Placement
This section is not applicable for this IP core.
Banking
This section is not applicable for this IP core.
Transceiver Placement
This section is not applicable for this IP core.
Simulation
For comprehensive information about Vivado simulation components, as well as
information about using supported third-party tools, see the Vivado Design Suite User
Guide: Logic Simulation (UG900) [Ref 6].
IMPORTANT: For cores targeting 7 series or Zynq®-7000 devices, UNIFAST libraries are not supported.
Xilinx IP is tested and qualified with UNISIM libraries only.
Customizing the core post implementation can be useful when the partial bitstream sizes
are not known when the Partial Reconfiguration Controller is initially configured, or when
the final set of Reconfigurable Modules have not been decided when the Partial
Reconfiguration Controller is initially configured.
IMPORTANT: Changes made to the netlist are not reflected in the original core configuration. Updating
the original core configuration could trigger a new implementation run of the entire design.
° If the Partial Reconfiguration Controller IP definition and the netlist are already
open, type this command:
set config [get_property CONFIG.ALL_PARAMS [get_ips <IP NAME>]]
Note: <ip path> is the path to the Partial Reconfiguration Controller instance in the netlist.
For example, i_prc/U0.
4. Modify the descriptor as required using the High Level Commands or Low Level
Commands. For example,
prc_v1_3::netlist::set_trigger dscr vs_shift 0 rm_shift_left
prc_v1_3::netlist::set_rm_bs_address dscr vs_shift rm_shift_left 0xAE9DF4
prc_v1_3::netlist::set_rm_bs_size dscr vs_shift rm_shift_left 375300
5. Apply the changes in the descriptor to the Partial Reconfiguration Controller instance in
the netlist.
prc_v1_3::netlist::apply_descriptor dscr
Mandatory Commands
These commands must be run when customizing the core post implementation.
Example Usage
The following example can be used as a starting point for your own customization.
Important Notes
• Changes made to the netlist directly are not reflected in the original IP’s configuration.
Doing so could trigger a new implementation run of the entire design
• These commands use the IP's configuration as their starting point. Any changes made
in the netlist will be lost if a new descriptor is created and further changes made. For
example, the following steps will cause Reconfigurable Module “A” to be lost:
1. A descriptor is created based on the IP's configuration (get_descriptor) and
Reconfigurable Module “A” is added.
2. The descriptor is applied to the netlist (apply_descriptor). The PRC instance in the
netlist now contains the new Reconfigurable Module “A”.
3. A descriptor is created based on the IP's configuration (get_descriptor) because
further changes have to be made.
4. Reconfigurable Module “A” has now been lost. The descriptor is only based on the IP's
configuration and Reconfigurable Module “A” does not exist in that (it was only added
to the PRC instance in the netlist, not to the PRC's configuration).
To avoid losing netlist changes, all changes must be made to the same descriptor.
If bitstream compression has been enabled in the core then the “-c 1” parameter must
be added to the command. If bitstream compression is disabled then “-c 0” can be
added, or the -c option can be completely omitted. For example:
If you are unsure if byte swapping is required, a simple hardware check can be
performed:
a. Create a version of the design with an ILA on the PRC's Configuration Library
interface.
b. Trigger the ILA on m_axi_mem_rvalid asserting and look at the data on
m_axi_mem_rdata.
000000bb
11220044
aa995566
Note: These will be surrounded by FFFFFFFF words and may not appear immediately next
to each other.
d. If compression is enabled, the first word to be fetched should be 950000XX, where
XX can take on any value. For example, 9500000F, 9500001C.
e. If you receive (compression off):
bb000000
44002211
665599aa
or
If any other values are received, the partial bitstream isn't stored at the location
programmed into the PRC.
4. The addresses used must match the bitstream addresses programmed into the core.
Also, the BIN file sizes must match the bitstream sizes programmed into the core. The
sizes are available from the file system or the Vivado Tcl command line using this
command:
file size <partial>.bin
Note: This information is required when the core is configured, but is not available until the
static and partial bitstreams have been generated. There are several ways to program the core
with this information:
• Program the values directly into the netlist using the commands described in
Customizing the Core Post Implementation.
• Use the AXI4-Lite interface to program the core at run time.
• Leave the information as zero in the Partial Reconfiguration Controller, implement the
entire design, obtain the required values, configure the Partial Reconfiguration
Controller with the correct information, and execute a second complete
implementation run. This approach is not suitable if the partial bitstream files change
size between runs. This can occur if bitstream compression is enabled, or if you change
any of the following:
If the design uses the PR Bitstream Monitor IP to trace partial bitstream flow then
prc_v1_3::format_bin_for_icap can be used to instrument the partial bitstreams
with the required identifiers.
To enable this, add -insert_ids 1 to the command. To disable the behavior, add
-insert_ids 0 to the command (or omit the -insert_ids option).
For example, the following command compresses the bin file and inserts:
Parameter Changes
None
Port Changes
The timing of vsm_<name>_rm_shutdown_req has changed in this release.
Debugging
This appendix includes details about resources available on the Xilinx® Support website
and debugging tools.
Documentation
This product guide is the main document associated with the Partial Reconfiguration
Controller. This guide, along with documentation related to all products that aid in the
design process, can be found on the Xilinx Support web page or by using the Xilinx
Documentation Navigator.
Download the Documentation Navigator from the Downloads page. For more information,
open the online help after installation.
Answer Records
Answer Records include information about commonly encountered problems, helpful
information on how to resolve these problems, and any known issues with a Xilinx product.
Answer Records are created and maintained daily ensuring that users have access to the
most accurate information available.
Answer Records for this core can be located by using the Search Support box on the main
Xilinx support web page. To maximize your search results, use proper keywords such as
• Product name
• Tool message(s)
• Summary of the issue encountered
A filter search is available after results are returned to further target the results.
AR: 62044
Technical Support
Xilinx provides technical support in the Xilinx Support web page for this LogiCORE™ IP
product when used as described in the product documentation. Xilinx cannot guarantee
timing, functionality, or support if you do any of the following:
• Implement the solution in devices that are not defined in the documentation.
• Customize the solution beyond that allowed in the product documentation.
• Change any section of the design labeled DO NOT MODIFY.
To contact Xilinx Technical Support, navigate to the Xilinx Support web page.
Debug Tools
Vivado Design Suite Debug Feature
The Vivado ® Design Suite debug feature inserts logic analyzer and virtual I/O cores directly
into your design. The debug feature also allows you to set trigger conditions to capture
application and integrated block port signals in hardware. Captured signals can then be
analyzed. This feature in the Vivado IDE is used for logic debugging and validation of a
design running in Xilinx devices.
The Vivado logic analyzer is used with the logic debug IP cores, including:
See the Vivado Design Suite User Guide: Programming and Debugging (UG908) [Ref 8].
Hardware Debug
If the Partial Reconfiguration Controller does not load a new Reconfigurable Module, the
following tips might be useful in debugging the issue:
• Visually check that the core is not being held in reset. The reset level is programmable
and needs to match the active level of your design's reset.
• Enable the AXI4-Stream status channel on the failing Virtual Socket Manager. This
allows live monitoring of the Virtual Socket Manager's operation. It can be very useful
to add ILAs here, on the Configuration Library interface, and on the ICAP interface.
• Make sure the failing Virtual Socket Manager is not in the Shutdown state. A bit in the
status information will tell you this. If the Virtual Socket Manager is in the Shutdown
state, bring it out of shutdown using the appropriate Restart command.
• Make sure the registers are programmed correctly. The incoming trigger selects a row in
the Trigger to Reconfigurable Module register bank which gives the row number in the
Reconfigurable Module Information register bank to use. The RM_BS_INDEX register in
this row provides the row number in the Bitstream Information register bank to use. The
registers in this row provide the size and address in memory of the bitstream to be
loaded. These are set correctly when the core is generated, but can be incorrect if
programmed through the AXI Lite interface.
° Use the Linux command xxd -c 4 to convert the BIN file to a HEX file. The data
seen on m_axi_mem_rdata should match the HEX data directly.
• Make sure the bitstream sizes programmed into the core are the sizes in bytes, not
words.
• Make sure the bitstreams are formatted correctly for the core.
° If an arbiter is not implemented, make sure the CAP_GNT port is tied to 1 and the
CAP_REL port is tied to 0.
• Check the status channel for errors.
• Check that the Virtual Socket Manager is not waiting for:
Xilinx Resources
For support resources such as Answers, Documentation, Downloads, and Forums, see Xilinx
Support.
References
These documents provide supplemental material useful with this product guide:
1. Vivado Design Suite User Guide: Designing IP Subsystems using IP Integrator (UG994)
2. Vivado Design Suite User Guide: Designing with IP (UG896)
3. Vivado Design Suite User Guide: Partial Reconfiguration (UG909)
4. Vivado Design Suite Tutorial: Partial Reconfiguration (UG947)
5. Vivado Design Suite User Guide: Getting Started (UG910)
6. Vivado Design Suite User Guide: Logic Simulation (UG900)
7. ISE to Vivado Design Suite Migration Guide (UG911)
8. Vivado Design Suite User Guide: Programming and Debugging (UG908)
9. Partial Reconfiguration in the Vivado Design Suite page on Xilinx.com
10. Artix-7 FPGAs Data Sheet: DC and AC Switching Characteristics (DS181)
11. Kintex-7 FPGAs Data Sheet: DC and AC Switching Characteristics (DS182)
12. Virtex-7 T and XT FPGAs Data Sheet: DC and AC Switching Characteristics (DS183)
13. Zynq-7000 All Programmable SoC (Z-7010, Z-7015, and Z-7020): DC and AC Switching
Characteristics Data Sheet (DS187)
14. Zynq-7000 All Programmable SoC (Z-7030, Z-7045, and Z-7100): DC and AC Switching
Characteristics Data Sheet (DS191)
15. Loading Partial Bitstreams using TFTP (XAPP1292)
Revision History
The following table shows the revision history for this document.
SAFETY CONCEPT OR REDUNDANCY FEATURE CONSISTENT WITH THE ISO 26262 AUTOMOTIVE SAFETY STANDARD ("SAFETY
DESIGN"). CUSTOMER SHALL, PRIOR TO USING OR DISTRIBUTING ANY SYSTEMS THAT INCORPORATE PRODUCTS, THOROUGHLY
TEST SUCH SYSTEMS FOR SAFETY PURPOSES. USE OF PRODUCTS IN A SAFETY APPLICATION WITHOUT A SAFETY DESIGN IS FULLY
AT THE RISK OF CUSTOMER, SUBJECT ONLY TO APPLICABLE LAWS AND REGULATIONS GOVERNING LIMITATIONS ON PRODUCT
LIABILITY.
© Copyright 2018 Xilinx, Inc. Xilinx, the Xilinx logo, Artix, ISE, Kintex, Spartan, Virtex, Vivado, Zynq, and other designated brands
included herein are trademarks of Xilinx in the United States and other countries. All other trademarks are the property of their
respective owners.