



XAPP1319 (v2.1) November 23, 2020

# Programming BBRAM and eFUSES

Author: Mir Sayed Ali

## Summary

The Zynq® UltraScale+™ MPSoC family is based on the Xilinx® UltraScale™ MPSoC architecture. The Zynq UltraScale+ RFSoCs are similar to the basic MPSoCs with the addition of key RF subsystems for multi-band, multi-mode cellular radios, and cable infrastructure. These MPSoC and RFSoC products integrate a feature rich 64-bit quad-core or dual-core Arm® Cortex™-A53 and dual core Arm Cortex R5 based processing system (PS) and Xilinx programmable logic (PL) UltraScale™ architecture in a single device. Nonvolatile memory (NVM) in the form of eFUSES and battery-backed RAM (BBRAM) is used for advanced encryption standard (AES) keys, Rivest-Shamir-Adleman (RSA) key hashes, security control, and user-defined applications. This application note describes the programming of BBRAM and eFUSES in Zynq UltraScale+ devices. The capability to program BBRAM and eFUSES increases the field programmability of Xilinx FPGAs and SoCs. The programming of BBRAM and eFUSES in Zynq UltraScale+ devices provides ease-of-use and security advantages over the programming capabilities of the Zynq-7000 SoC and UltraScale devices.

Download the [reference design files](#) for this application note from the Xilinx website. For detailed information about the design files, see [Reference Design](#).

## Introduction

The BBRAM and eFUSES in Zynq UltraScale+ devices are principally used to store AES keys and the hashes of RSA keys. Self-programming of BBRAM and eFUSES in Zynq UltraScale+ devices does not require an IP core. Software running on the Arm® Cortex-A53 or Cortex-R5 processor uses the Xilinx Secure Key (XilSK) library to program the BBRAM or the eFUSES. Example C code is provided with the XilSK library to program the BBRAM or eFUSES.

This application note provides two methods to program the BBRAM and eFUSES:

- Create and run software built in the Vitis™ software platform to program the BBRAM and eFUSES
- Use Xilinx Lightweight Provisioning (XLWP) command line tool to program the BBRAM and eFUSES

Along with instructions to program BBRAM and eFUSES, steps are provided to create and run an application software project in Vitis to test the cryptographic functionality, enabled by programmed memory. For example, run the **zcu102\_program\_bbram** software project to program the BBRAM, and then test the functionality using the standard hello\_world software project.

The uses of programming the BBRAM and eFUSES are listed as follows:

- AES Key
- RSA Support
- Security Control Support
- Physically Uncloneable Function (PUF) Support
- User Defined eFUSES

For a complete list of programmable eFUSES, see the *Zynq UltraScale+ MPSoC: Technical Reference Manual* (UG1085) [\[Ref 2\]](#).

Programming BBRAM and eFUSES is a prerequisite for the secure boot functionality discussed in the *Zynq UltraScale+ MPSoC: Embedded Design Tutorial* (UG1209) [\[Ref 1\]](#).

**Note:** This application note applies to eFUSES located in the processor system (PS) of Zynq UltraScale+ MPSoC/RFSOC devices, not the eFUSES located in the programmable logic (PL). For details on programming the eFUSES located in the programmable logic (PL) of Zynq UltraScale+ devices, see *Internal Programming of BBRAM and eFUSES* (XAPP1283) [\[Ref 3\]](#).

---

## Hardware and Software Requirements

The hardware and software requirements for the reference systems are as follows:

- ZCU102 evaluation board or Avnet UltraZed-EG board
- AC power adapter (12 VDC)
- USB type-A to USB mini-B cables (for UART, JTAG communication)
- SD-Card (FAT32)
- Xilinx Vitis software platform 2020.1 or newer



**IMPORTANT:** Programming any of the noted eFUSE settings preclude Xilinx test access. Consequently, Xilinx may not accept return material authorization (RMA) requests. The eFUSES are ENC\_ONLY, JTAG\_DIS, DFT\_DIS, RSA\_EN, and AES key. For further details, refer to Table 12-13 in the *Zynq UltraScale+ MPSoC: Technical Reference Manual* (UG1085) [\[Ref 2\]](#).

---

---

## Programming BBRAM and eFUSES Using XilSKey Library

The software projects in Vitis uses the XilSKey library to program the BBRAM and eFUSES. The XilSKey library is located at <Vitis\_install>/data/embeddedsw/lib/sw\_services.

The XilSKey library provides examples for programming Zynq UltraScale+ device eFUSES and BBRAM. The high-level steps using the XilSKey library are explained in the following sections:

- Programming the AES Key in BBRAM.
  - Programming eFUSES for AES and RSA Cryptographic Functions.
  - Programming PUF-related eFUSES.
- 

## BBRAM and eFUSE Uses

This section describes the uses cases of programming the BBRAM and eFUSES in Zynq UltraScale+ devices:

### AES Key

Zynq UltraScale+ devices use a hardened AES cryptographic block for AES encryption and decryption. The AES cryptographic block accepts keys from several sources to include storing a 256-bit AES key in BBRAM or eFUSES. The AES key can also be stored in an obfuscated or black format either externally in flash or internally in eFUSES. The AES key cannot be read out of BBRAM or eFUSES once it has been programmed. The integrity of the key loading operation is verified using a 32-bit CRC. The Zynq UltraScale+ device also supports AES encryption and decryption using a PUF generated key, as discussed in [Physically Uncloneable Function \(PUF\) Support](#). In the PUF eFUSES mode, the CHASH, AUX data, and SYNDROME or PUF helper data are programmed into the eFUSES.

### eFUSE Uses

Additional eFUSE fields use cases are described in the following section.

#### RSA Support

Zynq UltraScale+ devices use silicon-based RSA and SHA3 cryptographic blocks for RSA authentication. RSA uses a 4096-bit private/public key pair. Only the 384 bit hash of the primary public key (PKK) is stored in the eFUSES to save area on the device. The configuration security unit (CSU) reads the public key from external memory, calculates its cryptographic checksum using the SHA-3/384 engine, and compares it to the value stored in eFUSES. For further details, you can refer to *Zynq UltraScale+ MPSoC: Technical Reference Manual* (UG1085) [\[Ref 2\]](#).

You can also program eFUSES for revoking public keys of applications and partitions. For further details, you can refer to *Key Revocation Lab* (XAPP1344) [\[Ref 8\]](#).

#### Security Control Support

Zynq UltraScale+ devices provide eFUSES that increase the security of the device. For example, some eFUSE bits can permanently disable the JTAG and design for testing (DFT) functionality of the device which is useful during the development phase. When a device moves to the production phase, disabling the JTAG and DFT ensures these ports are no longer accessible, preventing an adversary from gaining access to the hardware.

## **Physically Uncloneable Function (PUF) Support**

The principle use of the PUF in Zynq UltraScale+ devices is black key storage. Black key storage stores the user's AES key in the eFUSES or in the Booheader in an encrypted format. At the time of use, the encrypted key in the eFUSES or Booheader is decrypted, and the resulting plaintext key is used for the encryption and decryption operation. As a secondary usage of the PUF, the PUF along with the AES engine, can be used to encrypt and decrypt user data. Refer to *External Secure Storage Using the PUF* (XAPP1333) [Ref 9].

The PUF registration software commands the PUF to generate values and program the eFUSES used by the PUF. This software is included in the XilSKey library. The registration software commands the PUF to generate the following values:

- Helper data
- Black key (encrypted user key)

The values generated by the PUF registration software are programmed into the eFUSES. In the PUF Booheader mode, the values are included in the Booheader by Bootgen.

The steps used to generate and program PUF values into the eFUSES are explained in [Programming PUF-related eFUSES](#). The use of the PUF Booheader mode is discussed in *Secure Boot of Zynq UltraScale+ MPSoC: Embedded Design Tutorial* (UG1209) [Ref 1].

## **User Defined eFUSES**

Zynq UltraScale+ devices provides eight 32-bit registers for user-defined eFUSES. These eFUSES can be written to and read from, for various user-defined functions. They can be used for enhanced secondary key revocation.

# XilSKey

The XilSKey library provides a convenient structure to program the BBRAM and eFUSES.

[Table 1](#) provides a summary of the user-defined macros used in BBRAM and eFUSE programming. These are used in the `xilskey_bbramps_zynqmp.c`, `xilskey_efuseps_zynqmp_input.h`, and `xilskey_puf_registration.h` files used in the example designs.

**Table 1: Zynq UltraScale+ User-configurable PS eFUSE Parameters**

| Macro                                   | Description                                                                                        |
|-----------------------------------------|----------------------------------------------------------------------------------------------------|
| <b>AES</b>                              |                                                                                                    |
| <code>XSK_EFUSEPS_WRITE_AES_KEY</code>  | Commands to write the value defined in the <code>XSK_EFUSEPS_AES_KEY</code> macro to the AES eFUSE |
| <code>XSK_EFUSEPS_AES_KEY</code>        | 256-bit AES key for use in eFUSE                                                                   |
| <code>XSK_ZYNQMP_BBRAMPS_AES_KEY</code> | 256-bit AES key for use in BBRAM                                                                   |

Table 1: Zynq UltraScale+ User-configurable PS eFUSE Parameters (Cont'd)

| Macro                         | Description                                                                                                                                                  |
|-------------------------------|--------------------------------------------------------------------------------------------------------------------------------------------------------------|
| XSK_EFUSEPS_AES_RD_LOCK       | Disables the AES key cyclic redundancy check (CRC) for eFUSE key storage                                                                                     |
| XSK_EFUSEPS_AES_WR_LOCK       | Disables write to AES eFUSES                                                                                                                                 |
| XSK_EFUSEPS_ENC_ONLY          | Requires that the boot image be encrypted with eFUSE AES key, when programmed. It only applies to the encryption status and is independent of the RSA_EN.    |
| XSK_EFUSEPS_BBRAM_DISABLE     | Disables use of AES key from BBRAM permanently                                                                                                               |
| <b>RSA</b>                    |                                                                                                                                                              |
| XSK_EFUSEPS_PPK0_IS_SHA3      | Specifies secure hash algorithm-2 (SHA-2) or SHA-3 of PPK0                                                                                                   |
| XSK_EFUSEPS_WRITE_PPK0_HASH   | Causes hash of public-private key 0 (PPK0) to be programmed into eFUSES                                                                                      |
| XSK_EFUSEPS_PPK0_HASH         | PPK0 hash                                                                                                                                                    |
| XSK_EFUSEPS_PPK1_IS_SHA3      | Specifies SHA-2 or SHA-3 of PPK1                                                                                                                             |
| XSK_EFUSEPS_WRITE_PPK1_HASH   | Causes hash of PPK1 to be programmed into eFUSES                                                                                                             |
| XSK_EFUSEPS_PPK1_HASH         | PPK1 hash                                                                                                                                                    |
| XSK_EFUSEPS_PPK0_WR_LOCK      | Disables writing to PPK0 eFUSES permanently                                                                                                                  |
| XSK_EFUSEPS_PPK0_INVLD        | Revokes PPK0 permanently                                                                                                                                     |
| XSK_EFUSEPS_PPK1_INVLD        | Revokes PPK1 permanently                                                                                                                                     |
| XSK_EFUSEPS_PPK1_WR_LOCK      | Disables writing to PPK1 eFUSES permanently                                                                                                                  |
| XSK_EFUSEPS_RSA_ENABLE        | Forces RSA authentication during boot permanently                                                                                                            |
| XSK_EFUSEPS_SPK_ID            | Selects SPK to use                                                                                                                                           |
| XSK_EFUSEPS_WRITE_SPK         | Writes control for SPK selection                                                                                                                             |
| <b>Security Control</b>       |                                                                                                                                                              |
| XSK_EFUSEPS_ERR_DISABLE       | Prohibits error messages from being read via JTAG (ERROR_STATUS register)                                                                                    |
| XSK_EFUSEPS_JTAG_DISABLE      | Disables JTAG. IDCODE and BYPASS are the only allowed commands.                                                                                              |
| XSK_EFUSEPS_DFT_DISABLE       | Disables DFT boot mode permanently                                                                                                                           |
| XSK_EFUSEPS_PROG_GATE_DISABLE | When programmed, these fuses prohibit the PROG_GATE feature from being engaged. If any of these are programmed, the PL is always reset when the PS is reset. |
| XSK_EFUSEPS_SECURE_LOCK       | When programmed, the device does not enable boundary scan (BSCAN) capability while in secure lockdown.                                                       |
| XSK_EFUSEPS_LBIST_EN          | Enables logic built-in self-test (BIST) to be run during boot permanently                                                                                    |
| XSK_EFUSEPS_LPD_SC_EN         | Enables zeroization of registers in low-power domain (LPD) during boot permanently                                                                           |
| XSK_EFUSEPS_FPD_SC_EN         | Enables zeroization of registers in full-power domain (FPD) during boot permanently                                                                          |
| XSK_EFUSEPS_PBR_BOOT_ERR      | Enables boot halt after a platform management unit (PMU) error permanently                                                                                   |

Table 1: Zynq UltraScale+ User-configurable PS eFUSE Parameters (Cont'd)

| Macro                            | Description                                                                                                 |
|----------------------------------|-------------------------------------------------------------------------------------------------------------|
| <b>PUF</b>                       |                                                                                                             |
| XSK_PUF_PROGRAM_EFUSE            | Programs syndrome data, CHASH, AUX, and black key into eFUSES                                               |
| XSK_PUF_IF_CONTRACT_MANUFACTURER | Checks whether or not RSA is enabled prior to issuing PUF commands                                          |
| XSK_PUF_READ_SECUREBITS          | Reads status of secure bits (SYN_INVALID, REGISTER_DISABLE, SYN_WRLK) for display on communication terminal |
| XSK_PUF_PROGRAM_SECUREBITS       | Programs PUF secure bits (SYN_INVALID, REGISTER_DISABLE, SYN_WRLK)                                          |
| XSK_PUF_SYN_INVALID              | Invalidates the programmed helper data permanently                                                          |
| XSK_PUF_REGISTER_DISABLE         | Disables PUF regeneration permanently                                                                       |
| XSK_PUF_AES_KEY                  | Red key value used in black key generation                                                                  |
| XSK_PUF_IV                       | User-provided initialization vector                                                                         |
| XSK_PUF_SYN_WRLK                 | Locks PUF helper data from future programming                                                               |
| <b>User eFUSES</b>               |                                                                                                             |
| XSK_EFUSEPS_USER[0-7]_FUSES      | User eFUSE value                                                                                            |
| XSK_EFUSEPS_WRITE_USER[0-7]_FUSE | Burns value in XSK_EFUSEPS_USER[0-7] to user eFUSES                                                         |
| XSK_EFUSEPS_USER_WRLK_[0-7]      | Locks the corresponding user eFUSE register so it cannot be written to again                                |

## Programming the AES Key in BBRAM

This section provides step-by-step procedures to program a user AES key in BBRAM for the ZCU102 evaluation board. The main steps are as follows:

- Launch Vitis and create a platform project.
- Import the example BBRAM project in Vitis and generate the elf file.
- Generate the boot image and program the BBRAM.
- Test the functionality of the programmed BBRAM using a hello\_world software project.

**Note:** These steps demonstrated here are for a Windows machine but could be performed in a Linux machine (either physical or virtual).

### Launch Vitis and create a platform project:

1. Launch the Vitis IDE in Windows by using the desktop shortcut or by double-clicking the C:\Xilinx\Vitis\2020.1\bin\vitis.bat file. The Eclipse Launcher dialog box opens.

2. Select the workspace location (for example: D:\designs\workspace). Create the workspace folder if it is not already created.



Figure 1: Vitis IDE Eclipse Launcher Dialog Box

3. Click **Launch**. The Vitis integrated design environment (IDE) opens.
4. Click **File > New > Platform Project** to create platform project using ZCU102 Vivado Xilinx Shell Archive (XSA).

5. Enter the project name as hw\_platform, when the New Platform Project dialog box opens as shown in [Figure 2](#). Click **Next**.



Figure 2: New Platform Window in Vitis

6. Choose Create from hardware specification (XSA) in the Platform Project dialog box, and click **Next**.



Figure 3: Setting Custom Hardware

7. Browse and select `zcu102.xsa` from the Vitis installation folder. To create the platform based on your selection, the tool automatically selects the appropriate operating system and processor.



Figure 4: Hardware and Software Specification in Vitis

8. Click **Finish** to create your platform project. The platform project editor opens as shown in [Figure 5](#).



*Figure 5: Platform View in Vitis*

9. Right-click **hw\_platform** and select **Platform Build > Project** to build the hardware platform.

When the platform is generated, the dialog box shows the status of platform generation and the Board Support Package settings dialog box opens.

10. Select **Board Support Package** under **psu\_cortexa53\_0**. The **Board Support Package** opens as shown in [Figure 6](#).



*Figure 6: Board Support Package View in Vitis*

11. In the Board Support Package page, click **Modify BSP Settings**.
12. Select **xilskey** under Supported Libraries in **Board Support Package Settings window**, and click **OK**.



Figure 7: Board Support Package Settings - Xilinx Secure Key Library

**Import the example BBRAM project in Vitis and generate the elf project:**

1. Select the Libraries tab under **Board Support Package** and click **Import Examples** to the right of the xilskey libraries to view the xilskey example projects.



Figure 8: Import Example Project for Xilinx Secure Key Library

2. Select the check box for xilskey\_bbramps\_zynqmp\_example. Click **OK**.



Figure 9: Import Xilskey BBRAM Example Project

The **xilskey\_bbramps\_zynqmp\_example\_1** project gets added to the workspace. This project contains the example C code to program a key into BBRAM and verify the key.

3. Double-click `xilskey_bbramps_zynqmp_example.c` so that it is displayed in the text window.
4. From the `aes.nky` file in the reference design files (see [Reference Design](#)), copy the AES key to line 41 in the `xilskey_bbramps_zynqmp_example.c` file as shown in [Figure 10](#).



```

22 * 4.0 vns 10/08/15 First release
23 * 6.7 psl 04/10/19 Fixed IAR warnings.
24 * </pre>
25 *
26 ****
27
28 /****** Include Files *****/
29
30 #include "xil_io.h"
31 #include "xstatus.h"
32 #include "xilskey_utils.h"
33 #include "xilskey_bbram.h"
34
35 /****** Macros (Inline Functions) Definitions *****/
36
37 /*
38 * This is the 256 bit key to be programmed into BBRAM.
39 * This should entered by user in HEX.
40 */
41 #define XSK_ZYNQMP_BBRAMPS_AES_KEY "45195DE9B5B80119D8DD4E7DF032736D53CF75AD1DC1E61C5BA681CF4A0724E8"
42
43 #define XSK_ZYNQMP_BBRAMPS_AES_KEY_LEN_IN_BYTES (32)
44 /*< AES key length in Bytes */
45 #define XSK_ZYNQMP_BBRAMPS_AES_KEY_LEN_IN_BITS (256)
46 /*< AES key length in Bits */
47 #define XSK_ZYNQMP_BBRAMPS_AES_KEY_STR_LEN (64)
48 /*< String length of Key */
49
50 /****** Type Definitions *****/
51
52

```

*Figure 10: xilskey\_bbramps\_zynqmp\_example.c file*

5. Save the file.
6. Right-click `xilskey_bbramps_zynqmp_example_1` in the Project Explorer, and select **Build Project** to build the application.

### Generate the boot image and program the BBRAM fuse:

1. Right-click `xilskey_bbramps_zynqmp_example_1` and select **Create Boot Image**. The **Create Boot Image** dialog box opens with pre-populated setting as shown in [Figure 11](#).



*Figure 11: Create Boot Image in Vitis*

2. Click **Create Image** to create boot image (.Bin) file.

The console window (Figure 12) shows the boot generation command line setting and result.



```
cmd /C bootgen -image xilskey_bbramps_zynqmp_example_1.bif -arch zynqmp -o \
D:/Designs/workspace/xilskey_bbramps_zynqmp_example_1/_ide/bootimage/BOOT.bin -w on

***** Xilinx Bootgen v2020.1.1
**** Build date : Aug 5 2020-23:32:09
** Copyright 1986-2020 Xilinx, Inc. All Rights Reserved.

[INFO] : Bootimage generated successfully
```

Figure 12: Create a Zynq MP Boot Image for the BBRAM AES Key

3. Verify that the BOOT.BIN and program\_aes\_bbram\_key.bif files are written to the specified directory D:/Designs/workspace/ xilskey\_bbramps\_zynqmp\_example\_1/\_ide/bootimage.
4. Use a text editor to review the program\_bbram\_aes\_key.bif file.
5. Insert an SD card into the SD card slot of the PC. Copy BOOT.BIN to the SD card.
6. Set up the ZCU102 or UltraZed-EG evaluation board.
7. Set up a communication terminal such as Tera Term using Interface 0, 115200 baud rate, and default settings.
8. Move the SD card from the PC to the SD card slot on the ZCU102 or UltraZed-EG evaluation board. The ZCU102 evaluation board uses a standard SD card. The UltraZed-EG board uses a mini SD card.
9. Configure the board to boot in SD-Boot mode by setting switch SW6 as shown in Figure 13 below.



Figure 13: SD-Boot Mode for Switch SW6

10. Apply power to the evaluation board.
11. Verify that the output on the communication terminal indicates successful programming of the BBRAM AES key ([Figure 14](#)).



```
Xilinx Zynq MP First Stage Boot Loader
Release 2020.1 Nov 15 2020 - 19:31:03
PMU-FW is not running, certain applications may not be supported.
BBRAM example for ZynqMP
BBRAM programming exit with Status = 00000000
```

*Figure 14:* Programmed and Verified BBRAM AES Key

**Test the functionality of the programmed BBRAM by using a hello software project:**

1. In the Vitis IDE, **select File > New > Application Project**. The **New Application Project** wizard welcome screen opens.



Figure 15: Create hello\_world Application Project

2. Click **Next**, and use the information in **Table 2** to make your selections in the "New Application Project" wizard screen.

Table 2: New Application Project Settings for Standalone APU Application

| Wizard Screen               | System Properties               | Settings                      |
|-----------------------------|---------------------------------|-------------------------------|
| Platform                    | Select platform from repository | hw_platform                   |
| Application project details | Application project name        | hello_world                   |
|                             | System project name             | hello_world_system            |
|                             | Target processor                | psu_cortexa53_0               |
| Domain                      | Domain                          | standalone on psu_cortexa53_0 |
| Templates                   | Available templates             | Hello World                   |

The hello\_world project gets created.

3. Right-click **hello\_world** under hello\_world\_system and select **Build Project** to build the project.
4. Right-click **hello\_world** once more and select **Create Boot Image**.
5. Rename the output BIF file as `test_encrypted_hello.bif` (Figure 16), in the Output BIF file path field.



Figure 16: Create Boot Image for hello\_world

6. Click **Security** tab, then click **Encryption** tab, and check **Use Encryption**. Under Key store select BBRAM RED (Figure 17).



Figure 17: Create Boot Image Encryption

7. Double-click `fsbl` to open edit partition window and change the encrypted option to AES, and browse to `aes_fsbl.nky` for key file (Figure 18). Click **OK**.

**Note:** The file aes\_fsbl.nky is available in the Reference Design file.



Figure 18: Encryption for fsbl Boot Image

8. Next, double-click the hello\_world.elf, change the encrypted option to AES, and browse to aes.nky file as Key file as shown in [Figure 19](#). Click **OK**.



Figure 19: Encryption for hello\_world Boot Image

Figure 20 shows the encrypted boot image creation GUI for hello\_world project.



Figure 20: Create Boot Image Using Encryption

9. Click **Create Image** to create a boot image (.Bin) file for hello\_world.
10. Insert an SD card into the SD card slot of the PC. Copy the BOOT.BIN to the SD card.
11. Move the SD card from the PC to the SD card slot on the evaluation board.
12. Apply power to the evaluation board.

13. Verify that Hello World is displayed on the communication terminal (Figure 21).



Figure 21: Verified Hello World

---

## Programming eFUSES for AES and RSA Cryptographic Functions

The following section provides step-by-step procedures to program the AES eFUSES and hash of the primary public key. These steps can be used to program any of the other eFUSES as well. Additionally, it includes steps to test the functionality of the programmed eFUSES, using a hello\_world software project.

1. Follow steps from [Launch Vitis and create a platform project](#): to create a platform project.
2. Expand Libraries under **Board Support Package** and click **Import Examples** to the right of the xilskey.
3. Select the check box for xilskey\_efuseps\_zynqmp\_example (Figure 22) in the import examples pane, and click **OK**.



Figure 22: Import Xilskey eFUSES Examples Project

4. Expand **xilskey\_efuseps\_zynqmp\_example\_1** in the project explorer pane, and double-click **puf\_registration > src > xilskey\_efuseps\_zynqmp\_input.h** to invoke the file in the Vitis source editor ([Figure 23](#)).

This file contains the #define statements that specifies the eFUSE functionality.



```

3/8 */
379 #define XSK_EFUSEPS_AES_RD_LOCK      FALSE
380 #define XSK_EFUSEPS_AES_WR_LOCK      FALSE
381 #define XSK_EFUSEPS_ENC_ONLY        FALSE
382 #define XSK_EFUSEPS_BBRAM_DISABLE   FALSE
383 #define XSK_EFUSEPS_ERR_DISABLE    FALSE
384 #define XSK_EFUSEPS_JTAG_DISABLE   FALSE
385 #define XSK_EFUSEPS_DFT_DISABLE    FALSE
386 #define XSK_EFUSEPS_PROG_GATE_DISABLE FALSE
387 #define XSK_EFUSEPS_SECURE_LOCK    FALSE
388 #define XSK_EFUSEPS_RSA_ENABLE     FALSE
389 #define XSK_EFUSEPS_PPK0_WR_LOCK   FALSE
390 #define XSK_EFUSEPS_PPK0_INVLD    FALSE
391 #define XSK_EFUSEPS_PPK1_WR_LOCK   FALSE
392 #define XSK_EFUSEPS_PPK1_INVLD    FALSE
393 #define XSK_EFUSEPS_LBIST_EN      FALSE
394 #define XSK_EFUSEPS_LPD_SC_EN     FALSE
395 #define XSK_EFUSEPS_FPD_SC_EN     FALSE
396 #define XSK_EFUSEPS_PBR_BOOT_ERR  FALSE
397
398 /**
399 * Following is the define to select if the user wants to program
400 * user control bits
401 */
402 #define XSK_EFUSEPS_USER_WRLK_0    FALSE
403 #define XSK_EFUSEPS_USER_WRLK_1    FALSE
404 #define XSK_EFUSEPS_USER_WRLK_2    FALSE
405 #define XSK_EFUSEPS_USER_WRLK_3    FALSE
406 #define XSK_EFUSEPS_USER_WRLK_4    FALSE
407 #define XSK_EFUSEPS_USER_WRLK_5    FALSE
408 #define XSK_EFUSEPS_USER_WRLK_6    FALSE

```

*Figure 23: xilskey\_efuseps\_zynqmp\_input.h File in Source Editor*

5. Change the xilskey\_efuseps\_zynqmp\_input.h as defined in [Table 3](#).

*Table 3: Cryptographic Macros in xilskey\_efuseps\_zynqmp.h*

| Line No | Macro                       | Value |
|---------|-----------------------------|-------|
| 416     | XSK_EFUSEPS_WRITE_AES_KEY   | TRUE  |
| 417     | XSK_EFUSEPS_WRITE_PPK0_HASH | TRUE  |
| 441     | XSK_EFUSEPS_WRITE_PPK1_HASH | TRUE  |

6. Open the supplied xilskey\_efuseps\_zynqmp\_input.h file in the [Reference Design](#) files, update the following keys and hash value, and save the xilskey\_efuseps\_zynqmp\_input.h file:

- XSK\_EFUSEPS\_AES\_KEY (Line 455)
- XSK\_EFUSEPS\_PPK0\_HASH (Line 458)

- XSK\_EFUSEPS\_PPK1\_HASH (Line 461) ([Figure 24](#))

---

```

433 /* For writing into eFUSE */
434 #define XSK_EFUSEPS_WRITE_AES_KEY      TRUE
435 #define XSK_EFUSEPS_WRITE_PPK0_HASH    TRUE
436 #define XSK_EFUSEPS_WRITE_PPK1_HASH    TRUE
437 #define XSK_EFUSEPS_WRITE_SPKID       FALSE
438
439 #define XSK_EFUSEPS_WRITE_USER0_FUSE   FALSE
440 #define XSK_EFUSEPS_WRITE_USER1_FUSE   FALSE
441 #define XSK_EFUSEPS_WRITE_USER2_FUSE   FALSE
442 #define XSK_EFUSEPS_WRITE_USER3_FUSE   FALSE
443 #define XSK_EFUSEPS_WRITE_USER4_FUSE   FALSE
444 #define XSK_EFUSEPS_WRITE_USER5_FUSE   FALSE
445 #define XSK_EFUSEPS_WRITE_USER6_FUSE   FALSE
446 #define XSK_EFUSEPS_WRITE_USER7_FUSE   FALSE
447
448 #define XSK_EFUSEPS_WRITE_USER8_FUSE   FALSE
449
450 /**
451 * Following defines should be given in the form of hex string.
452 * The length of AES_KEY string must be 64, PPK hash should be 96 for
453 * SHA3 selection and and for USER_FUSES, SPK ID must be 32.
454 */
455 #define XSK_EFUSEPS_AES_KEY      "45195DE9B5880119D8DD4E7DF032736D53CF75AD1DC1E61C5BA681CF4A0724E8"
456
457 #define XSK_EFUSEPS_PPK0_IS_SHA3   TRUE
458 #define XSK_EFUSEPS_PPK0_HASH     "4EC222B544A94AE2A4EFA7910187A94C77AFB918F4E2241C8F1C9B3A8B53794685882DF72D8D9D00A1862CE298EA819E"
459
460 #define XSK_EFUSEPS_PPK1_IS_SHA3   TRUE
461 #define XSK_EFUSEPS_PPK1_HASH     "C885F37FFCD4E4ECA2805271572086EA35F07E86C3D48F3A22AA7C290C4AC85BD14F5715BCC14DC16CBED8E25D23618"
462 #define XSK_EFUSEPS_SPK_ID        "00000000"

```

---

*Figure 24: Updated Keys in Hash Values*

- In the project explorer pane, right-click xilskey\_efuseps\_zynqmp\_example\_1, and select **Build Project**.
- Right-click xilskey\_efuseps\_zynqmp\_example\_1, and select **Xilinx > Create Boot Image**.
- Use default settings and **Click Create Image**.
- Insert an SD card into the SD card slot of the PC. Copy  
`<workspace>/xilskey_efuseps_zynqmp_example_1/_ide/bootimage/BOOT.BIN` to the SD card.
- Move the SD card from the PC to the SD card slot on the ZCU102 or UltraZed-EG evaluation board.
- Set the **Boot Mode** switch to SD mode.
- Apply power to the board.
- Verify that the log in the communication terminal indicates that programming of eFUSES works as expected.

To test the functionality of the programmed eFUSES, create a hello\_world software project:

- In the Vitis IDE, select **File > New Application Project**. The **Create New Application** project wizard welcome screen opens.
- Click **Next** and use the information in [Table 2](#) to make your selections in the **New Application Project** wizard screens.
- Right-click **hello\_world** and select **Build Project**.
- Right-click **hello\_world** and select **Create Boot Image**.

19. Rename the BIF file as test\_encrypted\_hello.bif in the Output BIF file path field.
20. Click **Security > Encryption** tab and check **Use Encryption**. Select **EFUSE RED** under key store.
21. Double-click the **zyngmp\_fsbl.elf** and change the Encrypted option to AES, and browse to aes\_fsbl.nky (Figure 18). Click **OK**.
22. Next, double-click the **hello\_world.elf** and change the encrypted option to AES, and browse to aes.nky file (Figure 19). Click **OK**.
23. In the **Create Boot Image GUI**, click **Create Image**.
24. Insert an SD card into the SD card slot of the PC. Copy the BOOT.BIN to the SD card.
25. Move the SD card from the PC to the SD card slot on the evaluation board.
26. Apply power to the evaluation board.
27. Verify that Hello World is displayed on the communication terminal. If the RSA\_EN eFUSE is programmed, every boot is required to be authenticated.

---

## Programming PUF-related eFUSES

This section provides step-by-step procedure to program eFUSES used by the PUF. In [Programming eFUSES for AES and RSA Cryptographic Functions](#), a red AES key is programmed in the eFUSES. This section show the user how to program a black key in the eFUSES.

**Note:** The users cannot run this section after [Programming eFUSES for AES and RSA Cryptographic Functions](#), as the eFUSES have already been programmed with the red AES key. Also, the users who want a Black Key cannot program the AES key in the earlier section.

1. Follow steps from [Launch Vitis and create a platform project](#):
2. Select **Board Support Package** under psu\_cortexa53\_0 and the **Board Support Package** page opens.
3. In the **Board Support Package** window, click **Modify BSP Settings**.
4. Select xilskey and xilsecure under **Supported Libraries** and click **OK**.
5. Expand Libraries under **Board Support Package** and click **Import Examples** to the right of the xilskey.
6. Select the check box for **xilskey\_puf\_registration** in the examples for xilskey pane, and click **OK**.
7. Expand **xilskey\_puf\_registration\_1** in the project explorer pane.
8. Double-click **xilskey\_puf\_registration\_1 > src > xilskey\_puf\_registration.h** in the project explorer pane, to invoke the file in the source editor.

9. Edit the xilskey\_puf\_registration.h as shown in [Table 4](#).

*Table 4: Cryptographic Macros in xilskey\_puf\_registration.h*

| Line No | Macro                 | Value                                                              |
|---------|-----------------------|--------------------------------------------------------------------|
| 131     | XSK_PUF_PROGRAM_EFUSE | TRUE                                                               |
| 145     | XSK_PUF_AES_KEY       | 45195DE9B5B80119D8DD4E7DF032736D53CF7<br>5AD1DCE61C5BA681CFA0724E8 |
| 146     | XSK_PUF_BLACK_KEY_IV  | 62A4B57D0F121CCB02CB8336                                           |

10. Save the file and exit.
11. In the project explorer, right-click the **xilskey\_puf\_registration\_1 project**, and select **Build Project**.
12. Right-click the **xilskey\_puf\_registration\_1 project**, and select **Create Boot Image**.
13. In the **Create Boot Image GUI**, ensure that Zynq MP is selected in the architecture field.
14. Use default settings and **Click Create Image**. Click **Create Image** to create boot image (.Bin) file.
15. Insert an SD card into the SD card slot of the PC. Copy  
 D:/Designs/workspace/xilskey\_puf\_registration\_1/ide/boot  
 image/BOOT.bin to the SD card.
16. Move the SD card from the PC to the SD card slot on the ZCU102 or UltraZed-EG evaluation board.
17. Set the **Boot Mode switch** to SD mode.
18. Set up a communication terminal.
19. Power cycle the board.
20. Verify that the log displayed in the communication terminal indicates that the security control eFUSES are programmed as expected.

# Use XLWP Command Line Tool to Program the BBRAM and eFUSES

Xilinx Lightweight Provisioning (XLWP) Tool is a simple way to program BBRAM and eFUSES. It performs all of its functionality via JTAG. It allows an interactive user mode via JTAG UART to terminal app or via Tcl script mode. Contact your local sales team to download the XLWP tool. For windows, it is recommended to install the TeraTerm terminal program to use the XLWP tool. TeraTerm is an open-source and free terminal emulator for Windows available from [Tera Term Home Page](#).

There are three Tcl files and one .ELF file that comprise the XLWP tool:

- `xlwp_tool.tcl`: Main XLWP Tcl that gets called by XSCT -- sets up JTAG connection downloads .elf, launches terminal -or- user\_script, etc.
- `xlwp_zup_cmds.tcl`: Contains all the commands to allow reading/programming of Zynq UltraScale+ eFUSES and load the AES key into BBRAM when running in script mode
- `xlwp_zup_script.tcl`: Template modified by user to define which ZU+ eFUSES to read/program and the AES key to load into BBRAM when running in script mode
- `xlwp_zup_<nn>mhz.elf`: Binary files based on xilskey and xilsecure libraries that is downloaded to Zynq UltraScale+ A53\_0 via JTAG - where <nn> must match the external PS\_REF\_CLK frequency on the customer's board

There are two batch (.bat) files and one initialization file for Windows and sample script for Linux included here. Here are the windows batch files:

- `xlwp_tool.bat`: Starts the hw\_server application and then calls `xlwp_tool.tcl` via XSDB with command-line arguments (ensure the path setting matches your system)
- `xlwp_term.bat`: Starts the TeraTerm terminal program in user mode and passes in the hw\_server hostname and TCP port number (ensure the path setting matches your system)
- `tt_jtag_uart.ini`: TeraTerm initialization file to setup proper operation with the XLWP tool via the JTAG UART over TCP

## Launching XLWP Tool in Command Line Mode to Program the BBRAM

1. Double-click xlwp\_tool.bat file to run the batch file.

The screenshot shows a terminal window titled "localhost - JTAG\_UART VT". The window contains the following text:

```
XLWP Tool - Lightweight Provisioning Tool
File Edit Setup Control Window Help
Starting XLWP tool initialization:
- Resetting PS eFUSE driver instance...
- Initializing SysMon & timing parameters...
- Verifying proper temperature and voltage...
- Resetting and initializing PUF driver instance...
Press any key to start XLWP tool -> [key pressed]
```

Below this, there is a large amount of memory dump output from the tool, which is mostly illegible due to its size. The terminal window has standard window controls (minimize, maximize, close) at the top right.

Figure 25: XLWP Tool Launch

2. Press any key and XLWP tool will open in TeraTerm terminal. [Figure 25](#) shows XLWP tool running in Teraterm GUI.
3. Press **4** to load BBRAM AES key, and enter your 256-bit AES key (you can use the same one that is used in Vitis flow).
4. Press **y** for “Is the key correct” instruction, and press **y** once more for Load key into BRAM instruction.

The AES key will be programmed in BBRAM and a CRC value will be calculated. Refer to Figure 26.

The screenshot shows a terminal window titled "localhost - JTAG\_UART VT". The menu includes File, Edit, Setup, Control, Window, and Help. The main menu displays:

```
1. Read & Display eFUSES
2. Program eFUSES
3. PUF Menu
4. Load Red AES key (BBRAM-based)

b. Build info
x. Exit XLWP tool

Please make a selection -> 4

> Enter the 256-bit red BBRAM AES key (64 hex characters):
-----
45195DE9B5B80119D8DD4E7DF032736D53CF75AD1DC1E61C5BA681CF4A0724E8
Is the key correct?! (y/[n]) -> y

Load key into BBRAM? (y/[n]) -> y

Red AES key CRC value: 0xE83AF0CD
Red AES BBRAM key CRC check passed!
*** BBRAM AES Key loaded OK! ***

Press any key to continue...[
```

Figure 26: BBRAM AES Programming Using XLWP Tool

5. Press any key to continue.

6. Press **x** to quit XLWP tool and then **y** for "Quit XLWP tool" instruction (Figure 27).



Figure 27: Exiting XLWP Tool

7. Close any terminal that remains open.

**Note:** You can follow similar steps and use a script to program BBRAM or eFUSE using the supplied script.

---

## Conclusion

BBRAM in Zynq UltraScale+ devices can be used to store the 256-bit AES image decryption key. This AES key can also be stored in the eFUSES with the important difference that it can neither be modified nor erased. Additionally, various custom use cases are also available for eFUSES.

This application note provides a straightforward and secure method to self-program BBRAM and eFUSES in the Zynq UltraScale+ devices. It also shows a hello\_world design with an encrypted image to verify the BBRAM key.

# Reference Design

Download the [reference design files](#) for this application note from the Xilinx website.

[Table 5](#) shows the reference design matrix.

*Table 5: Reference Design Matrix*

| Parameter                                                                                          | Description                                    |
|----------------------------------------------------------------------------------------------------|------------------------------------------------|
| <b>General</b>                                                                                     |                                                |
| Target devices                                                                                     | Zynq UltraScale+ devices                       |
| Source code provided                                                                               | Yes                                            |
| Source code format                                                                                 | C                                              |
| Design uses code and IP from existing Xilinx application note and reference designs or third party | No                                             |
| Static code analysis/MISRA C                                                                       | Yes                                            |
| <b>Simulation</b>                                                                                  |                                                |
| Functional simulation performed                                                                    | No                                             |
| Timing simulation performed                                                                        | No                                             |
| Test bench used for functional and timing simulations                                              | No                                             |
| Test bench format                                                                                  | N/A                                            |
| Simulator software/version used                                                                    | N/A                                            |
| SPICE/IBIS simulations                                                                             | N/A                                            |
| <b>Implementation</b>                                                                              |                                                |
| Synthesis software tools/versions used                                                             | N/A                                            |
| Implementation software tools/versions used                                                        | N/A                                            |
| Static timing analysis performed                                                                   | No                                             |
| <b>Hardware Verification</b>                                                                       |                                                |
| Hardware verified                                                                                  | Yes                                            |
| Hardware platform used for verification                                                            | Avnet UltraZed-EG and ZCU102 evaluation boards |

## Documentation Navigator and Design Hubs

Xilinx Documentation Navigator provides access to Xilinx documents, videos, and support resources, which you can filter and search to find information. To open the Xilinx Documentation Navigator (DocNav):

- From the Vivado® IDE, select **Help > Documentation and Tutorials**.
- On Windows, select **Start > All Programs > Xilinx Design Tools > DocNav**.

- At the Linux command prompt, enter docnav.

Xilinx Design Hubs provide links to documentation organized by design tasks and other topics, which you can use to learn key concepts and address frequently asked questions. To access the Design Hubs:

- In the Xilinx Documentation Navigator, click the **Design Hubs View** tab.
- On the Xilinx website, see the [Design Hubs](#) page.

**Note:** For more information on Documentation Navigator, see the [Documentation Navigator](#) page on the Xilinx website.

---

## References

1. *Zynq UltraScale+ MPSoC: Embedded Design Tutorial* ([UG1209](#))
2. *Zynq UltraScale+ MPSoC: Technical Reference Manual* ([UG1085](#))
3. *Internal Programming of BBRAM and eFUSES* ([XAPP1283](#))
4. *Secure Boot of Zynq-7000 SoC* ([XAPP1175](#))
5. *Zynq UltraScale+ MPSoC Technical Reference Manual* ([UG1085](#))
6. *Changing the Cryptographic Key in Zynq-7000 SoC* ([XAPP1223](#))
7. *Zynq UltraScale+ MPSoC Software Developer Guide* ([UG1137](#))
8. *Key Revocation Lab* ([XAPP1344](#))
9. *External Secure Storage using the PUF* ([XAPP1333](#))
10. *Zynq UltraScale+ MPSoC: Embedded Design Tutorial* ([UG1209](#))

# Revision History

The following table shows the revision history for this document.

| Date       | Version | Revision                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                 |
|------------|---------|--------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| 11/23/2020 | 2.1     | <p>Updated the flow and design example using Vitis IDE 2020.1.</p> <p>Updated the <a href="#">Introduction</a> section to clarify the BBRAM and eFUSES programming options.</p> <p>Added <a href="#">Figure 10</a>.</p> <p>Modified <a href="#">Figure 2</a>, <a href="#">Figure 3</a>, <a href="#">Figure 4</a>, <a href="#">Figure 5</a>, <a href="#">Figure 6</a>, <a href="#">Figure 7</a>, <a href="#">Figure 8</a>, <a href="#">Figure 9</a>, <a href="#">Figure 11</a>, <a href="#">Figure 12</a>, <a href="#">Figure 13</a>, <a href="#">Figure 14</a>, <a href="#">Figure 16</a>, <a href="#">Figure 17</a>, <a href="#">Figure 18</a>, <a href="#">Figure 19</a>, <a href="#">Figure 20</a>, <a href="#">Figure 21</a>.</p> <p>Modified <a href="#">Table 2</a>, <a href="#">Table 3</a>, <a href="#">Table 4</a>.</p> <p>Updated application projection creation flow for Vitis IDE 2020.1 in <a href="#">Test the functionality of the programmed BBRAM by using a hello software project</a>: section.</p>                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                  |
| 08/31/2020 | 2.0     | <p>Updated for Vitis™ unified software platform. Validated for Vitis IDE 2019.2. Updates describe how to program eFUSES in the field. Added new section <a href="#">Programming BBRAM and eFUSES Using XilSKey Library</a>. Added procedural steps in section <a href="#">Programming the AES Key in BBRAM</a>. Added <a href="#">Figure 1</a>, <a href="#">Figure 2</a>, <a href="#">Figure 3</a>, <a href="#">Figure 4</a>, <a href="#">Figure 5</a>, <a href="#">Figure 6</a>, <a href="#">Figure 7</a>, <a href="#">Figure 8</a>, <a href="#">Figure 9</a>, <a href="#">Figure 11</a>, <a href="#">Figure 12</a>, <a href="#">Figure 14</a>, <a href="#">Figure 15</a>, <a href="#">Figure 16</a>, <a href="#">Figure 17</a>, <a href="#">Figure 18</a>, <a href="#">Figure 19</a>, <a href="#">Figure 20</a>, and <a href="#">Figure 21</a> in section <a href="#">Programming the AES Key in BBRAM</a>.</p> <p>Added procedural steps in section <a href="#">Programming eFUSES for AES and RSA Cryptographic Functions</a>. Added <a href="#">Figure 22</a>, <a href="#">Figure 23</a>, and <a href="#">Figure 25</a>. Added <a href="#">Table 3</a>. Added procedural steps in <a href="#">Programming PUF-related eFUSES</a>. Added <a href="#">Table 4</a>. Added new section <a href="#">Use XLWP Command Line Tool to Program the BBRAM and eFUSES</a>. Added <a href="#">Launching XLWP Tool in Command Line Mode to Program the BBRAM</a>. Added procedural steps in section <a href="#">Launching XLWP Tool in Command Line Mode to Program the BBRAM</a>. Added <a href="#">Figure 25</a>, <a href="#">Figure 26</a>, and <a href="#">Figure 27</a>.</p> |
| 07/26/2017 | 1.0     | Initial Xilinx release.                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                  |

## 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 <https://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 <https://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 2017-2020 Xilinx, Inc. Xilinx, the Xilinx logo, Alveo, Artix, ISE, Kintex, Spartan, Versal, Virtex, Vivado, Zynq, and other designated brands included herein are trademarks of Xilinx in the United States and other countries. PCI, PCIe, and PCI Express are trademarks of PCI-SIG and used under license. AMBA, AMBA Designer, Arm, ARM1176JZ-S, CoreSight, Cortex, PrimeCell, Mali, and MPCore are trademarks of Arm Limited in the EU and other countries. All other trademarks are the property of their respective owners.