# Xilinx Standalone Library Documentation

# XiIFPGA Library v4.2

UG1229 (2018.3) November 14, 2018





# **Table of Contents**

| Chapter 1: Overview                            |    |
|------------------------------------------------|----|
| Supported Features                             | 3  |
| XiIFPGA library Interface modules              | 3  |
| Processor Configuration Access Port (PCAP)     | 3  |
| CSU DMA driver                                 | 3  |
| XilSecure Library                              | 4  |
| Design Summary                                 | 4  |
| Flow Diagram                                   | 5  |
| Setting up the Software System                 | 6  |
| Enabling Secure Mode                           | 6  |
| Bitstream Authentication Using External Memory | 7  |
| Bootgen                                        | 7  |
| Authenticated Bitstream Loading Using OCM      | 8  |
| Authenticated Bitstream Loading Using DDR      | 8  |
| Chapter 2: XiIFPGA APIs                        |    |
| Overview                                       | 9  |
| Function Documentation                         | 9  |
| XFpga_PL_BitStream_Load                        | 9  |
| XFpga_InterfaceStatus                          | 10 |
| XFpga_PL_PostConfig                            | 11 |
| XFpga_PL_ValidateImage                         | 11 |
| XFpga_GetPlConfigReg                           | 11 |
| XFpga GetPlConfigData                          | 12 |

### Appendix A: Additional Resources and Legal Notices





### Chapter 1

# Overview

The XilFPGA library provides an interface to the Linux or bare-metal users for configuring the programmable logic (PL) over PCAP from PS.

The library is designed for Zynq® UltraScale+™ MPSoC to run on top of Xilinx standalone BSPs. It is tested for A53, R5 and MicroBlaze. In the most common use case, we expect users to run this library on PMU MicroBlaze with PMUFW to serve requests from Linux for Bitstream programming.

# **Supported Features**

The following features are supported in Zyng® UltraScale+™ MPSoC platform.

- Full bitstream loading
- Partial bitstream loading
- Encrypted bitstream loading
- Authenticated bitstream loading
- · Authenticated and encrypted bitstream loading
- · Readback of configuration registers
- Readback of configuration data

# XiIFPGA library Interface modules

XilFPGA library uses the below major components to configure the PL through PS.

### **Processor Configuration Access Port (PCAP)**

The processor configuration access port (PCAP) is used to configure the programmable logic (PL) through the PS.

### **CSU DMA** driver

The CSU DMA driver is used to transfer the actual bitstream file for the PS to PL after PCAP initialization.





### **XilSecure Library**

The XilSecure library provides APIs to access secure hardware on the Zynq UltraScale+ MPSoC devices.

### Note

The current version of library supports only Zynq UltraScale MPSoC devices.

# **Design Summary**

XilFPGA library acts as a bridge between the user application and the PL device. It provides the required functionality to the user application for configuring the PL Device with the required bitstream. The following figure illustrates an implementation where the XilFPGA library needs the CSU DMA driver APIs to transfer the bitstream from the DDR to the PL region. The XilFPGA library also needs the XilSecure library APIs to support while programming the authenticated and the encrypted bitstream files.



Figure 1.1: XiIFPGA Design Summary



# Flow Diagram



Figure 1.2: XilFPGA Library Workflow



# **Setting up the Software System**

To use XiIFPGA in a software application, you must first compile the XiIFPGA library as part of software application.

- 1. Launch Xilinx SDK. Xilinx SDK prompts you to create a workspace.
- 2. Select File > New > Xilinx Board Support Package. The New Board Support Package wizard appears.
- 3. Specify a project name.
- 4. Select **Standalone** from the **Board Support Package OS** drop-down list. The **Board Support Package Settings** wizard appears.
- 5. Select the **xilfpga** library from the list of **Supported Libraries**.
- 6. Expand the **Overview** tree and select **xilfpga**. The configuration options for xilfpga are listed.
- 7. Configure the xilfpga by providing the base address of the Bit-stream file (DDR address) and the size (in bytes).
- 8. Click **OK**. The board support package automatically builds with XiIFPGA library included in it.
- 9. Double-click the **system.mss** file to open it in the **Editor** view.
- 10. Scroll-down and locate the **Libraries** chapter.
- 11. Click **Import Examples** adjacent to the XiIFPGA 4.2 entry.

# **Enabling Secure Mode**

To support encrypted and authenticated bitstream loading, you must enable secure mode in PMUFW.

- 1. Launch Xilinx SDK. Xilinx SDK prompts you to create a workspace.
- 2. Select File > New > Application Project. The New Application Project wizard appears.
- 3. Specify a project name.
- 4. Select **Standalone** from the **OS Platform** drop-down list.
- 5. Select a supported hardware platform.
- 6. Select psu pmu 0 from the Processor drop-down list.
- 7. Click Next. The **Templates** page appears.
- 8. Select **ZyngMP PMU Firmware** from the **Available Templates** list.
- 9. Click **Finish**. A PMUFW application project is created with the required BSPs.
- 10. Double-click the **system.mss** file to open it in the **Editor** view.



www.xilinx.com



- 11. Click the **Modify this BSP's Settings** button. The **Board Support Package Settings** dialog box appears.
- 12. Select xilfpga. Various settings related to the library appears.
- 13. Select secure\_mode and modify its value to true .
- 14. Click **OK** to save the configuration.

### Note

: By default the secure mode is enabled. To disable modify the secure\_mode value to false.

# **Bitstream Authentication Using External Memory**

For Bitstream, the size of the file is too large to be contained inside the device and external memory must be used. The use of external memory could pose access security issues. The following section describes how Bitstream is authenticated securely using external memory.

# **Bootgen**

When a Bitstream is requested for authentication, Bootgen divides the Bitstream into blocks of 8MB each and assigns an authentication certificate for each block. If the size of a Bitstream is not in multiples of 8 MB, the last block contains the remaining Bitstream data.



Figure 1.3: Bitstream Blocks

When both authentication and encryption are enabled, encryption is first done on the Bitstream. Bootgen then divides the encrypted data into blocks and assigns an Authentication certificate for each block.



# **Authenticated Bitstream Loading Using OCM**

To authenticate the Bitstream partition securely, XilFPGA uses the FSBL chapter's OCM memory to copy the bitstream in chunks from DDR.

The software workflow for authenticating Bitstream is as follows:

- 1. XilFPGA identifies DDR secure Bitstream image base address. XilFPGA has two buffers in OCM, Read Buffer of size 56KB and hash's of Chunks to store intermediate hashes calculated for each 56 KB of every 8MB block.
- 2. XiIFPGA copies a 56KB chunk from the first 8MB block to Read Buffer.
- 3. XilFPGA calculates hash on 56 KB and stores in HashsOfChunks.
- 4. XiIFPGA repeats steps 1 to 3 until the entire 8MB of block is completed.

### Note

The chunk that XiIFPGA copies can be of any size. A 56KB chunk is taken for better performance.

- 5. XilFPGA authenticates the Bitstream.
- Once the authentication is successful, XiIFPGA starts copying information in batches of 56KB starting from the first block which is located in DDR to Read Buffer, calculates the hash, and then compares it with the hash stored at HashsOfChunks.
- 7. If the hash comparison is successful, FSBL transmits data to PCAP using DMA (for un-encrypted Bitstream) or AES (if encryption is enabled).
- 8. XiIFPGA repeats steps 6 and 7 until the entire 8MB block is completed.
- 9. Repeats steps 1 through 8 for all the blocks of Bitstream.

### Note

You cannot use the warm restart when the FSBL OCM memory is used to authenticate the Bitstream.

# **Authenticated Bitstream Loading Using DDR**

XilFPGA uses DDR to authenticate as In-sufficient OCM memory (OCM memory occupies with ATF and FSBL). The software workflow for authenticating Bitstream is as follows:

- 1. XilFPGA identifies DDR secure Bitstream image base address.
- 2. XiIFPGA calculates hash for the first 8MB block.
- 3. XiIFPGA authenticates the 8MB block
- 4. If Authentication is successful, XiIFPGA transmits data to PCAP via DMA (for unencrypted Bitstream) or AES (if encryption is enabled).
- 5. Repeats steps 1 through 4 for all the blocks of Bitstream.





Chapter 2

# XiIFPGA APIs

### **Overview**

This chapter provides detailed descriptions of the XiIFPGA library APIs.

### **Functions**

- u32 XFpga\_PL\_BitStream\_Load (UINTPTR BitstreamImageAddr, UINTPTR AddrPtr, u32 flags)
- u32 XFpga\_InterfaceStatus (void)
- u32 XFpga\_PL\_PostConfig (XFpga\_Info \*PLInfoPtr)
- u32 XFpga\_PL\_ValidateImage (XFpga\_Info \*PLInfoPtr)
- u32 XFpga\_GetPlConfigReg (u32 ConfigReg, UINTPTR Address)
- u32 XFpga\_GetPlConfigData (XFpga\_Info \*PLInfoPtr)

### **Function Documentation**

# u32 XFpga\_PL\_BitStream\_Load ( UINTPTR BitstreamImageAddr, UINTPTR AddrPtr, u32 flags )

The API is used to load the bitstream file into the PL region. This function performs:

- Power-up the PL fabric.
- · Performs PL-PS Isolation.
- Initialize PL configuration Interface
- Write a Bitstream into the PL
- · Wait for the PL Done Status.
- Restore PS-PL Isolation (Power-up PL fabric).



### **Parameters**

| Linear memory Bitstream image base address            |
|-------------------------------------------------------|
| Aes key address which is used for Decryption.         |
| Flags are used to specify the type of Bitstream file. |
| BIT(0) - Bitstream type                               |
| o 0 - Full Bitstream                                  |
| 1 - Partial Bitstream                                 |
| BIT(1) - Authentication using DDR                     |
| o 1 - Enable                                          |
| o 0 - Disable                                         |
| BIT(2) - Authentication using OCM                     |
| ∘ 1 - Enable                                          |
| 。 0 - Disable                                         |
| BIT(3) - User-key Encryption                          |
| o 1 - Enable                                          |
| o 0 - Disable                                         |
| BIT(4) - Device-key Encryption                        |
| o 1 - Enable                                          |
| o 0 - Disable                                         |
|                                                       |

### Returns

- XFPGA\_SUCCESS on success
- Error code on failure.
- XFPGA\_VALIDATE\_ERROR.
- XFPGA\_PRE\_CONFIG\_ERROR.
- XFPGA\_WRITE\_BITSTREAM\_ERROR.
- XFPGA\_POST\_CONFIG\_ERROR.

### u32 XFpga\_InterfaceStatus (void)

This function provides the STATUS of PL programming interface.



### **Parameters**

### Returns

Status of the PL programming interface.

### u32 XFpga\_PL\_PostConfig ( XFpga\_Info \* PLInfoPtr )

This function set FPGA to operating state after writing.

#### **Parameters**

| PLInfoPtr | Pointer to XFgpa_Info structure |
|-----------|---------------------------------|
|-----------|---------------------------------|

### Returns

Codes as mentioned in xilfpga.h

### u32 XFpga\_PL\_ValidateImage ( XFpga\_Info \* PLInfoPtr )

This function is used to validate the Bitstream Image.

### **Parameters**

| PLInfoPtr | Pointer to XFgpa_Info structure |
|-----------|---------------------------------|
|-----------|---------------------------------|

### Returns

Codes as mentioned in xilfpga.h

# u32 XFpga\_GetPlConfigReg ( u32 ConfigReg, UINTPTR Address )

This function provides PL specific configuration register values.

### **Parameters**

| ConfigReg | Constant which represents the configuration register value to be returned. |
|-----------|----------------------------------------------------------------------------|
| Address   | DMA linear buffer address.                                                 |

### Returns

- XFPGA\_SUCCESS if successful
- XFPGA\_FAILURE if unsuccessful
- XFPGA\_OPS\_NOT\_IMPLEMENTED if implementation not exists.



### u32 XFpga\_GetPlConfigData ( XFpga\_Info \* PLInfoPtr )

This function provides functionality to read back the PL configuration data.

### **Parameters**

| PLInfoPtr | Pointer to XFgpa_Info structure |
|-----------|---------------------------------|
|-----------|---------------------------------|

### Returns

- XFPGA\_SUCCESS if successful
- XFPGA\_FAILURE if unsuccessful
- XFPGA\_OPS\_NOT\_IMPLEMENTED if implementation not exists.



# Appendix A

# Additional Resources and Legal Notices

### Xilinx Resources

For support resources such as Answers, Documentation, Downloads, and Forums, see Xilinx Support.

### **Solution Centers**

See the Xilinx Solution Centers for support on devices, software tools, and intellectual property at all stages of the design cycle. Topics include design assistance, advisories, and troubleshooting tips.

# Please Read: Important Legal Notices

The information disclosed to you hereunder (the "Materials") is provided solely for the selection and use of Xilinx products. To the maximum extent permitted by applicable law: (1) Materials are made available "AS IS" and with all faults, Xilinx hereby DISCLAIMS ALL WARRANTIES AND CONDITIONS, EXPRESS, IMPLIED, OR STATUTORY, INCLUDING BUT NOT LIMITED TO WARRANTIES OF MERCHANTABILITY, NON-INFRINGEMENT, OR FITNESS FOR ANY PARTICULAR PURPOSE; and (2) Xilinx shall not be liable (whether in contract or tort, including negligence, or under any other theory of liability) for any loss or damage of any kind or nature related to, arising under, or in connection with, the Materials (including your use of the Materials), including for any direct, indirect, special, incidental, or consequential loss or damage (including loss of data, profits, goodwill, or any type of loss or damage suffered as a result of any action brought by a third party) even if such damage or loss was reasonably foreseeable or Xilinx had been advised of the possibility of the same. Xilinx assumes no obligation to correct any errors contained in the Materials or to notify you of updates to the Materials or to product specifications. You may not reproduce, modify, distribute, or publicly display the Materials without prior written consent. Certain products are subject to the terms and conditions of Xilinx's limited warranty, please refer to Xilinx's Terms of Sale which can be viewed at http://www.xilinx.com/legal.htm#tos; IP cores may be subject to warranty and support terms contained in a license issued to you by Xilinx. Xilinx products are not designed or intended to be fail-safe or for use in any application requiring fail-safe performance; you assume sole risk and liability for use of Xilinx products in such critical applications, please refer to Xilinx's Terms of Sale which can be viewed at http://www.xilinx.com/legal.htm#tos.



### **Automotive Applications Disclaimer**

AUTOMOTIVE PRODUCTS (IDENTIFIED AS "XA" IN THE PART NUMBER) ARE NOT WARRANTED FOR USE IN THE DEPLOYMENT OF AIRBAGS OR FOR USE IN APPLICATIONS THAT AFFECT CONTROL OF A VEHICLE ("SAFETY APPLICATION") UNLESS THERE IS A 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.