# Xilinx Software Development Kit (SDK) Standalone Library Documentation

XIIFPGA (v1.1)

UG1229 (2016.4) November 30, 2016





# **Table of Contents**

## **Chapter 1 XiIFPGA APIs**

| Ove    | ew                                       |
|--------|------------------------------------------|
| Setti  | g up the Software System                 |
| Fund   | on Documentation                         |
|        | pga_PL_BitSream_Load                     |
|        | -pga_PcapStatus                          |
| Chapte | A Additional Resources and Legal Notices |
| Xilin  | Resources                                |
| Solu   | on Centers                               |
| Plea   | Read: Important Legal Notices            |

www.xilinx.com



## Chapter 1

# XiIFPGA APIs

### **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. In its current from it supports only full bitstream download. In subsequent releases it will support other features like encrypted and authenticated bitstream loading, partial bitstream loading.

#### Xilfpga 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 Bit stream file for the PS to PL after PCAP initialization.

**Xilsecure\_library** - The LibXilSecure library provides APIs to access secure hardware on the Zynq® UltraScale+™ MPSoC devices. This library includes:

- SHA-3 engine hash functions
- AES for symmetric key encryption
- RSA for authentication

#### Note

- The current version of library supports only Zynq® UltraScale+™ MPSoC devices.
- The XilFPGA library is capable of loading only .bin format files into PL. The library will not support the other file formats.
- Xilsecure library is required only for the below use cases:





- Encrypted bit-stream loading.
- o Authenticated bit-stream loading

#### **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 bit-stream. The figure below illustrates an implementation where the Xilfpga library needs the CSU DMA driver APIs to transfer the bit-stream 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: XiIFPGA 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 SDK. SDK opens and 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 xilfpga 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** section.
- 11. Click **Import Examples** adjacent to the xilfpga 1.1 entry.

## **Functions**

- u32 XFpga PL BitSream Load (u32 WrAddrHigh, u32 WrAddrLow, u32 WrSize, u32 flags)
- u32 XFpga\_PcapStatus (void)





## **Function Documentation**

#### u32 XFpga\_PL\_BitSream\_Load ( u32 WrAddrHigh, **u32** WrAddrLow, u32 WrSize, u32 flags)

The API is used to load the user provided bitstream file into zyngmp PL region. This function does the following jobs:

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

#### **Note**

This function contains the polling implementation to provide the PL reset wait time due to this polling implementation the function call is blocked till the time out value expires or gets the appropriate status value from the PL Done Status register.

#### **Parameters**

| WrAddrHigh | Higher 32-bit Linear memory space from where CSUDMA will read the data to be written |
|------------|--------------------------------------------------------------------------------------|
|            | to PCAP interface                                                                    |
| WrAddrLow  | Lower 32-bit Linear memory space from where CSUDMA will read the data to be written  |
|            | to PCAP interface                                                                    |
| WrSize     | Number of 32bit words that the DMA should write to the PCAP interface                |
| flags      | Flags are used to specify the type of bitstream file.                                |
|            | BIT(0) - Bit-stream type                                                             |
|            | ■ 0 - Full Bit-stream                                                                |
|            | ■ 1 - Partial Bit-stream                                                             |
|            | BIT(1) - Authentication                                                              |
|            | ■ 1 - Enable                                                                         |
|            | ■ 0 - Disable                                                                        |
|            | BIT(2) - Encryption                                                                  |
|            | ■ 1 - Enable                                                                         |
|            | ■ 0 - Disable                                                                        |
|            |                                                                                      |

www.xilinx.com





#### **Returns**

• Error status based on implemented functionality (SUCCESS by default).

## u32 XFpga\_PcapStatus (void)

This function provides the STATUS of PCAP interface

**Parameters** 

| None |  |
|------|--|

#### **Returns**

Status of the PCAP interface.



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

