



How to build an FPGA design for Aldec TySOM boards using board definition in Xilinx Vivado

Aldec® Disclaimer: The information provided in this document is provided in connection with Aldec's Hardware products. All solutions, designs, schematics, drawings, boards or other information provided by Aldec to Customer are intellectual property of Aldec, Inc. No license, express or implied, by estoppel, or otherwise, to any intellectual property right is granted to Customer by this document or in connection with the sale of Aldec products.

#### **Export Restriction**

Aldec, Inc. Hardware is not to be exported or re-exported, including reference images or accompanying documentation in any form without the appropriate government licenses, if required, and the expressed consent of Aldec, Inc. Purchaser warrants that it is not prohibited from receiving the Hardware under U.S. export laws and that it is not a national of a country subject to U.S. trade sanctions. Purchaser will not use the Hardware in a location that is the subject of U.S. trade sanctions that would cover the Hardware. Purchaser warrants that it is not subject to the U.S. Department of Commerce's table of deny orders or otherwise prohibited from obtaining goods of this sort from the United States.

### **Resale Restriction**

Aldec, Inc. Hardware is not to be resold except within their assigned territory by distributors with a valid written distribution agreement with Aldec, Inc. Purchasers of the Hardware agree not to transfer the Hardware to any third party without express written consent of Aldec, Inc.

2/25/2010

# **1** Table of Contents

| How to build an FPGA design for Aldec TySOM boards using board definit | ion in Xilinx Vivado1 |
|------------------------------------------------------------------------|-----------------------|
| 1 Table of Contents                                                    | 3                     |
| 2 Table of Figures                                                     |                       |
| 3 Introduction                                                         |                       |
| 4 Requirements                                                         | 4                     |
| 5 Available TySOM board definitions                                    | 5                     |
| 6 How to add board definitions to Vivado                               | 5                     |
| 7 How to use TySOM board definition in Vivado                          | 6                     |
| About Aldec, Inc.                                                      |                       |
| 2 Table of Figures                                                     |                       |
| Figure 1: How to start Vivado on Windows                               | f                     |
| Figure 2: Create project in Vivado.                                    |                       |
| Figure 3: Select Vivado project type                                   |                       |
| Figure 4: Select a target board                                        |                       |
| Figure 5: Add a daughter card connections                              |                       |
| Figure 6: Select a daughter card                                       |                       |
| Figure 7: Create a Block Design                                        |                       |
| Figure 8: Window with board components                                 |                       |
| Figure 9: Designer Assistance                                          |                       |
| Figure 10: Applying Zynq preset                                        |                       |



### 3 Introduction

TySOM is a family of development boards for embedded applications that features Xilinx® Zynq™ all programmable module combining FPGA with ARM® Cortex processor. Plethora of included peripherals makes these boards useful in various embedded applications like Automotive, IoT, Industrial automation or embedded HPC.

More information and parameters about the boards are provided on Aldec website <a href="https://www.aldec.com/en/products/emulation/tysom">https://www.aldec.com/en/products/emulation/tysom</a> boards.

One way of preparing projects for the TySOM board is using the Xilinx Vivado tool which enables to create, synthesize, perform timing analysis and implement systems for FPGA platforms. Using Vivado board definitions that have been added to a board repository allows to faster creating systems. After selecting a specific board, the project is configured with the predefined interface for that board and the Vivado design tools provide designer assistance to IP customization and creating IP integrator designs.

Using Aldec TySOM boards in Vivado tool is quite straightforward, because provided board definitions contain customized configurations of components available on the TySOM board. They describe the different operating modes supported by those components, list the signal interfaces implemented by those components, suggest the preferred IP to implement those interfaces in a design project and maps the logical ports of the interface definition to the physical ports and components pins of the Xilinx device.

This document will demonstrate how to build a Vivado design using TySOM Vivado board definition provided by Aldec. In case of any additional questions visit Aldec website <u>www.aldec.com</u> or create a support case in a customer-only portal <u>https://www.aldec.com/en/support/customer\_portal/cases</u>.

This flow requires using TySOM Vivado board definition from Aldec <u>GitHub</u> so a TySOM user does not have to build a Vivado project from the scratch.

# 4 Requirements

### **Hardware**

- Aldec TySOM board:
  - o <u>TySOM-3A-ZU19EG</u>
  - o <u>TySOM-3-ZU7EV</u>
  - o TySOM-2-7Z100
  - o <u>TySOM-2-7Z045</u>
  - o *TySOM-2A-7Z030*
  - o *TySOM-1-7Z030*
  - o *TySOM-1A-7Z010*
- Aldec FMC daughter card:
  - o FMC-ADAS



#### Software

Xilinx Vivado tool 2018.2 or newer

## 5 Available TySOM board definitions

All board definitions for Aldec TySOM boards are freely available on Aldec <u>GitHub</u>. Therefore, a user does not have to prepare all necessary files for TySOM board to use the board with the Vivado tool. All of them are provided and are ready to use with Vivado tool.

Every board definition includes the following files:

- 1. board.xml
- 2. preset.xml
- 3. part0\_pins.xml
- 4. Board image
- 5. preset.tcl

According to the selected TySOM board, the user need to choose one of the available definitions:

- 1. TySOM-3A-ZU19EG
- 2. TySOM-3-ZU7EV
- 3. TySOM-2-7Z100
- 4. TySOM-2-7Z045
- 5. TySOM-2A-7Z030
- 6. TySOM-1-7Z030
- 7. TySOM-1A-7Z010

Also FMC daughter cards are available:

1. FMC-ADAS

## 6 How to add board definitions to Vivado

Adding custom board definition files to Vivado can be done in two ways:

1. By special initial file for Vivado.

Create *Vivado\_init.tcl* file in a local user folder:

- for Windows 7 %APPDATA%/Xilinx/Vivado/Vivado\_init.tcl
- for Linux \$HOME/.Xilinx/Vivado/Vivado\_init.tcl

This file should contain a command like that:

set\_param board.repoPaths [list <path1> <path2> <path3>]

Where <pathx> is the path to a directory containing TySOM or FMC board definition.



2. By copying files into Vivado installation folder.

Is it also possible to copy all board files to Vivado installation folder. The path to this folder in Vivado is <*VIVADO\_PATH>/data/boards/board\_files*.

## 7 How to use TySOM board definition in Vivado

This chapter describes step by step how to create a Vivado project for the selected TySOM board using the TySOM Vivado board definition.

- 1. Create a working directory and start the Vivado from that directory.
  - for Windows:

After creating the directory, open the Windows command line and run the <**PATH\_TO\_VIVADO>/.settings64-Vivado.bat**. Then, run Vivado from the same path by typing **vivado** in the command line and pressing Enter.

Figure 1: How to start Vivado on Windows.

### • for Linux:

Create a working directory and "cd" to that folder. Next source environment settings from Vivado tool by command **source <PATH\_TO\_VIVADO>/settings64.sh** and start Vivado tool by calling **vivado**.

- 2. Create a Vivado project.
  - Click Create Project.



Figure 2: Create project in Vivado.

- Click Next.
- Provide a project name and choose previously created directory as project location (it is just set as default). Click *Next*.

THE DESIGN VERIFICATION COMPANY

• Select **RTL Project** and click **Next**.



Figure 3: Select Vivado project type.

- Two times click **Next**.
- Select a target board. Boards added to Vivado board repository in step 1 should be visible here.



Figure 4: Select a target board.

• Some of TySOM boards have FMC connectors. Board connections can be added by selecting a FMC daughter card as shown in Figure 5 and Figure 6.



Figure 5: Add a daughter card connections.



Figure 6: Select a daughter card.

- Then click Next.
- Click Finish.
- 3. Add repository with custom IPs and interfaces.
  - Unzip a provided *ip\_repo.zip* file for the selected TySOM board definition.
  - Select Tools → Settings.
  - Go to *Project Settings* → *IP* → *Repository*.
  - Add a file path to directory where the *ip\_repo.zip* file was unpacked.
  - Click *OK*.



4. Create a Block Design by clicking *Create Block Design* from *Flow Navigator*.



Figure 7: Create a Block Design.

5. Add customized board components to the design canvas. The components available for selected board are listed in the window *Board*, as shown in the Figure 8.



Figure 8: Window with board components.

- 6. You can add own IP cores if it is needed.
- 7. To complete connections you can use Designer Assistance by clicking *Run Block Automation* and

THE DESIGN VERIFICATION COMPANY

**Rev. 1.0** 

#### **Run Connection Automation.**



Figure 9: Designer Assistance.

- 8. The Zynq can be configured with default settings from the Vivado board definition.
  - Click Run Block Automation.
  - Select zynq\_ultra\_ps\_e\_0 and Apply Board Preset, as shown in the Figure 10.
  - Click OK.



Figure 10: Applying Zynq preset by running block automation.

Another way to configure the Zynq is by using tcl script from the Vivado board definition.

- Double click on the Zynq block.
- Click **Presets** and next **Apply Configuration...**.

THE DESIGN VERIFICATION COMPANY



Figure 11: Applying Zynq preset by using tcl script.

- Select the tcl script from Vivado board files and click **OK**.
- 9. Then you can run implementation and generate a bitstream for the design.

# **About Aldec, Inc.**

Established in 1984, Aldec Inc. is an industry leader in Electronic Design Verification and offers a patented technology suite including: RTL Design, RTL Simulators, Hardware-Assisted Verification, Design Rule Checking, IP Cores, DO-254 Functional Verification and Military/Aerospace solutions. Continuous innovation, superior product quality and total commitment to customer service comprise the foundation of Aldec's corporate mission. For more information, visit <a href="www.aldec.com">www.aldec.com</a>.

