

## Andromeda XZU65 Module

# Reference Design for Mercury+ ST1 Base Board User Manual

### **Purpose**

The purpose of this document is to present to the user the overall view of the Andromeda XZU65 module reference design and to provide the user with a step-by-step guide to the complete Xilinx® MPSoC design flow used for the Andromeda XZU65 module.

### **Summary**

This document first gives an overview of the Andromeda XZU65 module reference design and then guides through the complete Xilinx MPSoC design flow for the Andromeda XZU65 module in the getting started section. In addition, the internals and the boot options of the Andromeda XZU65 module reference design are described.

| <b>Product Information</b> | Code     | Name                   |
|----------------------------|----------|------------------------|
| Product                    | AM-XZU65 | Andromeda XZU65 Module |

| Document Information       | Reference      | Version       | Date       |
|----------------------------|----------------|---------------|------------|
| Reference / Version / Date | D-0000-489-026 | 2022.1_v1.0.0 | 03.05.2023 |

| Approval Information | Name      | Position        | Date       |
|----------------------|-----------|-----------------|------------|
| Written by           | ESOM/ABUE | Design Engineer | 17.02.2023 |
| Verified by          | GKOE      | Design Expert   | 03.05.2023 |
| Approved by          | IJOS      | Manager, BU SP  | 03.05.2023 |

#### License

Copyright 2023 by Enclustra GmbH, Switzerland.

Permission is hereby granted, free of charge, to any person obtaining a copy of this hardware, software, firmware, and associated documentation files (the "Product"), to deal in the Product without restriction, including without limitation the rights to use, copy, modify, merge, publish, distribute, sublicense, and/or sell copies of the Product, and to permit persons to whom the Product is furnished to do so, subject to the following conditions:

The above copyright notice and this permission notice shall be included in all copies or substantial portions of the Product.

THE PRODUCT IS PROVIDED "AS IS", WITHOUT WARRANTY OF ANY KIND, EXPRESS OR IMPLIED, INCLUDING BUT NOT LIMITED TO THE WARRANTIES OF MERCHANTABILITY, FITNESS FOR A PARTICULAR PURPOSE AND NONINFRINGEMENT. IN NO EVENT SHALL THE AUTHORS OR COPYRIGHT HOLDERS BE LIABLE FOR ANY CLAIM, DAMAGES OR OTHER LIABILITY, WHETHER IN AN ACTION OF CONTRACT, TORT OR OTHERWISE, ARISING FROM, OUT OF OR IN CONNECTION WITH THE PRODUCT OR THE USE OR OTHER DEALINGS IN THE PRODUCT.

## **Table of Contents**

| 1                  | Overview                      | 4        |
|--------------------|-------------------------------|----------|
| 1.1                | Introduction                  | 4        |
| 1.2                | Prerequisites                 | 5        |
| _                  |                               | _        |
| 2                  | Reference Design Description  | 6        |
| 2.1                | Processing System (PS)        | 6        |
| 2.1.1              | Clocks                        | 6        |
| 2.1.2              | PS DDR4 SDRAM                 | 7        |
| 2.1.3              | SD Card                       | 7        |
| 2.1.4              | eMMC                          | 7        |
| 2.1.5              | 12C                           | 7        |
| 2.1.6              | Quad SPI Flash Controller     | 7        |
| 2.1.7              | UART                          | 7        |
| 2.1.8              | Ethernet                      | 8        |
| 2.1.9              | USB                           | 8        |
| 2.1.10             | GPIOs                         | 8        |
| 2.2                | Programmable Logic (PL)       | 9        |
| 2.2.1              | PL DDR4 SDRAM                 | 9        |
| 2.2.2              | PL Ethernet                   | 9        |
| 2.2.3              | GPIOs                         | 9        |
| 2.2.3<br>2.2.4     |                               | 9        |
| 2.2.4              | System Management             | 9        |
| 3                  | Getting Started               | 11       |
| <b>3</b> .1        | <b>3</b>                      | 11       |
| 3.1<br>3.2         |                               | 12       |
|                    | ·                             |          |
| 3.3                |                               | 13       |
| 3.4                |                               | 14       |
| 3.5                | Running Software Applications | 18       |
| 4                  | Post Configurations           | 20       |
| -                  |                               |          |
| 4.0.1              | Generating the Image File     |          |
| 4.1                | QSPI Flash Boot               |          |
| 4.1.1              | 1 3                           | 20       |
| 4.1.2              |                               | 21       |
| 4.1.3              | <i>3</i>                      | 23       |
| 4.2                | SD Card Boot                  | 23       |
| 4.2.1              | Generating the Image Files    | 23       |
| 4.2.2              | Preparing the Hardware        | 23       |
| 4.2.3              | '                             | 24       |
| 4.2.4              |                               | 24       |
| 4.3                | <b>5</b>                      | 25       |
| 4.3.1              |                               | 25       |
| 4.3.1<br>4.3.2     |                               | 25       |
|                    |                               |          |
| 4.3.3              |                               | 25       |
| 4.3.4              | Booting from the eMMC         | 26       |
| 5                  | Troubleshooting               | 27       |
| <b>5</b> .1        | <b>J</b>                      | 27       |
| 5.2                |                               | 27       |
|                    |                               |          |
| 5.3                |                               | 27       |
| 5.4                |                               | 28       |
| 5.5                |                               | 28       |
| 5.6                | Emmc Boot Issues              | 28       |
| 5.7                |                               |          |
|                    | MCT Issues                    | 29       |
| 5. <i>1</i><br>5.8 | MCT Issues                    | 29<br>29 |

## 1 Overview

## 1.1 Introduction

The Andromeda XZU65 module reference design demonstrates a system using the Andromeda XZU65 module in combination with the Mercury+ ST1 base board. It presents the basic configuration of the device and contains a guided getting started tutorial.

A troubleshooting section is included at the end of the document, to help the user solve potential issues related to board connectivity and/or system functionality.

This reference design does not include any source code for software examples and instead Enclustra provides Application Notes [10] for some selected applications.

An introduction to the Xilinx tools is provided by the documents below:

- Vivado Design Suite User Guide, Embedded Processor Hardware Design [1]
- Zynq UltraScale+ MPSoC: Embedded Design Tutorial, A Hands-On Guide to Effective Embedded System Design [3]

More information on the Andromeda XZU65 module and the Mercury+ ST1 base board can be retrieved from their respective user manuals [4] [5].

The following directory structure applies to the XZU65 Reference Design:

• src — Xilinx pinout and timing constraints and VHDL source code directory

• scripts — Scripts directory required for Vivado project creation

• doc — Reference Design documentation

Pre-generated binaries for any XZU65 variant are released on the XZU65 Reference Design Github page.

## 1.2 Prerequisites

- IT
- A computer with a microSD card slot (optional<sup>1</sup>) running Windows 10 64-bit (or later)
- Software
  - Xilinx Vivado 2022.1 WebPack, Evaluation, Design or System Edition (check the Andromeda XZU65 Module User Manual [4] for details on device support in Xilinx tools)
  - Xilinx Vitis IDE
  - Enclustra Module Configuration Tool (MCT) [6] (optional<sup>2</sup>)
  - A terminal emulation program (e.g. Tera Term)
- Hardware
  - An Enclustra Andromeda XZU65 module
  - An Enclustra Mercury+ ST1 base board
  - An Andromeda to Mercury adapter (AM-ME-ADA1)
- Accessories
  - A 12 V DC power supply
  - A standard micro USB cable
  - A Xilinx JTAG programmer (e.g. Platform Cable USB II) (optional<sup>3</sup>)

<sup>&</sup>lt;sup>1</sup>Only required for SD card boot mode

<sup>&</sup>lt;sup>2</sup>May be used for MPSoC device configuration or for FTDI configuration.

<sup>&</sup>lt;sup>3</sup> Any FTDI device present on Enclustra hardware can be configured to Xilinx JTAG mode using the Enclustra MCT software [6].

## **2 Reference Design Description**



Figure 1: Hardware Block Diagram

## 2.1 Processing System (PS)

#### **2.1.1 Clocks**

The PS input clock frequency is configured to 33.33 MHz. The CPU clock frequency is configured to its corresponding maximum APU clock frequency, as specified in the Zynq UltraScale+ MPSoC Data Sheet (DS925) [2]. The maximum CPU (APU) clock performance depends on the device speedgrade and package. Beside that a 50 MHz and a 100 MHz clock are exported from PS to the PL.

These clocks can be modified in the settings of the processing system in Vivado.

#### 2.1.2 PS DDR4 SDRAM

The DDR4 SDRAM memory runs at its corresponding maximum PS DDR frequency. Depending on the module variant ECC RAM is enabled or disabled (see Andromeda XZU65 Module User Manual [4] for details).

Note that the maximum DDR performance depends on the device speedgrade and package as specified in the Zynq UltraScale+ MPSoC Data Sheet (DS925) [2]. The DDR clock frequency can be modified in the settings of the processing system in Vivado and must be configured according to the Andromeda XZU65 Module User Manual [4].

#### 2.1.3 SD Card

The SD card is configured in the PS to the MIO 46..51 pins. This enables SD card access, as well as booting from the SD card.

To allow the Andromeda XZU65 module to boot from the SD card, the hardware configuration on the Mercury+ ST1 base board must be done according to Section 4.2.2.

#### 2.1.4 eMMC

The eMMC interface is configured in the PS to the MIO 13..22 pins. This enables eMMC device access, as well as booting from the eMMC device. To allow the Andromeda XZU65 module to boot from the eMMC, the boot signals must be configured as in 4.3.4.

For further details refer to the Andromeda XZU65 Module and Mercury+ ST1 Base Board User Manual [4] [5].

#### 2.1.5 I2C

The I2C controller I2C0 is configured to the MIO 30..31 pins. For available devices on the I2C bus refer to the Andromeda XZU65 Module and Mercury+ ST1 Base Board User Manual [4] [5].

### 2.1.6 Quad SPI Flash Controller

The quad SPI flash controller is connected to MIO 0..12 pins in Dual Parallel mode. To allow the Andromeda XZU65 module to boot from the QSPI flash, the hardware configuration on the Mercury+ ST1 base board must be done according to Section 4.1.1.

#### 2.1.7 **UART**

The UART0 is mapped to MIO 26..27 pins and connected to the FTDI controller on the Mercury+ ST1 base board. The UART is configured as shown in Table 2.

| Parameter    | Value   |
|--------------|---------|
| Baud rate    | 115′200 |
| Data         | 8 bit   |
| Parity       | None    |
| Stop         | 1 bit   |
| Flow control | None    |

Table 2: UART Configuration

#### 2.1.8 Ethernet

The Ethernet MAC GEM1 is mapped to the MIO EMIO pins while GEM3 is mapped to the MIO 64..75 pins. Both are connected to a Microchip (Micrel) KSZ9131 Ethernet PHY on the Andromeda XZU65 module using RGMII interfaces. The PHYs can be configured via the MDIO management interface on address 7 and 3.

#### 2.1.9 USB

The USB controller USB0 on MIO 52..63 pins is connected to a USB3320C USB 2.0 PHY. This interface can be configured for USB host, USB device and USB On-The-Go (OTG) operations.

Depending on the required USB mode, the settings in the system controller and the DIP switches on the Mercury+ ST1 base board must be configured correctly. Please refer to the Mercury+ ST1 Base Board User Manual [5] for details.

### 2.1.10 **GPIOs**

The unused MIO pins from the PS are available as GPIOs. For details on the MIO assignement refer to the Multiplexed I/O (MIO) Pins section in the Andromeda XZU65 module User Manual [4]. Check the connectivity of the MIOs that provide user functionality with the Mercury+ ST1 base board User Manual [5].

## 2.2 Programmable Logic (PL)

#### 2.2.1 PL DDR4 SDRAM

The PL dedicated DDR4 SDRAM memory runs at its corresponding maximum Physical Interface (PHY) rate at a voltage of 1.2 V. The data width of this interface is 64 bits.

Note that the maximum DDR performance depends on the device speedgrade, the package and the VCC\_INT voltage (0.85 V by default) as specified in the Zynq UltraScale+ MPSoC Data Sheet (DS925) [2]. The DDR clock frequency can be modified in the settings of Memory Interface Generator (MIG) IP core in Vivado and must be configured according to the Andromeda XZU65 Module User Manual [4].

#### 2.2.2 PL Ethernet

The Ethernet MAC GEM1 is mapped to EMIO pins, providing a GMII interface to the FPGA logic. This interface is routed to a GMII-to-RGMII converter IP core from Enclustra; the RGMII interface is available on FPGA bank N (87 for ZU7 and 88 for ZU11), for connection to one of the two Microchip (Micrel) KSZ9131 Ethernet PHYs. This PHY can be configured via the PL dedicated MDIO management interface on PHY address 7.

The GMII-to-RGMII converter IP core is provided as-is without further documentation or source files. Support for the GMII-to-RGMII converter can be supplied as a part of a support package or design services.

Please refer to the Andromeda XZU65 Module User Manual [4] for the usage and configuration of the Ethernet PHYs.

#### 2.2.3 **GPIOs**

A Xilinx GPIO controller in the PL is connected to the PS via an AXI bus. Some PL GPIOs are connected to LEDs in the top level, as described in Table 3.

The PL firmware contains a 24-bit counter freely running at 50 MHz. The MSB of this counter is used to blink XZU65 LED0 N with a frequency of approximately 3 Hz.

| PL Pin | Signal       | Function                                     |
|--------|--------------|----------------------------------------------|
| AD20   | XZU65_LED0_N | Blinking LED counter MSB                     |
| AE20   | XZU65_LED1_N | GPIO 1, controlled by the PL GPIO controller |
| AK20   | XZU65_LED2_N | GPIO 2, controlled by the PL GPIO controller |
| AJ21   | XZU65_LED3_N | GPIO 3, controlled by the PL GPIO controller |

Table 3: PL Firmware I/O Configuration

#### 2.2.4 System Management

A System Management IP core instance is connected to the PS via an AXI bus, in order to monitor the temperature of the device. The temperature threshold for the FPGA is configured to its maximum allowed temperature.

The constraints provided in the reference design enable FPGA bitstream power-down, when the temperature increases above the threshold. In this case, the PL will be reset, while the ARM processor will still be running.

| Depending on the user application, the Andromeda XZU65 module may consume more power than can be dissipated without additional cooling measures; always make sure the MPSoC is adequately cooled by installing a heat sink and/or providing air flow. Temperature control and monitoring is very important in a complex design. |
|---------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
|                                                                                                                                                                                                                                                                                                                                 |
|                                                                                                                                                                                                                                                                                                                                 |
|                                                                                                                                                                                                                                                                                                                                 |
|                                                                                                                                                                                                                                                                                                                                 |
|                                                                                                                                                                                                                                                                                                                                 |
|                                                                                                                                                                                                                                                                                                                                 |
|                                                                                                                                                                                                                                                                                                                                 |
|                                                                                                                                                                                                                                                                                                                                 |
|                                                                                                                                                                                                                                                                                                                                 |

## 3 **Getting Started**

This section describes the steps required to configure the Andromeda XZU65 module and Mercury+ ST1 base board in order to run a simple HelloWorld example application. The section includes information on how to:

- Mount the module and configure the Mercury+ ST1 base board
- Generate the PL bitstream
- Prepare the software workspace
- Run a software application

## 3.1 Essential Information

#### Warning!

Always check that all connectors of the Mercury+ ST1 base board are aligned with all connectors of the AM-ME-ADA1. And the connectors of the Andromeda XZU65 module have also to be aligned with those on the Andromeda Mercury ADA1 Adapter. The base board and module may be damaged if the module or adapter is mounted the wrong way round and powered up.

If the module or adapter cannot be mounted correctly due to the mechanical collision, please contact Enclustra support.

#### Warning!

Never mount or remove the Andromeda XZU65 module to or from the Mercury+ ST1 base board or from the AM-ME-ADA1 while the Mercury+ ST1 base board is powered. Always remove or turn off the power supply before mounting or removing the Andromeda XZU65 module.

### Warning!

Please read carefully the Andromeda XZU65 module and Mercury+ ST1 base board user manuals before proceeding.

### Warning!

Depending on the user application, the Andromeda XZU65 module may consume more power than can be dissipated without additional cooling measures; always make sure the MPSoC is adequately cooled by installing a heat sink and/or providing air flow.

#### Warning!

Please make sure that a single JTAG adapter is connected to the base board and enabled at a given moment, otherwise the development tools may report errors during JTAG connecting attempts.

Note that when Enclustra MCT [6] is used for MPSoC configuration, all other tools that may be connected to the FTDI device (e.g. Vivado Hardware Manager, Vitis, UART terminal) must be closed.

## 3.2 Hardware Setup



Figure 2: Mercury+ ST1 Base Board Assembly Drawing (Top View)

| Step | Description                                                                                                                                         |
|------|-----------------------------------------------------------------------------------------------------------------------------------------------------|
| 1    | Set the I/O voltage jumpers on the Mercury+ ST1 base board according to label I/O Voltage in Figure 2 (the jumpers are marked with red rectangles): |
|      | <ul> <li>IO A = 1.8 V (position 5-6)</li> <li>IO B = 1.8 V (position 10-12)</li> <li>IO C = 1.8 V (position 9-11)</li> </ul>                        |

Continued on next page...

| Step | Description                                                                                                                                                                                                                                                                                                                                                                                                    |
|------|----------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| 2    | Set the configuration DIP switches on the Mercury+ ST1 base board as follows (see label <b>CFG</b> in Figure 2):                                                                                                                                                                                                                                                                                               |
|      | • CFG = [1: OFF, 2: OFF, 3: ON, 4: ON]                                                                                                                                                                                                                                                                                                                                                                         |
| 3    | Mount the Andromeda XZU65 module on the ADA1. Afterwards mount the Adapter AM-ME-ADA1 on the Mercury+ ST1 base board. Before proceeding check if all connectors are aligned.                                                                                                                                                                                                                                   |
| 4    | Set the configuration DIP switches on the Andromeda Mercury ADA1 Adapter as follows:  • BOOT = [1: ON, 2: OFF, 3: ON, 4: OFF]                                                                                                                                                                                                                                                                                  |
| 5    | Connect the micro USB cable between your computer and the Mercury+ ST1 base board. Use the micro USB port labeled <b>USBUB</b> in Figure 2.                                                                                                                                                                                                                                                                    |
| 6    | Connect the 12 V DC power supply plug to the power connector of the Mercury+ ST1 base board (see label <b>12 V</b> in Figure 2).                                                                                                                                                                                                                                                                               |
| 7    | Make sure that the FTDI device on the Mercury+ ST1 base board is configured to Xilinx JTAG mode using Enclustra MCT [6].                                                                                                                                                                                                                                                                                       |
|      | <ol> <li>Make sure no other FTDI devices are connected to the computer. To ensure, please use the FTprog utility [7] to enumerate all FTDI devices attached.</li> <li>Open the MCT and locate the <b>Settings</b> tab in the menu bar</li> <li>Select <b>Enable configuring any FTDI</b>. (Note that when another FTDI device is attached, proceeding may brick it's pre-programmed functionality.)</li> </ol> |
|      | <ul><li>4. After that click the <b>Enumerate</b> button</li><li>5. In the Action pane, navigate to the <b>FTDI Configuration</b> section</li></ul>                                                                                                                                                                                                                                                             |
|      | <ul><li>6. For the Device mode, select Xilinx JTAG</li><li>7. Press the Set device mode button and wait the process to complete.</li><li>8. Detach and reconnect all USB cables and power afterwards.</li></ul>                                                                                                                                                                                                |
|      | Alternatively, in case an external JTAG adapter is used, connect the JTAG signals from the Xilinx Platform Cable USB to the JTAG connector of the Mercury+ ST1 base board (see label <b>JTAG</b> in Figure 2.                                                                                                                                                                                                  |
|      | Details on the Xilinx JTAG mode configuration and on the JTAG connector are presented in the Mercury+ ST1 Base Board User Manual [5]                                                                                                                                                                                                                                                                           |
| 8    | Open a terminal program on your computer (e.g. Tera Term) and open a serial port connection using the COM port labeled with the higher number from the two newly detected ports.                                                                                                                                                                                                                               |
|      | For issues related to COM ports detection, refer to Section 5.4.                                                                                                                                                                                                                                                                                                                                               |
|      | Configure the UART parameters according to Section 2.1.7.                                                                                                                                                                                                                                                                                                                                                      |

Table 4: Hardware Setup Step-By-Step Guide

## 3.3 FPGA Bitstream Generation

For a fast test of the HelloWorld example application, the pre-generated bitstream may alternatively be used, therefore the steps described in this section may be skipped.

A pre-generated bitstream for any XZU65 variant is released on the XZU65 Reference Design Github page.

| Step | Description                                                                                                                                                                                                                                                                                                                                                                                                         |  |  |
|------|---------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|--|--|
| 1    | Configure the settings file:                                                                                                                                                                                                                                                                                                                                                                                        |  |  |
|      | <ol> <li>Edit the module_name variable in scripts/settings.tcl file, according to your modules name.         This file includes module name and board information required for the project creation script. All settings, except for module_name should be left on default. The list of options for module_name is given in the comments within the Tcl file.     </li> <li>Save the file after editing.</li> </ol> |  |  |
| 2    | Start Xilinx Vivado 2022.1 and create the Andromeda XZU65 module reference design project:                                                                                                                                                                                                                                                                                                                          |  |  |
|      | 1. Click on the Tcl console at the bottom of the page and type:                                                                                                                                                                                                                                                                                                                                                     |  |  |
|      | (a) cd { <base_dir>/reference_design} where <base_dir> is the directory in which you extracted the archive contents. Note the {} around the path.</base_dir></base_dir>                                                                                                                                                                                                                                             |  |  |
|      | (b) source ./scripts/create_project.tcl                                                                                                                                                                                                                                                                                                                                                                             |  |  |
|      | 2. Wait for completion                                                                                                                                                                                                                                                                                                                                                                                              |  |  |
| 3    | Run Synthesis, Implementation & Bitstream Generation in Vivado 2022.1:                                                                                                                                                                                                                                                                                                                                              |  |  |
|      | <ol> <li>Click on Generate Bitstream from the Flow Navigator bar</li> <li>In the Launch Runs window click OK - this will start automatically the entire implementation process</li> <li>Wait for completion → select View Reports → OK</li> </ol>                                                                                                                                                                   |  |  |
| 4    | Export the hardware system information (required for the Vitis IDE):  1. File → Export → Export Hardware and click Next 2. Select Include Bitstream and click Next 3. Leave the file name and export location as default and click Next 4. Click Finish                                                                                                                                                             |  |  |

Table 5: FPGA Bitstream Generation Step-By-Step Guide

## 3.4 Vitis Workspace Preparation

This section describes how to create and run software example applications. The steps are generic, and apply to the software example templates in the Vitis IDE.

A pre-generated binary file of the HelloWorld example application and a hardware description file for any XZU65 variant is released on the XZU65 Reference Design Github page.

| Step | Description                                                                     |
|------|---------------------------------------------------------------------------------|
| 1    | Start the Vitis IDE 2022.1                                                      |
|      | <ol> <li>Select any workspace (e.g. <base_dir>\workspace)</base_dir></li> </ol> |

Continued on next page...

| Step | Description                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                               |  |
|------|-------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|--|
| 2    | Create a new Platform Project                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                             |  |
|      | 1. File $\rightarrow$ New $\rightarrow$ Platform Project<br>2. In the New Platform Project:                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                               |  |
|      | <ul> <li>(a) For Project Name type the <project_name> e.g. Andromeda_XZU65_ST1</project_name></li> <li>(b) Hit Next</li> <li>(c) Select "Create a new platform from hardware (XSA)"</li> <li>(d) Hit the Browse button and select the Hardware Specification .xsa file you exported from Vivado, as described in Section 3.3.  The default export location used by Vivado is <br/></li></ul>                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                              |  |
| 3    | Create a new application                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                  |  |
|      | <ol> <li>File → New → Application Project</li> <li>In the New Application Project window:         <ul> <li>(a) Click Next if Welcome Page is displayed</li> <li>(b) Select the previously generated platform and click Next</li> <li>(c) For Project Name type a description for the new application e.g. "HelloWorld"</li> <li>(d) For the System project select "Create New" and use the default naming e.g. "HelloWorld_system" and click Next</li> <li>(e) For the Domain choose "standalone on psu_cortexa53_0"</li> <li>(f) Hit Next and wait for the tool to proceed</li> <li>(g) Select the HelloWorld (or any another) template <sup>4</sup></li> <li>(h) Hit Finish and wait for completion</li> </ul> </li> <li>Build the application by pressing Ctrl-B and wait for completion</li> <li>Add the pmufw.elf to BOOT.bin</li> <li>(a) Right-click on the application's system project and select "Create Boot Image"</li> </ol> |  |
|      | (a) Right-click on the application's system project and select. Create Boot image  (b) Click on add in the bottom right and navigate to the already created pmufw.elf file  (c) Change partition type to "pmu"  (d) Click on "Ok"  (e) Click on "Create Image" to generate the modified BOOT.bin file                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                     |  |

Table 6: Vitis Workspace Preparation Step-By-Step Guide

<sup>&</sup>lt;sup>4</sup>Depending on the selected sample project changes to the platform BSP might be necessary.



Figure 3: Create Boot Image



Figure 4: Add pmu to boot image

## 3.5 Running Software Applications

This section describes how to run software applications on the Andromeda XZU65 module. The steps are generic, and apply to the software example templates in the Vitis IDE.

| Step | Description                                                                                                                                                                                                                                                                                                                                                                                                      |
|------|------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| 1    | Create a run configuration for the application in Vitis IDE 2022.1:                                                                                                                                                                                                                                                                                                                                              |
|      | <ol> <li>Right click the previously generated application (e.g. HelloWorld) under the system project (e.g. HelloWorld_system) and select Run As → Run Configurations</li> <li>Right-click Single Application Debug and hit New Configuration or double-click on it</li> <li>Enter a run configuration name in the Name field (e.g. HelloWorld) and hit Apply</li> <li>Application tab (see Figure 5):</li> </ol> |
|      | <ul> <li>(a) Enable psu_cortexa53_0 checkbox</li> <li>(b) In the Project Name field click browse and select an application (e.g. HelloWorld)</li> <li>(c) In the Application field click search and select an .elf file (e.g. HelloWorld.elf)</li> <li>(d) Enable Reset processor checkbox</li> <li>(e) Hit Apply</li> </ul>                                                                                     |
|      | <ul> <li>5. Target Setup tab (see Figure 6):</li> <li>(a) For Hardware Platform refer to the corresponding Platform:</li></ul>                                                                                                                                                                                                                                                                                   |
| 2    | <ul> <li>Make sure the Hardware is configured according to Section 3.2:</li> <li>→ Connect the 12 V DC power supply plug to the power connector of the Mercury+ ST1 base board (see label 12 V DC in Figure 2).</li> <li>→ With a serial console program e.g. Tera Term connect to the COM port that corresponds to the Serial Converter B. For issues related to UART, refer to Section 5.4.</li> </ul>         |
| 3    | Start the application by clicking the Run button.                                                                                                                                                                                                                                                                                                                                                                |
|      | This method of starting the application resets the entire system, executes the required initialization for the PS, powers up the PL, configures the PLwith the specified bitstream and downloads the application program to the ARM processor.                                                                                                                                                                   |
|      | In some test setup cases it was observed that the Vitis tool was not able to start a second run session without a hardware reset. If required, power off and on the base board and restart the run configuration.                                                                                                                                                                                                |
|      | For issues related to JTAG, refer to Section 5.3.                                                                                                                                                                                                                                                                                                                                                                |

Table 7: Running an Application Step-By-Step Guide

After the PL is successfully configured, the **DONE** LED should be lit. When the application is running

successfully, the output of the HelloWorld application should appear on the UART console.



Figure 5: Run Configurations Settings - Application Tab



Figure 6: Run Configurations Settings - Target Setup Tab

## 4 Boot Configurations

Once a software application has been developed and tested, this can be used to build a boot image for the module.

The boot image contains the FSBL, the bitstream for programming the PL and the software bare-metal application.

In order to use a software application for the boot image, the code must be mapped for execution from the external DDR memory. If the program is mapped to the on-chip memory, it will overwrite the boot loader during execution.

For a fast test of the boot configurations, the pre-generated .bin images may be used for boot, instead of rebuilding the image. You need to select the file corresponding to the Andromeda XZU65 module variant. Pre-generated binaries for any XZU65 variant are released on the XZU65 Reference Design Github page.

## 4.0.1 Generating the Image File

| Step | Description                                                                                                                           |
|------|---------------------------------------------------------------------------------------------------------------------------------------|
| 1    | Create the boot image from Xilinx Vitis 2022.1 (see Figure 7):                                                                        |
|      | 1. Right click on the system project of the application in the Project Explorer 2. Select Create Boot Image $ ightarrow$ Create Image |
|      | An image will be created for example in <workspace>\HelloWorld\_system\_ide\ bootimage\BOOT.bin.</workspace>                          |

Table 8: Generating the Boot Image File Step-by-Step Guide

Beside the methods presented in this section, there are additional methods how a boot device can be programmed. Please refer to the Enclustra Build Environment's User Documentation for details [9].

## 4.1 QSPI Flash Boot

## 4.1.1 Preparing the Hardware

| Step | Description                                                                                                                    |
|------|--------------------------------------------------------------------------------------------------------------------------------|
| 1    | Disconnect the power supply of the Mercury+ ST1 base board (see label 12 V in Figure 2).                                       |
| 2    | Set the configuration DIP switches on the Andromeda Mercury ADA1 Adapter as follows:  • BOOT = [1: OFF, 2: ON, 3: OFF, 4: OFF] |

Table 9: Preparing the Hardware for QSPI Flash Boot Mode Step-by-Step Guide

## 4.1.2 Programming the QSPI Flash

To program the QSPI flash, JTAG boot mode needs to be configured. Set the DIP switches on Andromeda Mercury ADA1 Adapter as follows:

1. Set BOOT = [1: OFF, 2: OFF, 3: OFF, 4: OFF]

| Step | Description                                                                                                                                                                                                                                                                                                         |
|------|---------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| 1    | Program the boot image from Xilinx Vitis 2022.1 (see Figure 7):                                                                                                                                                                                                                                                     |
|      | <ol> <li>Right click on the system project of the application in the Project Explorer</li> <li>Select Program Flash         Vitis will fill out the fields for the selected application automatically.</li> <li>For Flash Type select qspi-x8-dual_parallel</li> <li>Hit Program and wait for completion</li> </ol> |
|      | The settings in the pictures are for reference only. Note that the configuration file must be selected according to your application.                                                                                                                                                                               |
| 2*   | <b>Optional</b> - if Vitis returns errors during flash programming or if the system does not boot properly, another option is to use Vivado to program the QSPI flash.                                                                                                                                              |
|      | <ol> <li>Flow → Open Hardware Manager</li> <li>Click on Open target → Auto Connect</li> <li>Right click on the corresponding MPSoC device in the left bar → Add Configuration Memory Device (see Figure 8)</li> </ol>                                                                                               |
|      | <ul> <li>(a) For Select Configuration Memory Part choose the memory part according to the Andromeda XZU65 Module User Manual [4].         This is in most cases s25fl512s-1.8v-qspi-x8-dual_parallel.     </li> <li>(b) Hit OK</li> </ul>                                                                           |
|      | 4. In Program Configuration Memory Device window (see Figure 9):                                                                                                                                                                                                                                                    |
|      | <ul> <li>(a) For Configuration file select the boot image generated as described in Section 4.0.1</li> <li>(b) For Zynq FSBL select the FSBL binary generated with the Platform as described in Section 3.4</li> <li>(c) In Program Operations section:</li> </ul>                                                  |
|      | <ul> <li>For Address Range select Entire Configuration Memory Device</li> <li>Enable checkboxes Erase, Program and Verify</li> <li>Hit OK and wait for completion</li> </ul>                                                                                                                                        |
|      | The settings in the pictures are for reference only. Note that the memory part and the configuration file must be selected according to your application.                                                                                                                                                           |

Table 10: Programming the QSPI Flash for QSPI Flash Boot Mode Step-by-Step Guide



Figure 7: QSPI Flash Programming Settings in Vitis



Figure 8: QSPI Flash Programming Settings in Vivado - Adding the Memory Device



Figure 9: QSPI Flash Programming Settings in Vivado

## 4.1.3 Booting from the QSPI Flash

| Step | Description                                                                                       |
|------|---------------------------------------------------------------------------------------------------|
| 1    | Check that the hardware configuration is done according to Section 4.1.1.                         |
| 2    | Press the power-on reset button (see label <b>POR</b> in Figure 2) and release it after a second. |

Table 11: Booting from the QSPI Flash Step-by-Step Guide

## 4.2 SD Card Boot

## 4.2.1 Generating the Image Files

Please refer to Section 4.0.1 describing the steps required to generate a boot image.

## 4.2.2 Preparing the Hardware

| Step | Description                                                                                                                        |
|------|------------------------------------------------------------------------------------------------------------------------------------|
| 1    | Disconnect the power supply of the Mercury+ ST1 base board (see label 12 V in Figure 2).                                           |
| 2    | Enable the SD card boot mode (default) by setting the configuration DIP switches on the Andromeda Mercury ADA1 Adapter as follows: |
|      | • BOOT = [1: ON, 2: OFF, 3: ON, 4: OFF]                                                                                            |

Table 12: Preparing the Hardware for SD Card Boot Mode Step-by-Step Guide

## 4.2.3 Programming the SD Card

| Step | Description                                                                                                                                                                                                                                             |
|------|---------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| 1    | Write the Xilinx SD card boot image to a FAT32 formatted SD card                                                                                                                                                                                        |
|      | <ol> <li>Insert the SD card into the SD card slot of your computer</li> <li>Copy the boot image generated for your application to your SD card (directly in the root directory).</li> <li>Note that the name of the image must be preserved.</li> </ol> |

Table 13: Programming the SD Card for SD Card Boot Mode Step-by-Step Guide

## 4.2.4 Booting from the SD Card

| Step | Description                                                                                                     |
|------|-----------------------------------------------------------------------------------------------------------------|
| 1    | Insert the SD card into the SD card slot of the Mercury+ ST1 base board (see label <b>SD Card</b> in Figure 2). |
| 2    | Connect the power supply to the Mercury+ ST1 base board(see label 12 V in Figure 2).                            |

Table 14: Booting from the SD Card Step-by-Step Guide

## 4.3 eMMC Boot

## 4.3.1 Generating the Image Files

Please refer to Section 4.0.1 describing the steps required to generate a boot image.

## 4.3.2 Preparing the Hardware

| Step | Description                                                                                                           |
|------|-----------------------------------------------------------------------------------------------------------------------|
| 1    | Disconnect the power supply of the Mercury+ ST1 base board.                                                           |
| 2    | Enable the eMMC boot mode by setting the configuration DIP switches on the Andromeda Mercury ADA1 Adapter as follows: |
|      | 1. Set CFG = [1: OFF, 2: ON, 3: ON, 4: OFF]                                                                           |

Table 15: Preparing the Hardware for eMMC Mode Step-by-Step Guide

## 4.3.3 Programming the eMMC

To program the eMMC flash, JTAG boot mode needs to be configured. Set the DIP switches on Andromeda Mercury ADA1 Adapter as follows:

1. Set BOOT = [1: OFF, 2: OFF, 3: OFF, 4: OFF]

| Step | Description                                                                                                                                                                                                                                                                                        |
|------|----------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| 1    | Program the boot image from Xilinx Vitis 2022.1 (see Figure 7):                                                                                                                                                                                                                                    |
|      | <ol> <li>Right click on the system project of the application in the Project Explorer</li> <li>Select Program Flash         Vitis will fill out the fields for the selected application automatically.</li> <li>For Flash Type select emmc</li> <li>Hit Program and wait for completion</li> </ol> |
|      | The settings in the pictures are for reference only. Note that the configuration file must be selected according to your application.                                                                                                                                                              |

Continued on next page...

| Step | Description                                                                                                                                                                                                                                                        |
|------|--------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| 2*   | <b>Optional</b> - if Vitis returns errors during flash programming or if the system does not boot properly, another option is to use Vivado to program the eMMC.                                                                                                   |
|      | <ol> <li>Flow → Open Hardware Manager</li> <li>Click on Open target → Auto Connect</li> <li>Right click on the corresponding MPSoC device in the left bar → Add Configuration Memory Device (see Figure 8)</li> </ol>                                              |
|      | <ul><li>(a) For Select Configuration Memory Part choose emmc.</li><li>This is in most cases jedec4.51-16gb-emmc.</li><li>(b) Hit OK</li></ul>                                                                                                                      |
|      | 4. In Program Configuration Memory Device window (see Figure 9):                                                                                                                                                                                                   |
|      | <ul> <li>(a) For Configuration file select the boot image generated as described in Section 4.0.1</li> <li>(b) For Zynq FSBL select the FSBL binary generated with the Platform as described in Section 3.4</li> <li>(c) In Program Operations section:</li> </ul> |
|      | <ul> <li>For Address Range select Entire Configuration Memory Device</li> <li>Enable checkboxes Erase, Program and Verify</li> <li>Hit OK and wait for completion</li> </ul>                                                                                       |
|      | The settings in the pictures are for reference only. Note that the memory part and the configuration file must be selected according to your application.                                                                                                          |

Table 16: Programming the eMMC for eMMC Boot Mode Step-by-Step Guide

## 4.3.4 Booting from the eMMC

| Step | Description                                                                                       |
|------|---------------------------------------------------------------------------------------------------|
| 1    | Check that the hardware configuration is done according to Section 4.3.2.                         |
| 2    | Press the power-on reset button (see label <b>POR</b> in Figure 2) and release it after a second. |

Table 17: Booting from the eMMC Step-by-Step Guide

## 5 Troubleshooting

### 5.1 Vivado Issues

- If the changes in the block design (including licenses for special IPs) are not propagated into implementation, open the Hierarchy tab in Vivado and regenerate the block design files:
  - 1. Right click on the block design file (.bd)
  - 2. Click on Reset Output Products → Reset
  - 3. Click on Generate Output Products  $\rightarrow$  Generate  $\rightarrow$  OK
- In Vivado 2019.2 and 2020.1 versions it is not possible to program the PL if the device is not in JTAG boot mode. This should be fixed in 2020.2 and later versions. If you still have issues, please refer to AR75416 for a workaround.
- In Vivado Hardware Manager when connecting to the device or programming it a (critical) warning might appear: "PL Power Status OFF, cannot program PL. Check that POR\_B signal is LOW or BOOT mode is JTAG.". This warning usually appears when the device has not been configured yet and the internal PL Power is still disabled. The warning can be ignored usually and does not pop up after the device has been programmed.

## 5.2 Vitis Issues

- If the platform generation in Vitis is not successful or the generated platform is not selectable for applications:
  - 1. Close Vitis
  - 2. delete the workspace folder
  - 3. Restart Vitis and try creating the platform again.
- If Vitis shows the warning "There's no DDR\_1 in the HW design. MMU translation table marks 32 GB DDR..." please check if more than 2GB PS DDR4 memory should be available. For detailed information please check the Xilinx Answer Records and Forum about this warning.

### 5.3 JTAG Connection Issues

- If the JTAG cable is not detected, the following steps should be followed:
  - 1. Make sure that the hardware configuration is made according to Section 3.2
  - 2. If built-in JTAG is used, check that the FTDI device is configured to Xilinx JTAG mode. This can be done using the Enclustra MCT software [6]. More information on the Xilinx JTAG mode configuration on the Mercury+ ST1 base board can be retrieved from the Mercury+ ST1 base board user manual [5].
  - 3. Check that only one JTAG adapter is active and connected to the hardware at a given moment. Make sure that you are not using both built-in JTAG and Xilinx Platform Cable USB.
  - 4. Remove the USB connection and the power supply from the Mercury+ ST1 base board and close Vitis
  - 5. Reconnect the USB and power supply and start Vitis again
  - 6. Check for UART Connection Issues (refer to Section 5.4)
  - 7. Reboot the computer if the problem persists
- If no device is detected, shutdown the hw\_server process e.g. in the Windows Task Manager and try again.

### 5.4 UART Connection Issues

- If the computer is not able to recognize the USB UART on the Mercury+ ST1 base board:
  - 1. Check that the USB cable is connected properly
  - 2. Check that the FTDI VCP drivers are installed
    - (a) Disconnect all JTAG connections
    - (b) Open Device Manager
    - (c) Universal Serial Bus controllers  $\to$  USB Serial Converter A/B  $\to$  Properties  $\to$  Advanced tab  $\to$  enable Load VCP checkbox
    - (d) Reboot the computer if the COM port is still not detected
  - 3. Reinstall the FTDI drivers if the problem persists
- If the computer does not output any character in the terminal program:
  - 1. Check that the FTDI device is set to UART mode:
    - (a) Download and open FT\_Prog utility (this is a third party tool offered by the FTDI company to configure FTDI devices)
    - (b) DEVICES → Scan and Parse
    - (c) Check that for Port A and B the RS232 UART property is true
  - 2. Check that the baud rate for the UART in the block design matches the baud rate set in the terminal program
  - 3. Make sure that Enclustra MCT software is not open. After closing it, unplug and plug in again the USB cable corresponding to the UART communication.

## 5.5 QSPI Boot Issues

- If the Andromeda XZU65 module is not able to boot from the QSPI flash:
  - 1. Use Vivado to program the flash
    - (a) Make sure that the Memory Device part type is correctly selected
    - (b) Make sure Erase and Program options are enabled
    - (c) Select Entire Configuration Memory Device for Address Range
  - 2. If the problem persists, a possible solution is to first erase the flash, and then program it either from Vivado or Vitis

Please refer to Section 4.1.2 for details on QSPI flash programming.

### 5.6 Emmc Boot Issues

- If the Andromeda XZU65 module is not able to boot from the eMMC flash:
  - 1. Use Vivado to program the eMMC
    - (a) Make sure that the Memory Device part type is correctly selected
    - (b) Make sure Erase and Program options are enabled
    - (c) Select Entire Configuration Memory Device for Address Range
  - 2. If the problem persists, a possible solution is to first erase the eMMC, and then program it either from Vivado or Vitis

Please refer to Section 4.3.3 for details on eMMC flash programming.

• With Xilinx 2020.1 tool version eMMC programming gets stuck and does not progress further. A possible workaround is to use tool version 2019.2 and select the binaries and FSBL generated with 2020.1.

## 5.7 MCT Issues

- If the Andromeda XZU65 module is not enumerated in the MCT:
  - 1. Detach all USB cables and power
  - 2. Close all other tools that may be connected to the FTDI device (Vivado Hardware Manager, Vitis, UART terminal).
    - (a) Force close the hw\_server process if it is not closed by Vivado/Vitis after closing the hardware server.
  - 3. Configure the boot mode according to section 3.2 and try again.
- Boot from QSPI fails after programming:
  - 1. Detach all USB cables and power
  - 2. Configure the hardware to boot from the QSPI flash according to section 4.1.2.
  - 3. Reattach USB cable an power accordingly and try again.

## 5.8 Program eMMC Issues

• If eMMC programming procedure of the Andromeda XZU65 module stucks and is therefore not able to be programmed please refer to AR67157 for a workaround.

## **List of Figures**

| 1<br>2<br>3<br>4<br>5<br>6<br>7<br>8<br>9                                            | Create Boot Image                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                   | 6<br>12<br>16<br>17<br>19<br>19<br>22<br>22<br>23                              |
|--------------------------------------------------------------------------------------|-------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|--------------------------------------------------------------------------------|
| List of                                                                              | f Tables                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                            |                                                                                |
| 2<br>3<br>4<br>5<br>6<br>7<br>8<br>9<br>10<br>11<br>12<br>13<br>14<br>15<br>16<br>17 | PL Firmware I/O Configuration                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                       | 7<br>9<br>13<br>14<br>15<br>18<br>20<br>21<br>23<br>24<br>24<br>25<br>26<br>26 |
| Refere                                                                               | ences                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                               |                                                                                |
| [4]  → [5]  → [6]  ht [7]  ht [8]  → [9]  ht [10]                                    | Vivado Design Suite User Guide, Embedded Processor Hardware Design, UG898, Xilinx, 2019 Zynq UltraScale+ MPSoC Data Sheet: DC and AC Switching Characteristics, DS925, Xilinx 2019 Zynq UltraScale+ MPSoC: Embedded Design Tutorial, A Hands-On Guide to Effective Embedded Stem Design, UG1209, Xilinx, 2019 Andromeda XZU65 Module User Manual Ask Enclustra for details Mercury+ ST1 Base Board User Manual Ask Enclustra for details Enclustra Module Configuration Tool (MCT) tps://www.enclustra.com/en/products/tools/module-configuration-tool/ FTDI FT_PROG Utility tps://ftdichip.com/utilities/#ft_prog Enclustra Modules Heat Sink Application Note Ask Enclustra for details Enclustra Build Environment tps://github.com/enclustra-bsp/bsp-Xilinx Enclustra Application Notes tps://github.com/enclustra/I2CAppNote tps://github.com/enclustra/GigabitEthernetAppNote |                                                                                |