





# Lecture Notes and Practical Courses on System on Chip (SoC): Materials for Embedded Systems Subjects

József VÁSÁRHELYI & Ahmed BOUZID

**First Edition** 









Authors:Dr. habil. József VÁSÁRHELYI, Associate Professor<br/>Dr. Ahmed BOUZID, Adjunct ProfessorLecturer:Dr. Rabab BENOTSMANE, Assistant LecturerEditor:University of MiskolcKeywords:Embedded Systems, FPGA, SoC, Computational Technologies, HDL

November 2021

All rights reserved. No part of this book may be reproduced, in any form or by any means without permission in writing from the publisher.

ISBN 978-963-358-238-1









### M40A>> ATMK1 449H >>H>>>

Translation: There is no rose without thorns.

Hungarian proverb

QOET OXX:Q XOO EO SENNO :+D:XOGOO ONOXNEE X:O SECOI

Translation: Always aim for the moon; if you miss, you'll land among the stars.

Amazigh (Berber) proverb



i







# **Contents**

| 1 | Emb | edded System Architectures – System on Chip Anatomy            | 1  |  |  |  |  |  |
|---|-----|----------------------------------------------------------------|----|--|--|--|--|--|
|   | 1.1 | Introduction to Embedded Systems                               | 1  |  |  |  |  |  |
|   | 1.2 | System on Chip (SoC)                                           | 1  |  |  |  |  |  |
|   |     | 1.2.1 Introduction to SoCs                                     | 1  |  |  |  |  |  |
|   |     | 1.2.2 The Principle of SoCs                                    | 3  |  |  |  |  |  |
| 2 | The | ne Zyng device 9                                               |    |  |  |  |  |  |
|   | 2.1 | Introduction                                                   | 9  |  |  |  |  |  |
|   | 2.2 | Zynq-7000 Overview                                             | 10 |  |  |  |  |  |
|   | 2.3 | The Zyng Processing System                                     | 10 |  |  |  |  |  |
|   |     |                                                                | 10 |  |  |  |  |  |
|   |     | 2.3.2 Memory interfaces                                        | 16 |  |  |  |  |  |
|   |     | 2.3.3 Processing System Interconnect                           | 16 |  |  |  |  |  |
|   |     |                                                                | 16 |  |  |  |  |  |
|   |     | 2.3.5 PS Boots first                                           | 16 |  |  |  |  |  |
|   |     | 2.3.6 Clock resources                                          | 17 |  |  |  |  |  |
|   | 2.4 | Summary                                                        | 17 |  |  |  |  |  |
| 3 | VHD | VHDL hardware description language 19                          |    |  |  |  |  |  |
|   | 3.1 | Introduction to Hardware Description Language                  | 19 |  |  |  |  |  |
|   | 3.2 |                                                                | 20 |  |  |  |  |  |
|   | 3.3 |                                                                | 21 |  |  |  |  |  |
|   |     |                                                                | 22 |  |  |  |  |  |
|   |     | 3.3.2 Verilog hardware description language                    | 22 |  |  |  |  |  |
|   |     |                                                                | 23 |  |  |  |  |  |
|   | 3.4 |                                                                | 23 |  |  |  |  |  |
|   |     | 3.4.1 Entity as the interface model                            | 25 |  |  |  |  |  |
|   |     | 3.4.2 Architecture as model functionality, behavior, structure | 25 |  |  |  |  |  |
|   |     | 3.4.3 Constants and Signals                                    | 27 |  |  |  |  |  |
|   |     | 3.4.4 Packages, Libraries                                      | 27 |  |  |  |  |  |
|   |     | -                                                              | 28 |  |  |  |  |  |
|   |     | 3.4.6 VHDL Objects                                             | 28 |  |  |  |  |  |
|   |     | 3.4.7 Data types and operations                                | 29 |  |  |  |  |  |



BEFEKTETÉS A JÖVŐBE

ii







|   | 3.5  | Behavioral system description in VHDL                               | 30  |  |  |  |  |
|---|------|---------------------------------------------------------------------|-----|--|--|--|--|
|   |      | 3.5.1 Combinational Signal Assignments                              | 30  |  |  |  |  |
|   |      | 3.5.2 Sequential signal assignments                                 | 31  |  |  |  |  |
|   |      | 3.5.3 Conditional Decisions in processes                            | 34  |  |  |  |  |
|   | 3.6  | Structural description in VHDL                                      | 36  |  |  |  |  |
| 4 | Hard | Hardware and software setup                                         |     |  |  |  |  |
|   | 4.1  |                                                                     | 42  |  |  |  |  |
|   |      |                                                                     | 47  |  |  |  |  |
|   |      | 5                                                                   | 48  |  |  |  |  |
|   | 4.2  | 5                                                                   | 48  |  |  |  |  |
|   | 4.3  | UART-USB driver install                                             | 49  |  |  |  |  |
| 5 | Emb  | edded system Design with Zynq, hardware and software design basics  | 51  |  |  |  |  |
|   | 5.1  |                                                                     | 52  |  |  |  |  |
|   |      |                                                                     | 52  |  |  |  |  |
|   |      |                                                                     | 80  |  |  |  |  |
|   | 5.2  | $\cdots$                                                            | 99  |  |  |  |  |
|   |      | 5.2.1 Create and Manage IP Project                                  |     |  |  |  |  |
|   |      | 5.2.2 Create the Vivado Project with User Designed IP               |     |  |  |  |  |
|   |      | 5.2.3 Launch Vitis and Generate the Test Application of the project | 131 |  |  |  |  |
| 6 |      |                                                                     | 142 |  |  |  |  |
|   | 6.1  |                                                                     |     |  |  |  |  |
|   |      |                                                                     | 143 |  |  |  |  |
|   |      | 6.1.1 Phase 1: Coding and Simulation                                |     |  |  |  |  |
|   |      | 6.1.2 Phase 2: Hardware design, Implementation and Test             |     |  |  |  |  |
|   | 6.2  | Project 2: Remote DC Motor Control using SoC and Hall effect Sensor | 144 |  |  |  |  |
| 7 | Exer |                                                                     | L45 |  |  |  |  |
|   | 7.1  | Multiple Choice Quizzes                                             |     |  |  |  |  |
|   | 7.2  | Questions                                                           | 146 |  |  |  |  |
| Α | Addi |                                                                     | 151 |  |  |  |  |
|   | A.1  | GPS Data                                                            |     |  |  |  |  |
|   |      | A.1.1 10 seconds 1Hz GPS NMEA (correct data)                        |     |  |  |  |  |
|   |      | A.1.2 10 seconds 1Hz GPS NMEA (incorrect data)                      | 152 |  |  |  |  |









# Chapter 1

# Embedded System Architectures – System on Chip Anatomy

# **1.1 Introduction to Embedded Systems**

Is a computing system that has been designed to accomplish a single specific application. Embedded systems can be based on homogeneous and heterogeneous technologies. The most familiar ones are the digital, analog or mixed-signal integrated circuits. However, some other technologies are not excluded since they offer better performances for some applications, for instance Quantium computers, Integrated Fluidic Circuits, Photonic Integrated Circuits and many other Unconventional computing systems.

Microcontrollers and Microprocessor are basically not embedded systems before being programmed.

# 1.2 System on Chip (SoC)

## **1.2.1** Introduction to SoCs

The advance of microelectronics allows the reduction of the size of transistors to get them embedded in increasingly small spaces. This ability to miniaturize components gives us the possibility of integrating different components in the same chip that were previously connected in a PCB (Printed Circuit Board) (See fig. 1.1). We are therefore witnessing the development of SoCs (System on Chip). Previously a digital computer was a single logic gate. Gathering those logic gates according to a specific architecture gives birth to processors. The packaging and miniaturization of these processors is the key point in the creation of microprocessors. What mainly differs between microprocessors and microcontrollers is the autonomy in terms of computation; in other words, microprocessors need other components, called peripherals (e.g. memory, I/O ...), for normal operation. That said, if in addition to peripherals









"FŐNIX ME" – Megújuló Egyetem felsőoktatási intézményi fejlesztések a felsőfokú oktatás minőségének és hozzáférhetőségének együttes javítása érdekében EFOP 3.4.3-16-2016-00015

are added other computing units from other technologies (Graphical Processors, Sound Processors ...), gives a System-on-Chip.



Figure 1.1: Miniaturization from a Printed Circuit Board to a System on Chip

The interest is to minimize the size, the energy consumption and above all to expand the fields of application. SoCs are a systematic result of the miniaturisation of processors, in consequence, they are useful for creating custom architectures that can accelerate microcontrollers or microprocessors for some tasks.

A hardware accelerator is a computational element that helps the main processing system to perform some tasks. The latter can be: matrix computations, floating point operations, image processing, digital signal processing... In addition to some tasks that cannot be performed by a digital processor such us: conditioning and analog signal processing.

SoCs allow to create other architectures and take benefits of design reuse by means of the emergence of IPs (Intellectual Properties). This leads to the ease of reuse, the reduction of time to market and therefore cheaper products.

#### Moore's Law

According to Gordon Moore, in 1965 the number of transistors in a given area on a chip could double every 18-24 months [Moo98]. In other words, it is possible to double the efficiency of semiconductor technology, and therefore chips, every two years or so while keeping the same power consumption. This law has enabled manufacturers of microelectronic manufacturing to clearly define their objectives and avoid unfair competition. 40 years after Moore's prediction, i.e. in 2005, the latter himself mentioned the future of this law which will end around 2025. Indeed, if we follow the evolution curve of the size of the transistors (Fig. 1.2), we can see that by 2025 the size will be around 2nm which is roughly equivalent to the size of two glucose molecules.













Figure 1.2: The evolution of the number of transistors, their density and size

## **1.2.2** The Principle of SoCs

A System-on-Chip (SoC) is a circuit that packages computing elements into a single die dedicated for an autonomous task. From this definition one could understand that previously the elements of calculations were separated in different chips. These computers can be simple transistors from their basic purposes/function (switch inverter, amplification), to more complex circuits (memories, processors...). Computers have more and more functionalities thanks to the ability to merge multiple heterogeneous technologies in the same chip such as mixed-signal integrated circuits.

An SoC can be defined by the integration of computational technologies into a single chip. From this definition SoC could divided into 3 types, these types are chronologically ordered:

**Specialized SoCs**, which also belongs to the family of ASICs (Application-Specific Integrated Circuit) since they are dedicated to a specific application.

The first System-on-Chip was an Intel 5810A CMOS chip created in 1972 for Microma-Seiko digital watches. The IC has two functions: LCD driver and timer. [Cor76] [Jr.07]

The Microma liquid crystal display (LCD) digital watch is the first product to integrate a complete electronic system onto a single silicon chip. [CGL<sup>+</sup>20] [VSM01] [HKM08]











Figure 1.3: The first wristwatch equipped with a dedicated SoC: The Seiko Microma in 1974 [Pre14]



Figure 1.4: The prototype of the Intel 5810A based watch [VSM01]

**Programmable SoCs.** This category concerns chips which contain a microprocessor, peripherals, and a programmable logic area (or FPGA). Zynq is a family of Xilinx SoCs which will be used to implement the labs proposed in this teaching material (see fig. 1.6). Actual research works propose chips where a programmable analog area is also included in the same chip which allows flexibility for mixed-signal (analog and digital) designs such as the RASP 3.0 (Reconfigurable Analog Signal Processor) (see 1.8). Actual Programmable SoCs (such as ACAP from Xilinx) are mainly a combination of microprocessors, FPGA, DSPs, GPU, RF, and notably Intelligent Engines capable of implementing artificial intelligent











Figure 1.5: Block diagram of the first SoC: the Intel 5810A [Cor76]

algorithms (See fig 1.7). Unlike Programmable SoCs, the previous category has the disadvantage of its fixed architecture and its impossibility to upgrade.











Figure 1.6: The architecture of Xilinx's Zynq Z-7010 SoC



Figure 1.7: The architecture of Xilinx's ACAP (Adaptive Compute Acceleration Platform)









"FŐNIX ME" – Megújuló Egyetem felsőoktatási intézményi fejlesztések a felsőfokú oktatás minőségének és hozzáférhetőségének együttes javítása érdekében EFOP 3.4.3-16-2016-00015



Figure 1.8: The architecture of the RASP 3.0 (Reconfigurable Analog Signal Processor) [STGH19]

**Microprocessor based SoCs**. This type constitute the main concern of the actual market of mobile phones, tablets, and some laptops. In addition to a multicore microprocessor, these chips mainly contain a GPU, DSPs, memory, and peripherals. Comparing to Programmable SoCs, this type of SoCs are not reconfigurable i.e., its architecture is fixed, however contain much higher performance processors.











Figure 1.9: Detailed die photo of the Apple's M1 SoC (2020) [tec]









# **Chapter 2**

# The Zynq device

# 2.1 Introduction

In the previous chapter was mentioned the impact of Moore's law on the evolution of integrated circuits. There were treated the SOC structures in general and was mentioned that the first system on chip was created by Intel. We have to clarify that this Intel's SOC was not programmable by the user. In this sense this Intel 5810A was an Application Specific Integrated Circuit (ASIC). Before we introduce the Zynq device let us mention some milestones, which lead to the All Programmable System on Chip (AP-SOC) architecture, which is the Zynq device and also should be here mentioned the Adaptive Compute Acceleration Platform (ACAP), which is much more then a system on chip. First it should be mentioned Tsugio Makimoto's paper [Mak02] in which the author detailed that evolution of integrated circuit (IC) technology every ten years oscillating between the standardization and customization depending on the "technology crisis". Also the author predicted the second digital wave, which came after the PC world (representing the first digital wave). In this sense it was easy to predict that different user programmable circuits and fix function IC will converge in what we call today APSOC and ACAP. We can affirm that because of the "von Neumann centered" engineering world, since the appearance of the FPGA on the market, it became a challenge to implement in the FPGA a processor. VHDL (Very High Speed Integrated Circuit Hardware Description Language) offered the solution to integrate a so called soft processor in the FPGA. These processors (8051 and PIC) were not integrated physically in the chip but they were described in VHDL and embedded in the user design. One can realize that almost from beginning of the FPGA era appeared the need to have a processor together with the FPGA in the same chip.

The first *hard processor* physically integrated in a System on Chip (hard processor and FPGA) was the 8032 micro-controller realized by Triscend in 1998 and later this company integrated the ARM7 processor (Xilinx acquired Triscend in 2004). Since the department always used Xilinx FPGA and APSOC in research and education this chapter focus on the most current device used in the embedded systems, which is the Zynq device. The chapter will not give a detailed description of the device, since there is









a huge literature about the Zynq device [[ARMb], [CEES14], [Xil18b]] and other materials found on the Xilinx webpage.

# 2.2 Zynq-7000 Overview

Based on the data sheet [Xil18b] The Zynq-7000 device is first generation architecture based on the Xilinx SoC architecture. The chip processing system (PS) integrate in the device a dual core ARM<sup>®</sup> Cortex<sup>™</sup>-A9 processor and programmable logic (PL) based on the 28 nm technology. Strictly speaking the Zynq device PS shows micro controller structure with its on-chip memory and external memory interfaces with a rich set of peripheral interfaces such as DMA controller, Ethernet MAC, USB 2.0B OTG interfaces, CAN 2.0B controllers, SD/SDIO 2.0/MMC3.31 compliant controllers, full duplex SPI ports, high-speed UARTs and multiplexed IOs for peripheral pin assignment. The connectivity within the PS and between the PS and PL it is realized with the AMBA<sup>®</sup> AXI standard interface bus. The programmable logic contains Configurable Logic Blocks (CLB), 36 Kb Block RAM, Digital Signal Processing (DSP) blocks, Programmable I/O Blocks (IOB), JTAG Boundary Scan interface, PCI Express<sup>®</sup> Block and two 12 bit Analog to Digital (AD) converters. With this reach architecture the Zynq-7000 device target "cost sensitive as well as high performance" embedded applications. In the following pages we will present the PS and the PL system. We underline that for an effective SoC embedded system development it is very important to have a deep knowledge about the hardware structure.

## 2.3 The Zynq Processing System

The hard processor integrated in all of Zynq devices is the ARM Cortex 9. The processing system incorporates not just the the ARM processor but also resources that come to extend the processor to a complex dual core micro controller. The Application Processing Unit (APU) is a dual core processing system. Each ARM processor has instruction and data cache, memory management unit (MMU) and a floating point NEON media processing engine for SIMD (Simple Instruction Multiple Data) support. The Accelerator coherency port (ACP) interface enable a coherent access from PL to CPU memory space. The 8-channel DMA supports multiple transfer types. Axi interface enable high throughput DMA transfers. Also the DMA has 4 channels to the PL. Interrupt are handled by the General Interrupt Controller (GIc), program execution can be controlled by the Watchdog Timers. The APU also has two triple timers/counters.

## 2.3.1 ARM processor

The ARM core have RISC architecture. RISC architectures have simple and powerful instructions, which are executed in a single clock cycle. Basically the RISC architecture reduces the complexity of instructions performed by the hardware and provide greater flexibility in software. For the ARM processors the RISC philosophy is implemented with four major considerations as detailed in [SSW04].











Figure 2.1: The Zynq Processing System [Xil18b]









"FŐNIX ME" – Megújuló Egyetem felsőoktatási intézményi fejlesztések a felsőfokú oktatás minőségének és hozzáférhetőségének együttes javítása érdekében EFOP 3.4.3-16-2016-00015

- 1. RISC Instructions processors have a reduced number of instructions. All instructions can be executed in single clock cycle and each have a fixed length to allow pipeline instruction execution.
- 2. Pipelines Multiple instructions are executed in parallel, each instruction, which participate in the pipeline execute a separate phase of the instruction execution.
- 3. Registers The processor have a large number of general purpose register set. Any register can store data or address.
- 4. Load-Store architecture The processor process only data stored in registers. To transfer data between the register and external memory there are special load and store instructions. This comes from the fact that memory instructions are costly.

### **ARM registers**

The Cortex A9 processor implements the ARMv7-A architecture that include the following architecture extensions: SIMD architecture for integrated floating-point vector operations; vector floating point computation (IEEE 754 standard); security extension for enhanced security; multiprocessing extensions for multiprocessing functionality ([ARMb]). General purpose registers are available in user mode, which hold data or and address. The register bank contain sixteen general purpose registers plus the special purpose register bank. Figure 2.2 represent a general overview of the registers. In the figure the special registers can differ from the represented one.

Registers R0 - R12 are general purpose registers, which are divided in low registers (R0-R7) and high registers (R8-R12). The low registers can be accessed by any instructions, while the high registers cannot be accessed by some Thumb instructions.

Register R13 is the Stack Pointer records the current address of the stack. R13 it is used for saving the context of a program while switching between tasks. It has to stack pointer (SP) registers. On of SP is the Main stack pointer (MSP), used in applications that require privileged access such as operating system kernel, and exception handlers. The other stack pointer is the Process Stack Pointer (PSP), which is used in base-level application code (when not running an exception handler).

R14 is the Link Register (LR) used to store the return address of a subroutine or a function call.

R15 register is the Program Counter (PC) used to record the address of the current instruction code. It is automatically incremented by 4 at each operation (for 32-bi instruction code). Exceptions are the branching operations. A branching operation, such as a function calls, will change the PC content to a specific address, meanwhile save the current PC to the Link Register. The PC will load the value from LR after a function is finished.

Special register provide information about the program execution status, and provide the ALU (Arithmetical Logical Unit) flags. The xPSR register contains three registers, such as Application PSR (APSR) containing the ALU flags, the Interrupt PSR (IPSR), containing executing interrupt service routine number and the EPSR the Execution PSR (EPSR). For a detailed register description please consult [ARMb] Technical Reference Manual.











Figure 2.2: ARM registers available in user mode









### The Advanced Micro-controller Bus Architecture (AMBA)

For System on Chip architectures there are two bus types: external and internal bus.

| AMBA Family | Bus Protocol | Processor             |
|-------------|--------------|-----------------------|
| AMBA5       | СНІ          | Cortex-A57, A53       |
| AMBA4       | ACE          | Cortex-A7, A15        |
|             | AXI4         |                       |
|             | AXI          | Cortex-A9, A8, R4, R5 |
| AMBA3       | AHB          | Cortex-M0, M3, M4     |
|             | APB          | Cortex-M0, M3, M4     |
|             | ATB          |                       |
| AMBA2       | AHB, ATB     | ARM7, ARM9            |
| AMBA1       | ASB, APB     |                       |

#### Table 2.1: ARM AMBA bus types and examples

The external bus connects off-chip memory, and other external devices. The Zynq processing system has an external memory interface to connect external memories such as DDR2, DDR3 and other newer memory types. In this way the user do not have to care about external memory interfacing. The internal bus connects internal components inside the chip. This bus is known as system bus with internal bus characteristics, which depends only by the programmable interconnections. The ARM processor cores have standardized bus interface architecture called also AMBA bus. This specification is intended to implement the on-chip communication interface. The AMBA standard is an open standard on-chip specification. The internal bus is the standard interface that enables Intellectual Property (IP) re-use and facilitate the development of multi-processor designs. Table 2.1 defines the AMBA bus protocols. Since the SOC Zynq architecture use AXI bus protocol, here we just enumerate all the other AMBA bus protocols in order to get an idea about what their acronym means:

- The AMBA5 CHI (Coherent Hub Interface) specification defines the interfaces for the connection of fully coherent processors.
- AMBA4 ACE Coherency Extensions (ACE) extends AXI with additional signaling introducing system
  wide coherency.This system coherency allows multiple processors to share memory and enables
  technology like ARM's big.LITTLE processing. The ACE-Lite protocol enables one-way aka IO coherency, for example a network interface that can read from the caches of a fully coherent ACE
  processor [KS13].









"FŐNIX ME" – Megújuló Egyetem felsőoktatási intézményi fejlesztések a felsőfokú oktatás minőségének és hozzáférhetőségének együttes javítása érdekében EFOP 3.4.3-16-2016-00015

- AMB AXI Advanced is part of the ARM Advanced Micro-controller Bus Architecture AXI3 and AXI4 specifications [ARMa] is a parallel high-performance, synchronous, high-frequency, multi-master, multi-slave communication interface, mainly designed for on-chip communication. AXI offers a wide spectrum of features, including:
  - separate address/control and data phases;
  - support for unaligned data accesses;
  - burst-based transfers, with a single transmission of the starting address;
  - separate and independent read and write channels;
  - support for outstanding transactions;
  - support for out-of-order transaction completion for transactions having different thread IDs on the same master port. Transactions on the same master port that have the same thread ID must be completed in order. Additionally, different master ports may be completed out of order with respect to each other.
  - support for atomic operations.
- AHB Advanced High-performance Bus is a bus protocol introduced in Advanced Micro-controller Bus Architecture. A simple transaction on the AHB bus consists of an address phase and a subsequent data phase. Access to the target device is controlled through a non-three-state multiplexer, for this reason only one bus-master is allowed at a time. Allows development of embedded systems in FPGA.
- APB Advanced Peripheral Bus is a low cost interface optimized of low power consumption and reduced interface complexity. The APB interface is a simple, synchronous protocol. It is not a pipeline protocol.
- ATB Advanced Trace Bus defines how a trace information transfers between components in a trace system. The ATB interface supports various features, including: stalling of data, using valid and ready responses, control signals that indicate the number of bytes valid in a cycle, identification of the originating component, by signaling an associated ID with each data packet, support for any trace protocol information, data information or data format requirements, identification of data from all originating components, flushing.

### ARM Cortex-A9 Processor Micro-Architecture

Based on the ARM documentation [ARMb] ARM Cortex A9 processor instructions has a speculative outof-order speculative issue super-scalar execution 8-stage pipeline giving 2.50 DMIPS/MHz/core [ARMb] each core processing. The NEOM co-processor technology allows SIMD operation, and floating point unit accelerate the floating point operations with twice speed of the previously ARM FPU version. THUM2-2 instruction set increase code density without influencing the instruction execution speed









"FŐNIX ME" – Megújuló Egyetem felsőoktatási intézményi fejlesztések a felsőfokú oktatás minőségének és hozzáférhetőségének együttes javítása érdekében EFOP 3.4.3-16-2016-00015

compared to the performance of ARM 32 bit instruction performance. The processor implements the ARMv7 Debug architecture that includes support for TrustZone and CoreSight. The Cortex-A9 processor implements Baseline CP14, Extended CP14 debug access, and memory mapped access to the debug registers. See [ARMb] for more detailed in formations.

## 2.3.2 Memory interfaces

The Xilinx Zynq SOC and 7 series FPGAs with a "Memory Interface Solution" core with its memory controller and physical layer core (PHY) optimize interfacing for user designs using the AMBA standard Advanced eXtensible Interface (AXI4) slave interfaces to DDR3 and DDR2 SDRAM devices and other. Using the Memory Interface Generator (MIG) IP one can easily interface external memories. One can setup the clock ratio, the power supply voltage for the respective FPGA IO banks, setup the memory type, memory part, data width and etc. Also the IP can create a custom memory controller part.

### 2.3.3 Processing System Interconnect

The processing system interconnect provide an interface between the PS (Processing System) and PL (Programmable Logic). The interconnect features are as follows: Enable/Disable I/O Peripherals (IOP), Enable/Disable AXI I/O ports, MIO Configuration, Extended Multiple Use I/Os (EMIO), Accelerator coherency port (ACP), Transaction checker (ATC), Interconnect logic for Vivado Design Suite IP – PS interface, PL Clocks and Interrupts, PS internal clocking, Generate PS configuration register.

## 2.3.4 Memory Map

The Cortex-A9 processor uses 32-bit addressing. PS peripherals and PL AXI slave interfaces are memory mapped to the Cortex-A9 processor cores. All AXI slave PL peripherals will be located between the addresses:

- 4000\_000 and 7FFF\_FFFF connected to AXI GP0 interface and
- 8000\_0000 and BFFF\_FFFF connected to AXI GP1 interface.

Note that the Zynq 7000 have different memory resources. First the primary memory is the On-chip memory (OCM), which is the RAM and Boot ROM. Second resource of memory is the off chip memory, which is connected via the MIG controller (DDRx dynamic memory controller), which supports LPDDR2, DDR2, DDR3. Third resource is the Flash/static memory controller, which supports SRAM, QSPI, NAND/NOR FLASH.

## 2.3.5 PS Boots first

After Power-on-Reset (POR) the PS clock is enabled. Then, the PS begins executing the BootROM code in the on-chip ROM to boot the system. The POR resets the entire device with no previous state saved.









"FŐNIX ME" – Megújuló Egyetem felsőoktatási intézményi fejlesztések a felsőfokú oktatás minőségének és hozzáférhetőségének együttes javítása érdekében EFOP 3.4.3-16-2016-00015

The BootRom is the first software run in the application processor unit. The BootROM executes on CPU 0 and CPU 1 executes the wait-for-event (WFE) instruction. The boot device can also hold a bitstream to configure the PL and an embedded operating system, but these are not accessed by the BootROM code. The bitstream and the operating system are stored in the flash memory (external memory). In master boot mode the system boots from the flash device, while in JTAG boot mode, the BootROM code does minimal system configuration and enables a JTAG interface. After the BootROM executes, the First Stage Boot Loader (FSBL)/User code takes control of the PS and is able to further configure the device, including the PL. For further details and reading please see Xilinx User Guide UG821 and [Xil21].

## 2.3.6 Clock resources

The external clock source for the PS drives the PS clock subsystem, which are derived from one of three programmable PLLs: CPU, DDR and I/O. Each of these PLLs is loosely associated with the clocks in the CPU, DDR and peripheral subsystems (see figure 2.3). The PLLs generates the corresponding clock for the SPU, DDR and peripherals, also contains four clock generators for the PL. The clock generation paths include glitch-free multiplexers and glitch-free clock gates to support dynamic clock control. The 6 bit programmable dividers helps to generate the corresponding clock frequency together with the Clock Ratio Generator.

## 2.4 Summary

This chapter gave a summary about the Zynq processing system. It was presented the ARM processor in general and was summarized the AMBA bus standard and ARM Cortex A9 processor. There were presented the memory interface MIG, the processing system interconnect, memory map and the PS boot sequences.











Figure 2.3: PS Clock subsystem block diagram









# **Chapter 3**

# VHDL hardware description language

## **3.1** Introduction to Hardware Description Language

Embedded system design is the process that begins with setting the requirements for the system and goes through several steps to the physical implementation of the system. With the development of integrated circuit technology, can be implemented extremely complex embedded systems. Dealing with complex designs has resulted in different trends in design methods:

- Behavioral method: It specifies the system in terms of its expected behavior. It is the closest to a natural language description of the circuit functionality, but also the most difficult to synthesize.
- Structural design style: The system is specified in terms of lower level components (in this case logic gates), functional blocks connected with internal signals. The translation of such a specification into a physical circuit is straightforward.
- Data-flow method: This design style is similar to logical equations, although in general is not limited to logical values only. The specification is comprised of expressions made up of input signals and assigned to outputs. In most cases such an approach can be quite easily translated into structure and the implemented.

In the design process, simulations are complementary activities of the synthesis (see figure 3.1). In the case of application specific integrated circuits (ASIC) or embedded systems design; for example, simulations eliminate design errors and thus significantly reduce manufacturing costs (ex. production of integrated circuit masks or printed board circuit – PCB or Field Programmable Gate Array – FPGA – design). Extensive simulations can result in 82% of bug elimination and 9 hours saved by finding each defect, also increase productivity. shows the correspondence between design steps and simulation steps during the development process. The first step is to define the the system requirements. These requirements specify operating speed, delay times, connection points (interfaces), dissipated power, and other physical parameters.













Figure 3.1: Design flow of digital systems

Based on the requirements mentioned above, the system is designed during the functional design and the functional requirements can be checked with the simulation used at this level. This design can be refined at the register transfer level. At this level, the tasks are taken over by registers, memories, arithmetic units, state machines. Logical design implements the elements defined at the register transfer level. The verification, debug simulation also models the design errors expected during production and the design errors induced by environmental influences. Finally, the physical implementation creates the digital circuit, which can even be a ready-to-manufacture integrated circuit or system.

## 3.2 Hardware Abstraction Levels

At each level of the design hierarchy, we describe the system design using circuit elements. Complex digital systems are described in different ways. However, these description methods are compatible with each other . Circuits are generally described in three domains: a behavioral domain, structural domain and a physical domain. These description methods are expressed in the Y diagram represented in figure 3.2.













Figure 3.2: Y chart [GD99] p. 358

Gajski has developed the Y chart in VLSI (Very Large Scale Integrated Circuits) and Kuhn in the year 1983 to categorize the behavior of hardware designs based on the three different domains [[GK83]]. The three different domains are behavioral, structural and physical/geometry domain, which are on radial axis. Each of the corresponding domains can be further divided into levels of abstraction using concentric rings and each of the domains falling within the circle forms a group and keep going on in a top down fashion towards the center of the core.

#### 3.3 Textual description of digital systems

Technology development and growing complexity of integrated circuits resulted in that conventional schematic design methods has become increasingly opaque and difficult-to-manage the design. Circuit technology has made it possible to manufacture so-called programmable logic circuits (as mentioned









"FŐNIX ME" – Megújuló Egyetem felsőoktatási intézményi fejlesztések a felsőfokú oktatás minőségének és hozzáférhetőségének együttes javítása érdekében EFOP 3.4.3-16-2016-00015

before). However, designing with programmable logic devices required a design tool that allows the user easily describe the objective functionality of the design. First, this description method was elaborated in the description of the fuse map file resulting from the circuit technology. The fuse map defined the connections inside the circuit, similar to the net list used in schematic designs. This method was cumbersome and complex, so it became necessary to develop a general hardware modeling language capable of uniformly describing digital circuits at different levels of abstraction to design a variety of usable electronic systems using programmable circuits from different manufacturers and implemented with different technologies. The technology evolution resulted in different text based hardware description languages such as: PALASM, ABEL, VHDL, VERILOG, System C, etc. In our days the most known hardware languages are VHDL, System Verilog and C or C++ based hardware description languages (such as SystemC, Catalpult C and others). In the following are presented shortly the most known hardware description languages and the VHDL is presented in detail.

## 3.3.1 VHDL hardware description language

What means the double acronym VHDL? The meaning of the VHDL is: VHSIC-HDL – (Very High Speed Integrated Circuits Hardware Description Language). Originally the VHDL was developed by the USA DoD (DoD – Department of Defense). The development result was a hardware description language, which highly satisfied all expectation of system design requirements. The VHDL is a self-documenting, structured and understandable language. The source code in the meantime is also a kind of specification document. The most important part of HDL (hardware description language) is the parallelism and the concurrent process handling. In addition, HDL can handle complex and compact sequential circuit models. The standardization of VHDL was made in 1987 by the IEEE (Institute of Electrical and Electronics Engineers). The first official standard of VHDL was elaborated in 1993. The VHDL extension to analog and mixed signal systems modeling opened a new chapter in the electronic system design and modeling. VHDL-AMS (analogue mixed signal) is an extension of the VHDL. The extension is valid for systems model simulation, because the analog circuit synthesis is a very complex and many parameter problem, which is not solved yet.

## 3.3.2 Verilog hardware description language

The designers of Verilog HDL (Gateway Design Automation – 1984) intention was to create a C like hardware description language, since the C programming language is already spread in the micro processing development applications. Verilog is sensible to lowercase and uppercase letters. Similar to ANSI C/C++ has pre-processing, flow control instructions (if/else, for, while, case, etc.) and is compatible to precedence operators. Syntactical differences are in the variable typed declarations, process module separation and others. A design written in Verilog program has multiple hierarchical modules. The modules contain the design hierarchy. The connection between the modules give the ports (input, output, inout) A module can contain internal signal declarations (such as wire, reg, integer, etc.), sequential blocks, modules Verilog is a simultaneous and synchronous data-flow processing language.









"FŐNIX ME" – Megújuló Egyetem felsőoktatási intézményi fejlesztések a felsőfokú oktatás minőségének és hozzáférhetőségének együttes javítása érdekében EFOP 3.4.3-16-2016-00015

### 3.3.3 SystemC hardware description language

"SystemC is a set of C++ classes and macros which provide an event-driven simulation interface (see also discrete event simulation). These facilities enable a designer to simulate concurrent processes, each described using plain C++ syntax. SystemC processes can communicate in a simulated real-time environment, using signals of all the data types offered by C++, some additional ones offered by the SystemC library, as well as user defined. In certain respects, SystemC deliberately mimics the hardware description languages VHDL and Verilog, but is more aptly described as a system-level modeling language." (Wikipedia) SystemC<sup>®</sup> is an extension of the ANSI C++ class library for hardware design. The purpose of SystemC to give a C++ based design service for hybrid systems, where both hardware and software elements can be found.

The language is described by the IEEE 1666-2005 standard. During a SystemC application one can use the possibility of C++, but with the constraints that are in the standard definitions.

## 3.4 VHDL basics

Let us analyze the structural and behavioral system description in more detail. A digital system is basically used to process signals. Signals can take binary values (0 or 1, X, Z, etc.). The elements of a digital system are components such as logic gates, flip-flops, counters, processors, and so on. The connections between the components are made by wires. The input signals are also converted by the components (by the logical functions) into output signals, but there are bidirectional or input-output signals also. A VHDL program from the point of view of its structure consists of design units. A feasible (synthetitsable) VHDL program should contain two design units: one *entity* and one *architecture* unit. The *entity* is the interface to the block of hardware, while the *architecture* defines the system internal structure or the system behavior. An *entity* may have several alternative *architecture* (see figure 3.3).



Figure 3.3: VHDL model











Figure 3.4: Domino code display

The structure of a VHDL program can best be illustrated through an example. Let us consider the example of the so cold "domino code display" (see figure 3.4). The output of the domino code will be 9 LEDs organized as seen in figure 3.4. In the classical digital systems first one should write the truth table, then using Boolean algebra and Karnaugh maps, then minimize the logical equations and finally implement the circuit. The result of the Boolean minimization is given by:

$$D1 = D9 = D + C + B; D2 = D8 = D + C * B; D3 = D7 = D + C; D4 = D6 = D; D5 = A;$$
 (3.1)

where the "+" is the logical **OR** and the "\*" symbolize the logical **AND** function, **D**, **C**, **B**, **A** are the input signals (variables) and **D9**, **D8**, **D7**, **D6**, **D5**, **D4**, **D3**, **D2**, **D1** are the output functions. See figure 3.4). The "domino coder" solution given in VHDL code is shown in figure 3.5.

Let us explain the domino VHDL code implementation presented above, and introduce the basic elements of a VHDL program (such as entity, architecture).









#### "FŐNIX ME" – Megújuló Egyetem felsőoktatási intézményi fejlesztések a felsőfokú oktatás minőségének és hozzáférhetőségének együttes javítása érdekében EFOP 3.4.3-16-2016-00015

| 19 🔆                                          |                         |                                                         |
|-----------------------------------------------|-------------------------|---------------------------------------------------------|
| 20                                            |                         |                                                         |
| 21                                            |                         |                                                         |
| 22 library IEEE;                              |                         | open library IEEE                                       |
| 23 use IEEE.STD LOGIC 1164.ALL;               |                         | open standard logic package                             |
| 24                                            |                         |                                                         |
| 25⊜ entity domino is                          |                         | entity name: domono;                                    |
| 26 🖯                                          |                         | entity begins here;                                     |
| 27 🤤 generic (nr point domino: in             | teger := 10 );          | <ul> <li>generic is not used in this example</li> </ul> |
| 28 Port ( D : in STD LOGIC:                   | •                       | input port definition D                                 |
| <pre>29 C : in STD LOGIC;</pre>               |                         | input C                                                 |
| 30 B : in STD LOGIC;                          |                         | input B                                                 |
| 31 A : in STD LOGIC;                          |                         | input A                                                 |
| 32 domino : out STD LOGI                      | C VECTOR (9 downto 1)); | output port                                             |
| 33                                            | -                       | output port definition is vector of 9 bits              |
| 34⊖ end entity domino;                        |                         | end entity domino                                       |
| 35                                            |                         | ,                                                       |
| 36 🖯 architecture Behavioral of domin         | o is                    | architecture description begins here                    |
| 37                                            |                         |                                                         |
| 38 begin                                      |                         |                                                         |
| 39                                            | description of outp     | ut functions                                            |
| <pre>40 domino(1) &lt;= D OR C OR B;</pre>    | DOMINO led 1            |                                                         |
| <pre>41 domino(2) &lt;= D OR (C AND B);</pre> | DOMINO led 2            |                                                         |
| <pre>42 domino(3) &lt;= D OR C;</pre>         | DOMINO led 3            |                                                         |
|                                               | DOMINO led 4            |                                                         |
|                                               | DOMINO led 5            |                                                         |
| <pre>45 domino(6) &lt;= D;</pre>              | DOMINO led 6            |                                                         |
| <pre>46 domino(7) &lt;= D OR C;</pre>         | DOMINO led 7            |                                                         |
| <pre>47 domino(8) &lt;= D OR (C AND B);</pre> | DOMINO led 8            |                                                         |
| 48 domino(9) <= D OR C OR B;                  | DOMINO led 9            |                                                         |
| 49                                            |                         |                                                         |
| 50                                            |                         |                                                         |
| 51 end Behavioral;                            | end architecture de     | scription                                               |
| ro -                                          |                         |                                                         |

Figure 3.5: Domino coder implemented in VHDL

## 3.4.1 Entity as the interface model

The *entity* defines the design name and the way that the described VHDL element how is connected to other elements, the circuit unit's basic parameters, input and output pins. That is, with what static parameters (constants) and dynamic channels (signals) happens the information exchange between the *entity* and its environment. The *entity* allows defining any parameters that are passed into the model using hierarchy. The basic template for an entity is shown in figure 3.6.

Signals defined with the *port* section can be used to connect entities together. In the domino example 3.5 the entity contains four input signals (D, C, B, A) and a 9 bit bus output (D[9:0]). The schematic symbol is much more expressive (see figure 3.7). The textbf*port* declaration defines the type of connection, direction, and dimension. A textbf*port* direction can be *in* (only read), *out* (only write) and *inout* (read and write). Port type is *bit (std\_logic)* or *bit\_vector (std\_logic\_vector)*. The type bit\_vector defines buses. If the model has parameters, then this are defined by using the keyword *generic*. Generic declaration is similar to that of constant. A *generic* definition should contain type (integer, time) and initial value defined after the symbol":=""."

## 3.4.2 Architecture as model functionality, behavior, structure

There is no *architecture* without an interface. Its importance is so great that *architecture* is specified in VHDL as the architecture of entity (see domino implementation above figure 3.5). The general structure of the architecture is shown in 3.8. The first line of the architecture links the implementation to the









"FŐNIX ME" – Megújuló Egyetem felsőoktatási intézményi fejlesztések a felsőfokú oktatás minőségének és hozzáférhetőségének együttes javítása érdekében EFOP 3.4.3-16-2016-00015



Figure 3.6: Entity template



Figure 3.7: The domino coder schematic created from VHDL code

entity defined above (architecture Behavioral of domino is).

VHDL architecture can have a variety of structures to achieve different type of functionality (from simple combinatorial to complex sequential or structural description). Declarative items can be internal signals seen only in the architecture, or other components described by other VHDL models.









```
1
2
3 architecture <arch_name> of <entity_name> is
4 -- declarative_items (signal declarations, component declarations, etc.)
5 begin
6 -- architecture body
7 end <arch_name>;
8
```

### Figure 3.8: Architecture structure

### 3.4.3 Constants and Signals

When a value needs to be static throughout a simulation, the type of element to use is a **constant**. A **constant** is used to initialize parameters, registers, or other. **Signal**s are the "wires" inside the architecture connects processes or design elements (components) together. **Signal**s have no direction they are read-and-write type. **Constant**s and **signal**s are declared in the architecture before the **begin** statement.

### 3.4.4 Packages, Libraries

Design units are the building blocks of the VHDL program. When compiling a VHDL program, the processing program distinguishes five separate program units. Each unit is analyzed separately. The five separate units are:

- entity,
- architecture,
- package definition,
- package body,
- configuration.

The entity and the architecture were presented previously. The *package definition* describes the elements implemented and usable in the package, while the *package description* includes equations describing the implementation of functions, components, VHDL program codes, and so on. One characteristic of VHDL is that multiple architectures can be assigned to an entity. The *configuration* specifies which architecture is assigned to the design entity under the conditions we defined. The VHDL *library* stores the design units that contain the most commonly used components and functions. To achieve rapid synthesis, the IEEE created various standardized VHDL *packages*, which were defined in standards 1164, 1076.3. (The actual standard is IEEE 1076-2008). Standard libraries are opened with the *library* keyword, while the library package you want to use is specified with the *use* keyword.

Opening a library and assign packages within a VHDL program is necessary because one can use in the given VHDL program different data types defined in the packages. For example: standard logic (std\_logic), standard bus system (std\_logic\_vector), which is part of the std\_logic\_1164 package.







> library IEEE; use IEEE.STD\_LOGIC\_1164.ALL; use IEEE.numeric\_std.all; use IEEE.std\_logic\_unsigned.all;

-- open library IEEE -- open standard logic package -- commonly used packages

Figure 3.9: Open IEEE Library and use packages

## 3.4.5 VHDL grammar and lexical elements

Lexical elements are the syntax units that form the basis of the VHDL language. These include comments, identifiers, reserved words, numbers, characters, and strings. The *comment* is text after two minus signs ("--"). The comment is ignored when processing the program. The comments are mainly used to document the program. A well commented program documenting itself. *Identifier* is the name of a VHDL object. The following rules apply to identifiers:

- only Latin letters are allowed;
- decimal numbers and underscore can be used to name the identifier;
- the first character of the identifier is always a letter;
- the last character cannot be an underscore ("\_")

The last character cannot be an underscore ("\_") Correct examples for identifiers: A10, next\_state, NextFunction, etc. VHDL is not case sensitive; the following identifier names all refer to the same object: identifier, IdENTIFIER. Therefore, the correct programming mode is to always refer to an object in the same way. Best practice for identifier names is to use expressive names as possible, but the use of reserved words is forbidden!

**Numbers, characters and strings:** In VHDL, the type of numbers can be integer, floating point, real. In the representation of numbers, the decimal number system (i.e. 23), the double precision system (i.e. 23 => 2 #10111#) or the hexadecimal system e.g. (23 => 16#17#) is used. For example, the number 123456 is the same as the number 123\_456, just as the binary number 2#10100101101# is the same as the number 2#1010\_0101\_1010#.

*Character* types are denoted by apostrophes, such as 'V', 'H', 'D', 'L'. Note that the 23 and '23' are different, the first is a number and the second is a character type. Character strings or strings are enclosed in double quotation marks, such as "VHDL". Note that the number 2 # 0101\_1010 # and the character lines "0101\_1010" also differ in terms of notation and content, what's more, the following two character lines are not the same: "0101\_1010", "01011010".

### 3.4.6 VHDL Objects

An object is a data type which contains a given value. Four object types are known:

signal









- variable
- constant
- file

The file type is not discussed in this chapter because it is not a synthesizable element.

A *Signal* must be defined at the beginning of the architecture (after "architecture", before "begin"). The signals are only visible in the architecture which defined them. The *signal* definition is as follows: signal <name> : <type> := <value>;

signal a signal name: std logic := '0';

The value of the signal is assigned by the following operator: <= Example:

a\_signal\_name <= d\_in0 and din1;

*Variable*s in the traditional sense play the same role like variables in programming languages. The use of variables is only allowed in *processes*. The variable can also be thought of as a "local symbolic storage element" to describe the abstract behavior of the system. The variable is defined as follows:

variable <name>: <type> := <value>; - variable declaration

The value of a variable is assigned by the following operator :=; Example:

variable name\_of\_var: std\_logic\_vector(2 downto 0) := "00"; - variable with init value "00"
name\_of\_var := in1 and in2;

**Note:** Because the compiler does not assign any timing values to a variable, means that assigning a value to the variable has an immediate effect on it.

*Constant* The value of the constant cannot be changed in the VHDL code. The constant is defined as follows:

```
constant <name>: <type> := <value>;
constant bus_dimension: integer := 32;
```

## 3.4.7 Data types and operations

In the VHDL language, we assign to each variable a data type (i.e. object or signal). The data type defines a set of values that variables can take and a set of operations that can be performed with the variables. Because in VHDL the values that can be assigned to signals and the operations that can be performed on them are strongly type-dependent, type conversion should be applied if other data type is assigned to a a given object.

### Standard VHDL data types

From the synthesis point of view, the most common data types are as follows:

• integer in VHDL the integer type has a 32 bit representation and can get values in the  $[-2^{31}, 2^{31} - 1]$ . VHDL defines two sub types such as normal type ( $N^*$ ) and positive (N) type;

29

• Boole type with true, false values;









- **bit** type with '0', '1' values;
- **bit\_vector** type defined as a multi bit signal.

In the case of real digital design, a signal can be assigned with many signal levels not only with twostate signal levels, as a signal can be in a high-impedance state or even can have a signal level conflict in the case of wired logic. Therefore, in the VHDL, the STD\_LOGIC and STD\_LOGIC\_VECTOR types were introduced in the IEEE std\_logic\_1164 package to solve this problem. This data types allows a more flexible signal handling.

### STD\_LOGIC, STD\_LOGIC\_VECTOR data types

The most commonly used two data types are contained in the *STD\_LOGIC\_1164* package. The *std\_logic* type is a sub type of the unsigned *std\_ulogic* contained in the *STD\_ULOGIC\_1164* package. For use of any data type, first the library and then the package must be opened: library IEEE;

### use IEEE.STD\_LOGIC\_1164.ALL;

The std\_logic data type can have nine possible values: {'U', 'X', '0', '1', 'Z', 'W', 'L', 'H', '-'}. These values are explained as follows:

- '0' and '1' denote the values "definite logic 0" and "definite logic 1", respectively, which are taken by a signal driven by standard circuit;
- The high impedance value 'Z' can be taken by the signal if the drive circuit is a tri-state buffer;
- 'L' and 'H' 'weak logic 0' and 'weak logic 1' can be set to a signal for wired logic circuits when the driver circuit provides a weak drive current;
- 'X' and 'W' "indeterminate logic state" or "weak indeterminate logic state" value taken when the driver signal value cannot be interpreted as a logic 0 or a logic 1. This state occurs when two output drivers control the signal to a logic state of conflicting values (logic 0 and 1). This is happen especially in circuit simulation conditions indicate faulty circuit operation, especially in circuit simulation. • 'U' - Status used in simulation. Indicates that a value has not yet been assigned to the signal or variable. • '-' indicates that the signal is redundant.

## 3.5 Behavioral system description in VHDL

### 3.5.1 Combinational Signal Assignments

There is a strong relationship between the signal assignments and VHLD, as result there can be achieved very effective implementations. In the VHDL standard there are three type of simultaneous/parallel signal assignments (see example in 3.10):

• Simple signal assignment, which correspond to the Boolean algebraic equations;









- Conditional signal assignment;
- Selected signal assignment.

Digital circuits are combinational and sequential type. Combinational circuits do not have internal storage elements (memory) and internal intermediate states. The output function of the combinational system has always the same value for a given variation of the input signals. In reality, short transients may appear due to the gate delay of the circuits. However, when the input variables are steady state, the output always take the same value. From the point of view of implementation (with programmable logic circuits) the combinational circuit is without memory or internal storage (latch or flip-flop) or without feedback.

- simple signal assignment with Boolean functions:

The signal assignment ""<=" means that the input signal value is assigned immediately to the output (see figure 3.10).

- Conditional signal assignment

The outputs get the input values based on the *when ... else* condition (see figure 3.10).

- Selected signal assignment

This type of signal assignment is similar to the truth table. The selector usually is a *std\_logic\_vector*, when the value what gets the selector is true then the given values is assigned to the output signal. The closing operator *when others* assign an output values for all other input signal variations, which are not enumerated (see figure 3.10).

### 3.5.2 Sequential signal assignments

The outputs of sequential circuits are a function of the state of the input variables and the actual value of the internal variables (state register output values). The description of sequential system can be done by concurrent assignments, but this is not the common method. The **process** is the sequential description mode used for description of sequential systems, state machines, etc. The process is the mechanism by which sequential statements can be executed in the correct sequence, and with more then on process, concurrently. A process consist of a sensitivity list, declarations and statements. The process is executed simultaneously with the parallel assignments, however, the program lines in the process take place sequentially after a signal from the sensitivity list activate the process (change of signal). In the process execution an important role plays the signal identities, conditional signal assignments ("if then else", "case"), and cycles. It is important to clarify the difference between sequential signal assignment and a sequential logic circuit. The first one describes the process internal state while the last one is the digital circuit with internal states. Note that a process can implement not only sequential circuit but also combinational one.

The signals from the sensitivity list (see figure 3.11; "all\_input\_signals,separated\_by\_commas, "clk" and "rst") activate the process. If at least one signal change its state the process is executed.









"FŐNIX ME" – Megújuló Egyetem felsőoktatási intézményi fejlesztések a felsőfokú oktatás minőségének és hozzáférhetőségének együttes javítása érdekében EFOP 3.4.3-16-2016-00015

> 34⊜॑ entity sig\_assign is 35 Port ( a : in STD\_LOGIC; 36 b : in STD\_LOGIC; 37 c : in STD LOGIC; 38 d : in STD LOGIC; 39 s : in STD\_LOGIC\_VECTOR (3 downto 0); 40 f0 : out **STD\_LOGIC**; 41 f1 : out STD\_LOGIC; f2 : out STD\_LOGIC\_VECTOR(6 downto 0)); 42 44 ⊖ architecture Behavioral of sig\_assign is 45 signal for input data bus definition signal d\_in: std\_logic\_vector (3 downto 0); 46 begin 47 48 🖯 -- data bus from input signals -- d in <= d & c & b & a; 49 50 🖨 -- simple signal asignament with Boolean functions: f0 <= a and (b or c) and d; -- simple assignment with "<=" 51 52 © 53 <u></u> conditional signal assignment 54 f1 <= a when s = "0000" else -- if s = 0 then f1 <= a else b when s = "0001" else 55 -- if s = 1 then f1 <= b else c when s = "0010" else -- if s = 2 then f1 <= c else 56 57 d : -- if s = any other value then f1 <= d 58 O 59 -- selected signal assignment 60 🖻 the example is a seven segment decoder example 61 with s SELect f2 <= "1111001" when "0001", 62 "0100100" when "0010", 63 - -2 "0110000" 64 when "0011", - -3 "0011001" 65 when "0100" - -4 "0010010" when "0101" 66 - - 5 "0000010" "0110" 67 when - - 6 "1111000" when "**0111**" 68 - - 7 "0000000" 69 when "1000" - -8 "0010000" 70 when "1001" - -9 71 "0001000" when "1010" - - A "0000011" when "1011" 72 - - h 73 "1000110" when "1100" - - C "0100001" when "1101" 74 - - d "0000110" when "1110", 75 - - F "0001110" when "1111", 76 - - F "1000000" when others; 77 - - 0 78 🖨 end Behavioral; 79

Figure 3.10: Combinational Signal Assignment Methods

#### Variables

Definition of internal *variables*, used by the process, which are local signals, objects can be seen only inside the process. As the process is activated the sequential signal assignments are executed one-by-one and the process transits to the next internal state. A process as part of a digital systems can be in active or suspended state. Inside the process, signal assignment is done line by line execution of the process body. Signal use inside the the process is done taking into account three important aspects:









#### "FŐNIX ME" – Megújuló Egyetem felsőoktatási intézményi fejlesztések a felsőfokú oktatás minőségének és hozzáférhetőségének együttes javítása érdekében EFOP 3.4.3-16-2016-00015

```
34⊖ entity example_proc is
35
         generic (dim: integer := 16);
         Port ( all_input_signals: in STD_LOGIC_VECTOR (dim-1 downto 0);
36
37
                separated_by_commas: in STD_LOGIC;
38
                clk : in STD_LOGIC;
                                      -- clock
39
                rst : in STD_LOGIC); -- reset
40 \stackrel{.}{\ominus} end example_proc;
41
42  ⇔ architecture Behavioral of example proc is
43
44
    begin
45
          - combinational process example
46 process (all_input_signals, separated_by_commas)
47 begin
48
            <statements>;
49 \doteq end process;
50
         -- sequential process with negative edge clocked
51
         -- and synrconous High reset
52 process (clk)
53 begin
54 ė
        if (clk'event and clk = '0') then
55
        -- if there was a change in the clock signal and its value = 0
        -- this define the negative edge
56
           if rst = '1' then
57 ė
58
               -- if reset is 1 then execute the reset statments
59
               -- <statements>;
60
           else
61
              -- otherwise
62
              -- <statements>:
63 ė
           end if;
64 🖨
        end if;
66
        -- sequential process with positive edge clocked
67
        -- and synrconous Low reset
68 process (clk)
69 begin
70 👳
       if (clk'event and clk = '1') then
71 <del>\</del>
           if rst = '0' then
              -- <statements>;
72
73
           else
74
                 <statements>;
75 🖻
           end if;
76 <u></u>
       end if;
77 🗄 end process;
78 end Behavioral;
```

#### Figure 3.11: Example of different process types

- signal definition in process is forbidden;
- signals take the new value assigned in the process became valid at the process termination. Signals preserve their previous values until the process termination;
- in the case of multiple assignments for the same signal the last value is preserved at process termination.









| 34⊖ entity var example is                |                                      |
|------------------------------------------|--------------------------------------|
| 35 Port (a : in STD LOGIC; in            | put signals a, b, c                  |
| 36 b : in STD_LOGIC;                     |                                      |
| 37 c : in STD_LOGIC;                     |                                      |
| <pre>38 f_out : out STD_LOGIC);</pre>    | output function f_out                |
| 39⊜ end var_example;                     | · –                                  |
| 40                                       |                                      |
| 41 architecture Behavioral of var_exa    | mple is                              |
| 42                                       |                                      |
| 43 begin                                 |                                      |
| 44 🗇 process (A, B, C)                   |                                      |
| 45 variable declarations var1,           | var2, var3                           |
| 46 variable var1, var2, var3: <b>std</b> | _logic;                              |
| 47 begin                                 |                                      |
| 48 var1 := c;<br>49 var2 := var1 and a;  | var1 = c see schetic figure          |
| 49 var2 := var1 and a;                   | on schematic f_out2_i                |
| 50 var3 := var2 nand b;                  |                                      |
|                                          | ; on schematic f_out1_i and f_out0_i |
| 52 ⇔ end process;                        |                                      |
| 53 🖕 end Behavioral;                     |                                      |





Figure 3.13: Schematic resulted from variable assignment example

Since signals preserve the last value assigned to them, for this reason they are not used to store temporal values. On the other hand value assignment is made at process end or when the process is suspended. To solve this problem the term of *variable* is introduced. *Variables* are defined inside a process can store temporal value, and they take the values assigned to them immediately after assignment. Variable value assignment is made with ":=" operator. The following example demonstrate variable usage (figure 3.12).

Figure 3.13 represents the schematic obtained by the example given in figure 3.12. The blue wires represents the variables. Var1 assignment is useless in this form, since the and gate four3\_i input is directly connected to signal c.

#### 3.5.3 **Conditional Decisions in processes**

The following decisions can be used only in the process body: IF\_THEN\_ELSE, CASE, for IF\_THEN\_ELSE general structure is represented in figure 3.14. All the possible variants of the IF\_THEN\_ELSE decisions are given in the example (figure 3.15). The figure illustrate by examples the decision possibilities from the basic syntax to the most complete syntax of the conditional assignment.











#### Figure 3.14: IF\_THEN\_ELSE structure

```
41 begin
42 🖯
         process(a, b, c, d)
43
         begin
44
          -- simple IF THEN decision exmple
45 Ö
         if (a=b) then
46
              f1 <= a;
47 🖨
         end if;
48
         -- IF THEN ELSE example
49 <del>©</del>
         if (a=b) then
50
              f2 <= a;
51
              -- statments;
52
         else
53
              f2 <= b;
54
              -- more statments;
55 🖨
         end if;
         -- multiple if condition using genreal form example
56
57 O
        if a=b then
58
              f3 <= a;
59

    statments;

        elsif (a>b) then
60
61
             f3 <= b;
62
              -- more elsif conditions and statments;
63
        else
64
              f3 <= c;
65

    other statments eventualy;

66 <u></u>
        end if;
67 👜
        end process;
68 end Behavioral;
```

#### Figure 3.15: IF\_THEN\_ELSE examples

#### CASE

As demonstrated above with the if statement is simple to define multiple conditions but for complex









"FŐNIX ME" – Megújuló Egyetem felsőoktatási intézményi fejlesztések a felsőfokú oktatás minőségének és hozzáférhetőségének együttes javítása érdekében EFOP 3.4.3-16-2016-00015

branching the solution is the case structure without having to use Boolean conditions in every case. This structure is useful for state machine description or any other special state transitions. An example of the **CASE** structure is presented in figure 3.16, where four possible choices are presented. **Note** that for a complete description **CASE** structure the termination "**others** should be included (as shonw in figure 3.16)! Figure 3.17 is a case example where the selector line sel is a two bits vector and

```
1
 2
      case (<2-bit select>) is
 З
          when "00" =>
 4
             <statement>;
          when "01" =>
 5
 6
             <statement>:
 7
          when "10" =>
             <statement>:
 8
          when "11" =>
 9
             <statement>:
10
          when others =>
11
             <statement>;
12
13
      end case:
14
15
```

Figure 3.16: CASE structure

depending on sel value the output f1 is assigned with the values of input signals a, b, c and d respectively.

# 3.6 Structural description in VHDL

Structural description for a digital system means describing what components the system consists of and how these components are connected to each other. The structural description allows the application of multi-level (hierarchical) design in the VHDL program using the *component*. Components can be used in the subsystems of a system (in other words in the main VHDL program) that implement even simpler functions. At the lowest level, the VHDL program describes the component in terms of its behavior. The components are connected with signals in the VHDL program. As represented in figure 3.18 the









Figure 3.17: CASE structure example

system is built from components, which are connected with signals (arrows at both end), while the input and output ports represented by unidirectional arrows. In order to connect a component first should be declared (figure 3.19) then instantiated (figure 3.20). A *component* needs two VHDL elements for the structural description. First the *component* is described in as a stand-alone entity - a VHDL program - that has a stand-alone entity and architecture. Secondly the *component* should be declared then instantiated. *Component* declaration makes the connection to the original VHDL module with the definition of its entity (generics and ports) while *Component* instantiating defines the relationship of the *component* ports and other signal from the architecture where the component was invoked. Steps to insert the part:

- 1. Component behavior design in VHDL;
- 2. Component declaration in the structural VHDL design;
- 3. Component instantiating.

### Structural description example

On the following we will present the structural design style by designing a three bit shift register. The example starts from the the lowest level presenting a D type flip-flop design, followed by D type component declaration in the shift register VHDL program. Since the VHDL program is well commented the figures are self self-explanatory. First the rising edge controlled D flip-flop is presented (figure 3.21)











Figure 3.18: Structural system













```
1
 2
 3
   :<instance name> : <component_name>
 4
   generic map (
 5
      <generic_name> => <value>,
 6
      <other generics>...
   :)
 7
 8
   port map (
 9
      <port_name> => <signal_name>,
10
      <other ports>...
11 ;);
12
13 ¦
```

Figure 3.20: Component instantiating

then the hierarchical design of the shift register (figure 3.22) and finally the Schematic obtained from the VHDL code is presented.











Figure 3.21: D flip-flop VHDL example









| <pre>23: use IEEE.STD_LOGIC_1164.ALL;<br/>240 entity shift_reg_ex is<br/>25: Port ( d_in : in STD_LOGIC; serial data input<br/>26: clk : in STD_LOGIC; clock rising edge is controlling the shift regiszter<br/>27: rst : in STD_LOGIC; reset when rst='1' then the outpust are q_out = '0'<br/>28: q_out : out STD_LOGIC_VECTOR (2 downto 0)); register output<br/>290 end shift_reg_ex;<br/>300 architecture Behavioral of shift_reg_ex is<br/>31: component declaration of D flip-flop<br/>220 component fdd<br/>33: port ( d : in STD_LOGIC; D flip-flop input<br/>34: rst : in STD_LOGIC; RESET when rst='1' then q='0'<br/>35: clk : in STD_LOGIC; CLK control clock<br/>36: q : out STD_LOGIC; O flip-flop outptu on rising edge clock<br/>370 end component;<br/>38: signal fqd : STD_LOGIC_VECTOR (2 downto 0);<br/>39 begin<br/>40: component instantiating bit 0, bit 1 ,bit2:<br/>410 fd0: fdd<br/>42: port map ( d =&gt; d_in,<br/>43: clk =&gt; clk,<br/>44: rst =&gt; rst,<br/>45: q =&gt; fqd(0) );<br/>46: fd1 : fdd<br/>47: port map ( d =&gt; fqd(0),<br/>48: clk =&gt; clk,<br/>49: rst =&gt; rst,</pre>                                                                |
|---------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| <pre>25 Port ( d_in : in STD_LOGIC; serial data input<br/>26</pre>                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                          |
| <pre>26</pre>                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                               |
| <pre>27</pre>                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                               |
| 28       q_out: out STD_LOGIC_VECTOR (2 downto 0)); register output         296       end shift_reg_ex;         306       architecture Behavioral of shift_reg ex is         31       component declaration of D flip-flop         320       component declaration of D flip-flop         320       component declaration of D flip-flop         321       component declaration of D flip-flop         322       component declaration of D flip-flop         325       component fdd         33       port (d : in STD_LOGIC; D flip-flop input         34       rst : in STD_LOGIC; RESET when rst='1' then q='0'         35       clk : in STD_LOGIC; Q flip-flop outptu on rising edge clock         36       q : out STD_LOGIC); Q flip-flop outptu on rising edge clock         37       end component;         38       signal fqd : STD_LOGIC_VECTOR (2 downto 0);         39       begin         40       component instantiating bit 0, bit 1 ,bit2:         410       fd0: fdd         42       port map (d => d_in,         43       clk => clk,         44       rst => rst,         45       q => fqd(0);         46       fd1 : fdd         47       port map (d => fqd(0); |
| <pre>29 end shift_reg_ex;</pre>                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                             |
| <pre>30 © architecture Behavioral of shift_reg_ex is<br/>31 component declaration of D flip-flop<br/>32 © component fdd<br/>33</pre>                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                        |
| <pre>31 component declaration of D flip-flop<br/>320 component fdd<br/>33     port ( d : in STD_LOGIC; D flip-flop input<br/>34         rst : in STD_LOGIC; RESET when rst='1' then q='0'<br/>35</pre>                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                      |
| <pre>320 component fdd<br/>33     port ( d : in STD_LOGIC; D flip-flop input<br/>34</pre>                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                   |
| <pre>33 port ( d : in STD_LOGIC; D flip-flop input<br/>34 rst: in STD_LOGIC; RESET when rst='1' then q='0'<br/>35 clk : in STD_LOGIC; CLK control clock<br/>36 q : out STD_LOGIC); O flip-flop outptu on rising edge clock<br/>37¢ end component;<br/>38 signal fqd : STD_LOGIC_VECTOR (2 downto 0);<br/>39 begin<br/>40 component instantiating bit 0, bit 1 ,bit2:<br/>41¢ fd0: fdd<br/>42 port map ( d =&gt; d_in,<br/>43 clk =&gt; clk,<br/>44 rst =&gt; rst,<br/>45¢ q =&gt; fqd(0) );<br/>46♀ fd1 : fdd<br/>47 port map ( d =&gt; fqd(0),<br/>48 clk =&gt; clk,<br/>49 rst =&gt; rst,</pre>                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                           |
| 34rst : in STD_LOGIC;<br>clk : in STD_LOGIC;<br>q : out STD_LOGIC;<br>signal fqd : STD_LOGIC;<br>r = 0 flip-flop outptu on rising edge clock36q : out STD_LOGIC;<br>q : out STD_LOGIC;<br>signal fqd : STD_LOGIC_VECTOR (2 downto 0);<br>3939begin<br>4040 component instantiating bit 0, bit 1 ,bit2:<br>410410fd0: fdd<br>4242port map (d => d_in,<br>clk => clk,<br>4443clk => clk,<br>q => fqd(0) );<br>46046fd1 : fdd<br>rst => rst,<br>q => rst,                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                      |
| <pre>35</pre>                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                               |
| <pre>36  q : out STD_LOGIC); Q flip-flop outptu on rising edge clock<br/>37¢ end component;<br/>38 signal fqd : STD_LOGIC_VECTOR (2 downto 0);<br/>39 begin<br/>40 component instantiating bit 0, bit 1 ,bit2:<br/>41℃ fd0: fdd<br/>42 port map ( d =&gt; d_in,<br/>43 clk =&gt; clk,<br/>44 rst =&gt; rst,<br/>45 q =&gt; fqd(0) );<br/>46 fd1 : fdd<br/>47 port map ( d =&gt; fqd(0),<br/>48 clk =&gt; clk,<br/>49 rst =&gt; rst,</pre>                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                   |
| 37 $\ominus$ end component;<br>38 signal fqd : <b>STD_LOGIC_VECTOR</b> (2 downto 0);<br>39 begin<br>40 component instantiating bit 0, bit 1 ,bit2:<br>41 $\ominus$ fd0: fdd<br>42 port map ( d => d_in,<br>43 clk => clk,<br>44 rst => rst,<br>45 $\ominus$ q => fqd(0) );<br>46 $\ominus$ fd1 : fdd<br>47 port map ( d => fqd(0),<br>48 clk => clk,<br>49 rst => rst,                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                      |
| 38       signal fqd : STD_LOGIC_VECTOR (2 downto θ);         39       begin         40       component instantiating bit 0, bit 1 ,bit2:         410       fd0: fdd         42       port map ( d => d_in,         43       clk => clk,         44       rst => rst,         450       q => fqd(0);         460       fdl : fdd         47       port map ( d => fqd(0),         48       clk => clk,         49       rst => rst,                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                          |
| <pre>39 begin<br/>40 component instantiating bit 0, bit 1 ,bit2:<br/>410 fd0: fdd<br/>42 port map ( d =&gt; d_in,<br/>43 clk =&gt; clk,<br/>44 rst =&gt; rst,<br/>450 q =&gt; fqd(0) );<br/>460 fd1 : fdd<br/>47 port map ( d =&gt; fqd(0),<br/>48 clk =&gt; clk,<br/>49 rst =&gt; rst,</pre>                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                               |
| 40 component instantiating bit 0, bit 1, bit2:<br>41 $\ominus$ fd0: fdd<br>42 port map ( d => d_in,<br>43 clk => clk,<br>44 rst => rst,<br>45 $\ominus$ q => fqd(0));<br>46 $\ominus$ fdl: fdd<br>47 port map ( d => fqd(0),<br>48 clk => clk,<br>49 rst => rst,                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                            |
| $ \begin{array}{llllllllllllllllllllllllllllllllllll$                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                       |
| $ \begin{array}{llllllllllllllllllllllllllllllllllll$                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                       |
| $\begin{array}{cccc} 43 & & clk \Rightarrow clk, \\ 44 & & rst \Rightarrow rst, \\ 45 \ominus & q & \Rightarrow fqd(0) \ ); \\ 46 \ominus & fdl : fdd \\ 47 & port map (d => fqd(0), \\ 48 & & clk \Rightarrow clk, \\ 49 & & rst \Rightarrow rst, \end{array}$                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                             |
| $\begin{array}{cccc} 44 & & rst \Rightarrow rst, \\ 45 \ominus & & q \Rightarrow fqd(0) \ ); \\ 46 \ominus & fdl: fdd \\ 47 & port map ( d \Rightarrow fqd(0), \\ 48 & & clk \Rightarrow clk, \\ 49 & & rst \Rightarrow rst, \end{array}$                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                   |
| $\begin{array}{rcl} 45 & q & \Rightarrow fqd(0) \); \\ 46 & fdl : fdd \\ 47 & port map ( d \Rightarrow fqd(0), \\ 48 & clk \Rightarrow clk, \\ 49 & rst \Rightarrow rst, \end{array}$                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                       |
| 46 © fd1 : fdd<br>47 port map ( d => fqd(0),<br>48 clk => clk,<br>49 rst => rst,                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                            |
| 47 port map ( d => fqd(0),<br>48 clk => clk,<br>49 rst => rst,                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                              |
| $\begin{array}{ccc} 48 & clk \Rightarrow clk, \\ 49 & rst \Rightarrow rst, \end{array}$                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                     |
| 49 rst => rst,                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                              |
|                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                             |
| $F \cap A$ $\rightarrow f = d(1)$                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                           |
| 50                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                          |
| 52 port map ( $d \Rightarrow fqd(1)$ ,                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                      |
| $\begin{array}{ccc} 52 & \text{port map ( } \mathbf{u} \implies r(\mathbf{u}(1), \\ 53 & \text{clk} \implies clk, \end{array}$                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                              |
| $55$ $C(k \Rightarrow C(k))$<br>$54$ $rst \Rightarrow rst,$                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                 |
|                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                             |
| 55                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                          |
| 57 ≙ end Behavioral;                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                        |

Figure 3.22: Shift register example









# **Chapter 4**

# Hardware and software setup

hardware setup for zybo from digilent boardifels how to create a project on the vivado 2019.2 preparation of the software and hardwer,

- SSH setup
- IP cam setup
- Vivado and ZedBoard/zybo setup
- sbRIO ZedBoard setup

this • Extra components setup (DC motor, motor driver, hall effect sensor, GPS receiver)

## 4.1 Creating an SSH tunnel

Install PuTTY: https://www.chiark.greenend.org.uk/ sgtatham/putty/ latest.html

- 1. Start PuTTY as administrator.
- 2. In the Host Name. field, enter: mazsola.iit.uni-miskolc.hu











Figure 4.1

3. Open the Connection tab, in the Seconds between keepalives field, enter: 120



Figure 4.2

4. If you do not want to enter a user name every time you log in, on the Data tab, type in the Auto-login username field









"FŐNIX ME" – Megújuló Egyetem felsőoktatási intézményi fejlesztések a felsőfokú oktatás minőségének és hozzáférhetőségének együttes javítása érdekében EFOP 3.4.3-16-2016-00015



Figure 4.3

- Open the Tunnels tab, then fill in the Source port and Destination fields as follows : Source port: 3331 Destination: 192.168.201.21:3389
- 6. Press the Add button:
- 7. Go back to the Sessions tab and enter a name for the settings ( Save d Sessions field) and press Save :



Figure 4.4

44

8. Then start the session by double-clicking on its name or selecting-Load-Open. To log in, enter the us-er name (if not saved in the session) and password. Keep the window open while entering









the internal machine.

9. Press "Windows" + "I" to open settings and click on "Update & Security".

|   |  |                                                         | W              | Vindows Settings                                           |               |                                                            |                                                        |
|---|--|---------------------------------------------------------|----------------|------------------------------------------------------------|---------------|------------------------------------------------------------|--------------------------------------------------------|
|   |  |                                                         | Find a setting |                                                            | $\mathcal{P}$ |                                                            |                                                        |
| E |  |                                                         |                |                                                            |               | Network & Internet<br>W-Fs arptane mode, VPN               | Personalization<br>Endproved, lock screep, colors      |
|   |  | Accounts<br>True accounts, email, spre,<br>work, family |                | Time & Language<br>Speech, region, date                    |               | Garring<br>Game but, capitures,<br>broadcasting, Game Mode | Ease of Assess<br>Namber, magnifier, high<br>contrast. |
| C |  |                                                         | 0              | Update & Security<br>Windows Spalate, ensineery,<br>backup |               |                                                            |                                                        |

Figure 4.5

10. Select the "Windows Security" tab from the left pane and click on the "Firewall and Network Security" option.



Figure 4.6

- 11. Select the "Advanced Settings" button from the list.
- 12. A new window will open up, Click on the "Inbound Rules" option, and select "New Rule".









"FŐNIX ME" – Megújuló Egyetem felsőoktatási intézményi fejlesztések a felsőfokú oktatás minőségének és hozzáférhetőségének együttes javítása érdekében EFOP 3.4.3-16-2016-00015

| 🔗 Windows Defender Firewall with | Advanced Security                                   |                                                  |           |                  | -    |     |
|----------------------------------|-----------------------------------------------------|--------------------------------------------------|-----------|------------------|------|-----|
| File Action View Help            |                                                     |                                                  |           |                  |      |     |
| Þ 🔿 🙍 📆 🔂 📷                      |                                                     |                                                  |           |                  |      |     |
| Windows Defender Firewall witl   | Inbound Rules                                       |                                                  |           | Actions          |      |     |
| Cutbound Rules                   | Name                                                | Group                                            | Profile ^ | Inbound Rules    |      |     |
| Connection Security Rules        | 🔮 @{Microsoft.AAD.BrokerPlugin_1000.183             | @{Microsoft.AAD.BrokerPlu                        | Domai     | 🐹 New Rule       |      |     |
| Monitoring                       | @(Microsoft.Windows.CloudExperience                 | @{Microsoft.Windows.Clou                         | Domai     | Filter by Profil | le   |     |
|                                  | @{Microsoft.Windows.ShellExperienceH                | @{Microsoft.Windows.Shell                        | Domai     | Filter by State  |      |     |
|                                  | @{Microsoft.Windows.StartMenuExperie                | @{Microsoft.Windows.Start                        | Domai     | Filter by Grou   |      |     |
|                                  | @FirewallAPI.dll,-80201     @FirewallAPI.dll,-80206 | @FirewallAPI.dll,-80200<br>@FirewallAPI.dll80200 | All       |                  | ip 🦳 |     |
|                                  | AllJoyn Router (TCP-In)                             | AllJoyn Router                                   | Domai     | View             |      |     |
|                                  | Allovn Router (UDP-In)                              | AllJoyn Router                                   | Domai     | Refresh          | ΔΌΡυ | ΔL: |

Figure 4.7

13. Select "Port" and click on "Next".

| Rule Type                          |                                                                |
|------------------------------------|----------------------------------------------------------------|
| elect the type of firewall rule to | o create.                                                      |
| leps:                              |                                                                |
| Rule Type                          | What type of rule would you like to create?                    |
| Protocol and Ports                 |                                                                |
| Action                             | O Program                                                      |
| Profile                            | Pule that controls connections for a program.                  |
| Name                               | Port     Rule that controls connections for a TCP or UDP port. |
|                                    | Predefined:     @FirewalAPIdI_80200                            |
|                                    | Rule that controls connections for a Windows experience.       |
|                                    | O Custom                                                       |
|                                    | Custom rule.                                                   |
|                                    |                                                                |
|                                    |                                                                |
|                                    |                                                                |
|                                    |                                                                |
|                                    |                                                                |
|                                    |                                                                |

Figure 4.8

14. Click on "TCP" and select the "Specified Local Ports" option.



Figure 4.9

- 15. Enter in "3389" into the port number.
- 16. Click on "Next" and select "Allow the Connection".









| P Norwiebound Rule Wound Action Settly be action to be laten when a correction natches the condition specified in the tas. Settly and action be laten when a correction natches the specified conditions? Action A fail in the intervention of the product o                                   |                                  |                                                                                                                                                                                                      |           |
|---------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|----------------------------------|------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|-----------|
| Shorty the action to be taken when a convection matches the conditions goodfield in the site.           Step:           > Marting and Marting           > Antime           > Antime           > Marting           >                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                       | P New Inbound Rule Wiza          | rd                                                                                                                                                                                                   | ×         |
| Skep:         What action should be taken when a connection matches the specified conditions?                Phatcal and Phate          More the connection the are protocols of this factors?                Phatcal and Phate          The choice connection the are protocols of this factors?                Phatcal          The choice connection of a the secure                 Phatcal          The choice connection of a the secure                 Phatcal          The choice connection of a the secure                 Phatcal          The choice connection of the secure                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                 | Action                           |                                                                                                                                                                                                      |           |
|                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                           | Specify the action to be taken v | when a connection matches the conditions specified in the rule.                                                                                                                                      |           |
| A constant of Point     Admin     Admin     Admin     Thankade scorectores by any particular with Pine as well as those are not.     Or exercise of a second score of a s | Steps:                           |                                                                                                                                                                                                      |           |
| Adam     Adam    | Rule Type                        | What action should be taken when a connection matches the specified conditions?                                                                                                                      |           |
| Adm     The includes connections that are protected with Piece as well as those are not     Piece     Name     Name | Protocol and Ports               |                                                                                                                                                                                                      |           |
| Name     Name    | Action                           |                                                                                                                                                                                                      |           |
| Taine     The includes carly connections that have been authenticated by using Times. Connections were been estimated and the set of the settings in Times properties and rules in the Connection Society Rule rook.     Contention:                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                      | Profile                          |                                                                                                                                                                                                      |           |
| APUALS                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                    | Name                             | This includes only connections that have been authenticated by using Pleec. Connections<br>will be accured using the settings in Pleec properties and rules in the Connection Security<br>Rule node. |           |
|                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                           |                                  |                                                                                                                                                                                                      | <u>_S</u> |

Figure 4.10

17. Select "Next" and make sure all three options are checked.

| Profile                            |                                                                                                      |
|------------------------------------|------------------------------------------------------------------------------------------------------|
| Specify the profiles for which thi | a rule applies.                                                                                      |
| Steps:                             |                                                                                                      |
| Bule Type                          | When does this rule apply?                                                                           |
| Protocol and Ports                 |                                                                                                      |
| Action                             | Domain                                                                                               |
| Profile                            | Applies when a computer is connected to its corporate domain.                                        |
| a Name                             | Private                                                                                              |
|                                    | Applies when a computer is connected to a private network location, such as a home<br>or work place. |
|                                    | Public                                                                                               |
|                                    | Applies when a computer is connected to a public network location.                                   |
|                                    |                                                                                                      |
|                                    |                                                                                                      |

Figure 4.11

- 18. Again, click on "Next" and write a "Name" for the new rule.
- 19. Select "Next" after writing a name and click on "Finish".
- 20. Similarly, go back to the 4th step that we have listed and select "Outbound Rules" this time and repeat the whole process to create an Outbound Rule for this process as well.
- 21. After creating both an inbound and an Outbound rule, check to see if the issue persists.

## 4.1.1 Password change

- 1. Log in to mazsola.iit.uni-miskolc.hu as described before (e.g. by creating an ssh tunnel) or with a simple ssh connection.
- 2. To log in, use the username and password you received.
- 3. After logging in, issue the ppasswd command. Then enter the current password first and then the new password twice.









## 4.1.2 Login to the internal machine

#### On Linux

- 1. Install a Remote Desktop Protocol (RDP Client) program, e.g. Remmina, VirtualBox package also in-cludes one or the other.
- 2. Start and connect with RDP to localhost:3331 OR 127.0.0.1:3331

#### **On Windows**

- 1. Find the Remote Desktop program and launch it.
- 2. Connect to localhost:3331 OR 127.0.0.1:3331

#### Login to the internal machine

Windows often displays "others are logged in, continue?" message even if no one is logged on to the machine. Press TAB to switch to "Yes" and then enter.

To log in, use the username and the password provided by your instructor.

## 4.2 Installing Xilinx Vitis

This section gives the tutorial to install the Xilinx software. We recommend to use the latest Vitis software. The tutorials and the labs presented in this book were developed on Vitis 2019.2.

It is recommended for the online lab to install the Vitis 2020.2 software version in order to be compatible with the hardware server.

Vitis is the new name for the earlier *Software Development Kit (SDK)*, in addition integrates some other earlier tools such as SDAccel. Now, the whole suite is also called Vitis, which includes Vivado also. If Vitis is installed, then Vivado also gets installed. Vitis is used for the software development, while Vivado is used for hardware development. Bellow are the steps to be fallowed to install the software:

- You need a Xilinx account. If you don't, please create one.
- Xilinx unified web installer is downloadable at (login required):
- https://www.xilinx.com/support/download.html
- Download the Xilinx Unified Installer Windows/Linux Self Extracting Web Installer corresponding to your operating system.
- Run the downloaded file with system administrator privileges.
- Click *Next*, and enter your Xilinx account details. In the selection below of the installer choose 'Download and Install Now' then click *Next*.
- Select Vitis then click Next.
- Do the selection as given in the screenshot below (See 4.12).









"FŐNIX ME" – Megújuló Egyetem felsőoktatási intézményi fejlesztések a felsőfokú oktatás minőségének és hozzáférhetőségének együttes javítása érdekében EFOP 3.4.3-16-2016-00015

• Agree all the license agreements. Click Next and Select a suitable directory.



Figure 4.12: Vitis Unified Software Platform Install - Device selection screenshot

- Click *Next* once more and Install. If you are prompted to allow installation of some hardware, firewall warnings (Windows) about opening certain ports, simply click allow without changing the default options. This may also happen during the first run of certain tools after installation. When the installation has completed, click *Finish* to close the wizard.
- For the Vivado License Manager window, just cancel it, as the built-in Webpack license will suffice.

## 4.3 UART-USB driver install

#### Windows

Installing UART-USB driver may be unnecessary, as Windows 10 should be able to get the driver from the internet. If you have issues, please follow the instructions given in the "Setup Guide" of the Zedboard:









http://www.zedboard.org/sites/default/files/documentations/CY7C64225\_Setup\_Guide\_1\_3.pdf. Download the driver (need an account to download from Cypress) and run the *setup.exe* after extracting the zip file.

#### Linux

If you want to be able to access local hardware, do the following. If you are using FPGA remotely, this is not needed. Cable drivers are not installed by the installation wizard. Please install it from the script you can find at <install\_directory>/Xilinx/Vitis/2019.2/data/xicom/cable\_drivers/lin64/install\_script/install\_drivers (system administrator privileges are required).

### **Installing Digilent Board Support Files**

Zybo and Zybo Z7 are provided by Digilent. To use Zybo in the lab one need to install the board support files provided by Digilent. These files make it easy to select the correct part when creating a new project and allow for automated configuration of several complicated components used in many designs. For the Digilent board support files please refer to:

#### https://reference.digilentinc.com/vivado/installing-vivado/start

To work with **PMOD** the Digilent PMOD Library repository should be installed. To download and install this please refer to:

https://reference.digilentinc.com/learn/programmable-logic/tutorials/pmod-ips/start









# **Chapter 5**

# Embedded system Design with Zynq, hardware and software design basics

This chapter guide the student thru some basic laboratory examples, which give the necessary knowledge for further hardware-software development. In the chapter are used some of the workshop materials from Xilinx. We recommend to consult also the Xilinx documents and videos. For this open the **Docnav**, which was installed together with the software installation. These documents will familiarize you with the Xilinx Vivado Design Flow, which can be seen in figure 5.1. The Chapter is organized in three lab projects, which are as follows:

- 1. Lab 1 which is divided in two parts:
  - (a) Lab 1 Part 1 basic processing system design;
  - (b) Lab 1 Part 2 Processing system design with MIO.
- 2. Lab 2 Design with Xilinx IP library;
- 3. Lab 3 Create a user specific IP

The chapter concentrate on the Embedded Processor Design hardware and software development. We follow the methodology as it is in the workshop Xilinx material (Introduction, Objectives and Procedure). First an ARM Cortex A9 based processor system is designed and tested with the "Hello world" software application (see figure 5.1.2) The design includes a processor, external DDR and UART. Then LED blinking hardware test is demonstrated in two different ways. First using Processor system (PS) and MIO connected LED to create a software controlled project. This project allow the reader to explore the Zynq PS parametrizable resources, in the example using MIO for LED blinking project. Secondly the Programmable Logic will be used and adding to the PS system a PL interface using Xilinx IP library. In this case a general purpose port (GPIO) will be added to drive the board LEDs. The third lab use VHDL code to create a user specific peripheral, this time the board switches are connected to the AXI bus as a user created IP. The VHDL program will be integrated in the Block Design.









"FŐNIX ME" – Megújuló Egyetem felsőoktatási intézményi fejlesztések a felsőfokú oktatás minőségének és hozzáférhetőségének együttes javítása érdekében EFOP 3.4.3-16-2016-00015



Figure 5.1: Xilinx UltraFast Design Methodology - System-Level Design Flow

## 5.1 Lab 1

## 5.1.1 Lab 1 Part 1: Hello World

## Introduction

In this part of the lab we create a simple ARM Cortex A9 based processor design targeting the Zybo/Zed-Board board. Where the instructions refer to both boards, choose the board you are using. First the hardware system is created using Vivado, then using Vitis using an example application the hardware functionality is verified. **REDESSINER** 











### Figure 5.1.2: Processor design of Lab 1 [Xil18a] page 38.









#### Objectives

- Create a Vivado project for a Zynq system;
- Use IP Integrator to create a hardware system;
- Use Vitis to create a standard "Hello World" test project;
- Run the test application on the board.

#### Procedure

In the first lab the design steps will be presented in detail to provide adequate instructions. Detailed instructions are given which must be followed in order to complete the lab. To complete the project, first the hardware design must be created. The PS system is defined, external DDR and UART is connected. Lab 1 *"Hello World"* hardware design follows exactly the steps to be completed as they are written in the Xilinx Embedded workshop material Lab1 [Xil18a].



Figure 5.1.3: General Flow for Lab1 [Xil18a] page 2

#### Create a Vivado Project and test the project in Vitis

- 1. Launch Vivado and create an empty project targeting the Zybo/ZedBoard, using the VHDL language.
  - (a) Open Vivado by selecting: Start > All Programs > Xilinx Design Tools > Vivado 2020.2 > Vivado 2020.2
  - (b) Open Vivado by starting the *xilinx.sh* -v script if you are logged in the lab. Select Vivado 2020.2 from the list.
  - (c) Click **Create New Project** to start the wizard. You will see the *Create a New Vivado Project* dialog box. Click **Next**.
  - (d) Click in the field of the Project Location and type /embed/zybo/. Enter lab1 in the Project Name field. Make sure that the Create project subdirectory box is checked. Click Next. See figure 5.1.4.









"FŐNIX ME" – Megújuló Egyetem felsőoktatási intézményi fejlesztések a felsőfokú oktatás minőségének és hozzáférhetőségének együttes javítása érdekében EFOP 3.4.3-16-2016-00015

- (e) In the **Project Type** form select *RTL Project*. Make sure that *Do not specify sources this time* box is checked and click **Next**. See figure 5.1.5.
- (f) For the Default Part window choose Boards and select Zybo or Zedboard click Next.
- (g) For choosing Zybo choose Vendor digilentinc.com, while for the Zedboard choose em.avnet.com, then select the board in the window or simply type in the search box the desired board and revision. The online Zedboard is rev D. See figure 5.1.6 and 5.1.7. Then click Next and finally click Finish.

| 4                  | New Project                                                                       | Ŷ    |        |
|--------------------|-----------------------------------------------------------------------------------|------|--------|
| Project Name       | your project and specify a directory where the project data files will be stored. |      | Δ      |
|                    |                                                                                   |      |        |
| Project name:      | lab1                                                                              |      | ٢      |
| Project location:  | /home/vajo/embed/zybo                                                             |      | ⊗ …    |
| 🕑 Create projec    |                                                                                   |      |        |
| Project will be cr | reated at: /home/vajo/embed/zybo/lab1                                             |      |        |
|                    |                                                                                   |      |        |
|                    |                                                                                   |      |        |
|                    |                                                                                   |      |        |
|                    |                                                                                   |      |        |
|                    |                                                                                   |      |        |
|                    |                                                                                   |      |        |
|                    |                                                                                   |      |        |
|                    |                                                                                   |      |        |
|                    |                                                                                   |      |        |
|                    |                                                                                   |      |        |
|                    |                                                                                   |      |        |
| ?                  | < Back Next > Eini                                                                | sh [ | Cancel |

Figure 5.1.4: Project Name Entry









"FŐNIX ME" – Megújuló Egyetem felsőoktatási intézményi fejlesztések a felsőfokú oktatás minőségének és hozzáférhetőségének együttes javítása érdekében EFOP 3.4.3-16-2016-00015

| ~ | New Project 🔿 💿 🗙                                                                                                                                                                 |
|---|-----------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
|   | ct Type A start type of project to create.                                                                                                                                        |
| 0 | BTL Project<br>You will be able to add sources, create block designs in IP Integrator, generate IP, run RTL analysis, synthesis, implementation, design planning<br>and analysis. |
| ? | < gack Einish Cancel                                                                                                                                                              |

Figure 5.1.5: RTL Project selection

|                                                                     | Ne         | w Project |                 |              |            | Ŷ            |        |
|---------------------------------------------------------------------|------------|-----------|-----------------|--------------|------------|--------------|--------|
| e <b>fault Part</b><br>Ioose a default Xilinx part or board for you | r project. |           |                 |              |            |              | 1      |
| Parts   Boards                                                      |            |           |                 |              |            |              |        |
| Reset All Filters                                                   |            |           |                 |              | In         | stall/Update | Boards |
| Vendor: digilentinc.com v                                           | Name: Zybo |           |                 | ~            | Board Rev: | Latest       | ~      |
| Search: Q-                                                          | ~          |           |                 |              |            |              |        |
| Display Name                                                        |            | Preview   | Vendor          | File Version | Part       |              |        |
| Zybo                                                                |            |           | digilentinc.com | 1.0          | xc7z010c   | lg400-1      |        |
|                                                                     |            |           |                 |              |            |              |        |
|                                                                     |            |           |                 |              |            |              |        |
|                                                                     |            |           |                 |              |            |              |        |
|                                                                     |            |           |                 |              |            |              |        |
|                                                                     |            |           |                 |              |            |              |        |
|                                                                     |            |           |                 |              |            |              |        |
|                                                                     |            |           |                 |              |            |              |        |
|                                                                     |            |           |                 |              |            |              | >      |
| <                                                                   |            |           |                 |              |            |              |        |

Figure 5.1.6: Board selection window for Zybo









"FŐNIX ME" – Megújuló Egyetem felsőoktatási intézményi fejlesztések a felsőfokú oktatás minőségének és hozzáférhetőségének együttes javítása érdekében EFOP 3.4.3-16-2016-00015

| Parts   Boards Reset All Filters |         |         |         |               |              | Install/Update B | Roards |
|----------------------------------|---------|---------|---------|---------------|--------------|------------------|--------|
| Vendor: All                      | ✓ Name: | All     |         | ~             | Board        | Rev: Latest      | ×      |
|                                  |         |         |         |               |              |                  |        |
| Search: Q-                       | ×       |         |         |               |              |                  |        |
| Display Name                     |         | Preview | v Vende | or File'      | Version Parl | :                |        |
| Nexys Video                      |         |         | digile  | ntinc.com 1.1 | xc7          | a200tsbg484-1    |        |
| Sword                            |         |         | digile  | ntinc.com 1.0 | xc7          | <325tffg900-2    |        |
| Zedboard                         |         |         | digile  | ntinc.com 1.0 | хс7;         | 2020clg484-1     |        |
| Zybo Z7-10                       |         |         | digile  | ntinc.com 1.0 | xc7          | 2010clg400-1     |        |
| Zybo Z7-20                       |         |         | digile  | ntinc.com 1.0 | xc7          | 2020clg400-1     |        |

Figure 5.1.7: Board selection window for Zedboard

#### 2. Creating the System Using the IP Integrator

- (a) Use the IP Integrator to create a new Block Design, add the ZYNQ processing system block, and configure the processing system.
- (b) In the Flow Navigator, click Create Block Design under IP Integrator. See figure 5.1.8
- (c) Enter *system* for the design name and click OK. See figure 5.1.9.
- (d) IP from the catalog can be added in different ways. Click + icon in the empty block diagram workspace or Add IP icon in the block diagram side bar or press Ctrl + I, or right-click anywhere in the Diagram workspace and select Add IP. See figure 5.1.10
- (e) Once the IP Catalog is open, type "z" into the Search bar, find and double click on ZYNQ7 Processing System entry, or click on the entry and hit the Enter key to add it to the design (See 5.1.11).
- (f) Notice the message at the top of the Diagram window that *Designer Assistance Available*. Click **Run Block Automation** and select /processing\_system7\_0. See figure 5.1.12
- (g) In the *Run Block Automation* window, leave the default settings, including *Apply Board Preset* checked, and click **OK**. See figure 5.1.13. Once Block Automation has been complete, notice that ports have been automatically added for the DDR and Fixed IO, and some additional ports are now visible. The imported configuration for the Zynq related to the Zy-bo/Zedboard board has been applied which will now be modified. See figure 5.1.14









"FŐNIX ME" – Megújuló Egyetem felsőoktatási intézményi fejlesztések a felsőfokú oktatás minőségének és hozzáférhetőségének együttes javítása érdekében EFOP 3.4.3-16-2016-00015

(h) Double-click on the added block to open its Customization window. Notice now the Customization window shows selected peripherals (with tick marks). This is the default configuration for the board applied by the block automation. See figure 5.1.15



Figure 5.1.8: Create IP Integrator Block Diagram









"FŐNIX ME" – Megújuló Egyetem felsőoktatási intézményi fejlesztések a felsőfokú oktatás minőségének és hozzáférhetőségének együttes javítása érdekében EFOP 3.4.3-16-2016-00015

| DI UI | 0.1.0 | 10 2010 | 00010 |
|-------|-------|---------|-------|
|       |       |         |       |
| <br>  |       |         |       |

| Create Blo                           | ck Design                          |        |  |  |  |
|--------------------------------------|------------------------------------|--------|--|--|--|
| Please specify name of block design. |                                    |        |  |  |  |
| <u>D</u> esign name:                 | system                             | 8      |  |  |  |
| D <u>i</u> rectory:                  | ਙ <local project="" to=""></local> | [      |  |  |  |
| Specify source set:                  | 🗅 Design Sources                   | ~      |  |  |  |
| ?                                    | ок                                 | Cancel |  |  |  |

Figure 5.1.9: Create New Block Diagram

| This design is empty. Press the                                                     | + | button to add IP. |
|-------------------------------------------------------------------------------------|---|-------------------|
| $@   0   X   \Sigma   0   0   \overline{X}   0 +                                  $ | С |                   |

Figure 5.1.10: Add IP to Block Diagram possibilities









"FŐNIX ME" – Megújuló Egyetem felsőoktatási intézményi fejlesztések a felsőfokú oktatás minőségének és hozzáférhetőségének együttes javítása érdekében EFOP 3.4.3-16-2016-00015

| Search: Q-z (9 matches)                               |  |  |  |  |  |  |
|-------------------------------------------------------|--|--|--|--|--|--|
| 👎 Clocking Wizard                                     |  |  |  |  |  |  |
| 👎 ILA (Integrated Logic Analyzer)                     |  |  |  |  |  |  |
| 👎 MicroBlaze                                          |  |  |  |  |  |  |
| 👎 MicroBlaze Debug Module (MDM)                       |  |  |  |  |  |  |
| 👎 MicroBlaze MCS                                      |  |  |  |  |  |  |
| PWM_Analyzer_v1.0                                     |  |  |  |  |  |  |
| 👎 SelectIO Interface Wizard                           |  |  |  |  |  |  |
| 👎 XADC Wizard                                         |  |  |  |  |  |  |
| 👎 ZYNQ7 Processing System                             |  |  |  |  |  |  |
|                                                       |  |  |  |  |  |  |
| ENTER to select, ESC to cancel, Ctrl+Q for IP details |  |  |  |  |  |  |

Figure 5.1.11: Add IP ZYNQ7 Processing System









"FŐNIX ME" – Megújuló Egyetem felsőoktatási intézményi fejlesztések a felsőfokú oktatás minőségének és hozzáférhetőségének együttes javítása érdekében EFOP 3.4.3-16-2016-00015



### Figure 5.1.12: Run Block Automation Process



Figure 5.1.13: Selecting connections on Run Block Automation Process Settings













### 3. Configure the processing block with just UART 1 peripheral enabled.

- (a) A block diagram of the Zynq should now be open again (figure 5.1.15), showing various configurable blocks of the *Processing System*. At this stage, the designer can select or deselect various configurable blocks (highlighted in green) and change the system configuration.
- (b) Only the UART is required for this lab, so all other peripherals will be deselected.
- (c) Click on one of the peripherals (in green) in the *I/O Peripherals* block, or **select** the **MIO Configuration** tab on the left to open the configuration form. See figure 5.1.16
  - i. Expand *I/O peripherals* if necessary, and ensure all the following I/O peripherals are deselected except **UART 1** (figure 5.1.16).
  - ii. Remove ENET 0, USB 0, SD 0 (figure 5.1.17)
  - iii. Expand GPIO to deselect GPIO MIO.
  - iv. Expand Memory Interfaces to deselect Quad SPI Flash.
  - v. Expand Application Processor Unit to disable Timer 0. See figure 5.1.17
  - vi. Select the *PS-PL Configuration* tab on the left. Expand AXI Non Secure Enablement ⇒ GP Master AXI interface and select M AXI GPO interface if not all ready selected(!). (figure 5.1.18.
  - vii. Expand General  $\Rightarrow$  Enable Clock Resets and deselect the FCLK\_RESETO\_N option. (figure 5.1
  - viii. Select the **Clock Configuration** tab on the left. Expand the **PL Fabric Clocks** and select the **FCLK\_CLK0** option and click **OK**. See figure 5.1.19.









"FŐNIX ME" – Megújuló Egyetem felsőoktatási intézményi fejlesztések a felsőfokú oktatás minőségének és hozzáférhetőségének együttes javítása érdekében EFOP 3.4.3-16-2016-00015

- ix. In the block design connect FCLK\_CLKO with textbfM\_AXI\_GPO\_ACLK. Hover your mouse over the connector port until the pencil button appears then connect the two signals (Figure 5.1.20).
- x. Click on the Validate Design button and make sure that there are no errors.



Figure 5.1.15: ZYNQ 7 IP Processing System Settings









#### "FŐNIX ME" – Megújuló Egyetem felsőoktatási intézményi fejlesztések a felsőfokú oktatás minőségének és hozzáférhetőségének együttes javítása érdekében EFOP 3.4.3-16-2016-00015

|                        |                                     |                     |            |         |               |       |        |          | 1 |
|------------------------|-------------------------------------|---------------------|------------|---------|---------------|-------|--------|----------|---|
| YNQ7 Processing        | System (5.5)                        |                     |            |         |               |       |        | - P      | • |
| Documentation 🔅 Pr     | esets 📄 IP Location 🔅               | Import XPS Settings |            |         |               |       |        |          |   |
| Page Navigator         | MIO Configuratio                    | n                   |            |         |               |       | Summar | y Report |   |
| lynq Block Design      | Bank 0 I/O Voltage LVC              | MOS 3.3V 🗸          | Bank 1 1/0 | Voltage | LVCMOS 1.8V V |       |        |          |   |
| S-PL Configuration     |                                     |                     |            |         |               |       |        |          |   |
| eripheral I/O Pins     | Search: Q-                          |                     |            |         |               |       |        |          |   |
| 10 Configuration       | Peripheral                          | 10                  | Signal     | 10 Тур  | be            | Speed | Pullup | Direct   |   |
| la de Canfinunation    | USB 1                               |                     |            |         |               |       |        |          |   |
| lock Configuration     | > 🗆 SD 0                            |                     |            |         |               |       |        |          |   |
| DR Configuration       | > 🗆 SD 1                            |                     |            |         |               |       |        |          |   |
| MC Timing Calculation  | > UART 0                            |                     |            |         |               |       |        |          |   |
| me finning calculation | > 🗹 UART 1                          | MIO 48 49           | ~          |         |               |       |        |          |   |
| nterrupts              | I2C 0                               |                     |            |         |               |       |        |          |   |
|                        | 🗌 I2C 1                             |                     |            |         |               |       |        |          |   |
|                        | > 🗌 SPI 0                           |                     |            |         |               |       |        |          |   |
|                        | > 🗌 SPI 1                           |                     |            |         |               |       |        |          |   |
|                        | > 🗌 CAN 0                           |                     |            |         |               |       |        |          |   |
|                        | > 🗌 CAN 1                           |                     |            |         |               |       |        |          |   |
|                        | > GPIO                              |                     |            |         |               |       |        |          |   |
|                        | > Application Processor Unit        |                     |            |         |               |       |        |          |   |
|                        | > Programmable Logic Test and Debug |                     |            |         |               |       |        |          |   |
|                        | <                                   |                     |            | -       |               |       |        | >        |   |

Figure 5.1.16: ZYNQ 7 IP Processing System Peripheral Settings









"FŐNIX ME" – Megújuló Egyetem felsőoktatási intézményi fejlesztések a felsőfokú oktatás minőségének és hozzáférhetőségének együttes javítása érdekében EFOP 3.4.3-16-2016-00015

| Peripheral                                     | 10              |
|------------------------------------------------|-----------------|
| <ul> <li>I/O Peripherals</li> </ul>            |                 |
| >  ENET 0                                      |                 |
| > 🗌 ENET 1                                     |                 |
| USB 0                                          |                 |
| 🗌 USB 1                                        |                 |
| > 🗌 SD 0                                       |                 |
| > 🗌 SD 1                                       |                 |
| > 🗌 UART 0                                     |                 |
| > 🗹 UART 1                                     | MIO 48 49 🗸 🗸 🗸 |
| D 12C 0                                        |                 |
| 🗌 I2C 1                                        |                 |
| > 🗌 SPI 0                                      |                 |
| > 🗌 SPI 1                                      |                 |
| > 🗌 CAN 0                                      |                 |
| > 🗌 CAN 1                                      |                 |
| V GPIO                                         |                 |
|                                                |                 |
| EMIO GPIO (Width)                              |                 |
| > 🗌 ENET Reset                                 |                 |
| > 🗌 USB Reset                                  |                 |
| > 🗌 I2C Reset                                  |                 |
| <ul> <li>Application Processor Unit</li> </ul> |                 |
| 🗌 Timer 0                                      |                 |
| Timer 1                                        |                 |
| 🗌 Watchdog                                     |                 |

Figure 5.1.17: ZYNQ 7 IP configuration: deselect ENET 0, USB 0, SD 0, GPIO MIO, Timer 0









#### "FŐNIX ME" – Megújuló Egyetem felsőoktatási intézményi fejlesztések a felsőfokú oktatás minőségének és hozzáférhetőségének együttes javítása érdekében EFOP 3.4.3-16-2016-00015

| > Enable Clock Triggers                       |     |                                                     |  |  |  |  |  |
|-----------------------------------------------|-----|-----------------------------------------------------|--|--|--|--|--|
| <ul> <li>Enable Clock Resets</li> </ul>       |     |                                                     |  |  |  |  |  |
| FCLK_RESET0_N                                 |     | Enables general purpose reset signal 0 for PL logic |  |  |  |  |  |
| FCLK_RESET1_N                                 |     | Enables general purpose reset signal 1 for PL logic |  |  |  |  |  |
| FCLK_RESET2_N                                 |     | Enables general purpose reset signal 2 for PL logic |  |  |  |  |  |
| FCLK_RESET3_N                                 |     | Enables general purpose reset signal 3 for PL logic |  |  |  |  |  |
| <ul> <li>AXI Non Secure Enablement</li> </ul> | 0 ~ | Enable AXI Non Secure Transaction                   |  |  |  |  |  |
| GP Master AXI Interface                       |     |                                                     |  |  |  |  |  |
| > M AXI GP0 interface                         |     | Enables General purpose AXI master interface 0      |  |  |  |  |  |
| > M AXI GP1 interface                         |     | Enables General purpose AXI master interface 1      |  |  |  |  |  |



| Cor    | mponent                 | Clock Source | Requested Fre | Actual Freque | Range(MHz)           |  |  |  |
|--------|-------------------------|--------------|---------------|---------------|----------------------|--|--|--|
| >      | Processor/Memory Clocks |              |               |               |                      |  |  |  |
| >      | IO Peripheral Clocks    |              |               |               |                      |  |  |  |
| $\sim$ | PL Fabric Clocks        |              |               |               |                      |  |  |  |
|        | FCLK_CLK0               | IO PLL       | 100           | 10.00000      | 0.100000 : 250.00000 |  |  |  |
|        | FCLK_CLK1               | IO PLL       | 50            | 10.000000     | 0.100000 : 250.00000 |  |  |  |
|        | FCLK_CLK2               | IO PLL       | 50            | 10.000000     | 0.100000 : 250.00000 |  |  |  |
|        | FCLK_CLK3               | IO PLL       | 50            | 10.000000     | 0.100000 : 250.00000 |  |  |  |
| >      | > System Debug Clocks   |              |               |               |                      |  |  |  |
| >      | Timers                  |              |               |               |                      |  |  |  |

Figure 5.1.19: ZYNQ 7 IP deselect FCLK\_CLK0



Figure 5.1.20: Updated schematic block design

- 4. Generate IP Integrator Outputs, the top-level HDL, export the hardware to Vitis.
  - (a) Right-click on system.bd, and select Create HDL Wrapper to generate the top-level VHDL model. Leave the Let Vivado manager wrapper and auto-update option selected, and click OK The system\_wrapper.vhd file will be created and added to the project (Figure 5.1.21.
  - (b) In the sources panel, right-click again on **system.bd**, and select **Generate Output Products** and click **Generate** to generate the Implementation, Simulation and Synthesis files for the









"FŐNIX ME" – Megújuló Egyetem felsőoktatási intézményi fejlesztések a felsőfokú oktatás minőségének és hozzáférhetőségének együttes javítása érdekében EFOP 3.4.3-16-2016-00015

design. Select **Global** You can also click on **Generate Block Design** in the *Flow Navigator pane* to do the same. See figure 5.1.22

**Note**: If the synthesis option is **Global**, only wrapper files are generated during the block design generation phase, and the design will be synthesized as a whole at the synthesis stage. If the synthesis option is **Out of context per IP** or **Out of context per Block design**, the wrapper of the IP or block design will be generated and synthesized during block design generation, and the generated netlists will be combined together at the synthesis stage. See figure 5.1.23. Double-click on the file to see the content in the Auxiliary pane.

- (c) Notice that the VHDL file is already Set As the Top module in the design, indicated by the icon in front of the **system\_wrapper.vhd**.
- (d) In the main menu Select File > Export > Hardware and click Next. See figure 5.1.24.
   Note: Since we do not have any hardware in Programmable Logic (PL) there is no bitstream to generate, hence the *Include bitstream* option is not necessary at this time (figure 5.1.25). Click Next.
- (e) As in figure 5.1.26 name the XSA file to **system\_wrapper** and specify the folder name where the project is exported **Export to:** */embed/lab1*. Click **Next** and then click **Finish**.



Figure 5.1.21: System Wrapper File Created









"FŐNIX ME" – Megújuló Egyetem felsőoktatási intézményi fejlesztések a felsőfokú oktatás minőségének és hozzáférhetőségének együttes javítása érdekében EFOP 3.4.3-16-2016-00015

| Generate Outpo                    | ut Products 🗘 🖓 🔲 💥      |
|-----------------------------------|--------------------------|
| The following output products     | will be generated.       |
| Preview                           |                          |
| Q ¥ ≑                             |                          |
| ∨ 🚓 🔳 system.bd (00C per          | IP)                      |
| Synthesis                         |                          |
| Implementation                    |                          |
| Simulation Hw Handoff             |                          |
|                                   |                          |
| Synthesis Options                 |                          |
| 🔘 <u>G</u> lobal                  |                          |
| Out of context per IP             |                          |
| ○ Out of context per <u>B</u> loc | k Design                 |
| Run Settings                      |                          |
| • On <u>l</u> ocal host:          | Number of jobs: 4 🗸 🗸    |
| ○ On <u>r</u> emote hosts         | Configure <u>H</u> osts  |
| 🔵 Launch run <u>s</u> on Cluste   | r İsf 🗸                  |
| ? Apply                           | G <u>e</u> nerate Cancel |
|                                   |                          |

Figure 5.1.22: Generate Output Products









|           | Export Hardware Platform                                                                                                                              |
|-----------|-------------------------------------------------------------------------------------------------------------------------------------------------------|
|           | Export Hardware Platform<br>This wizard will guide you through the export of a hardware platform for use in the Vitis or<br>PetaLinux software tools. |
|           | To export a hardware platform, you will need to provide a name and location for the<br>exported file and specify the platform properties.             |
|           |                                                                                                                                                       |
|           |                                                                                                                                                       |
|           |                                                                                                                                                       |
|           |                                                                                                                                                       |
|           |                                                                                                                                                       |
| E XILINX. |                                                                                                                                                       |
|           | < Back Einish Cancel                                                                                                                                  |

Figure 5.1.23: Export Hardware Platform









| orm properties to inform downstream tools of the intended use of the target platform's hi                                                                                          |                             |                                                                                                                                                                                                                    |
|------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|-----------------------------|--------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
|                                                                                                                                                                                    | ardware                     | 4                                                                                                                                                                                                                  |
| latform includes a hardware specification for downstream software tools.<br>e bitstream<br>latform includes the complete hardware implementation and bitstream, in addition to the | hardware                    |                                                                                                                                                                                                                    |
|                                                                                                                                                                                    |                             |                                                                                                                                                                                                                    |
|                                                                                                                                                                                    |                             |                                                                                                                                                                                                                    |
|                                                                                                                                                                                    |                             |                                                                                                                                                                                                                    |
|                                                                                                                                                                                    | ication for software tools. | latform includes a hardware specification for downstream software tools.  e bitstream latform includes the complete hardware implementation and bitstream, in addition to the hardware ication for software tools. |

Figure 5.1.24: Export Hardware Platform

|                         | Export Hardware Platform                                                                                                                                                                                                                                                                           |
|-------------------------|----------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| VIVADO,<br>HLx Editions | Export Hardware Platform<br>This wizard will guide you through the export of a hardware platform for use in the<br>Vitis or PetaLinux software tools.<br>To export a hardware platform, you will need to provide a name and location for the<br>exported file and specify the platform properties. |
|                         | < gack Next > Einish Cancel                                                                                                                                                                                                                                                                        |

Figure 5.1.25: Export Hardware Platform Window









"FŐNIX ME" – Megújuló Egyetem felsőoktatási intézményi fejlesztések a felsőfokú oktatás minőségének és hozzáférhetőségének együttes javítása érdekében EFOP 3.4.3-16-2016-00015

|                         | Export Hardware Platform                                                             | Ŷ |       | $\times$ |
|-------------------------|--------------------------------------------------------------------------------------|---|-------|----------|
| Files<br>Enter the name | of your hardware platform file, and the directory where the XSA file will be stored. |   | I     | 4        |
| XSA file name:          | system_wrapper                                                                       |   |       | ۲        |
| <u>E</u> xport to:      | /home/vajo/embed/lab1                                                                |   | 8     | •••      |
|                         | The XSA will be written to: /home/vajo/embed/lab1/system_wrapper.xsa                 |   |       |          |
|                         |                                                                                      |   |       |          |
|                         |                                                                                      |   |       |          |
|                         |                                                                                      |   |       |          |
|                         |                                                                                      |   |       |          |
|                         |                                                                                      |   |       |          |
|                         |                                                                                      |   |       |          |
|                         |                                                                                      |   |       |          |
|                         |                                                                                      |   |       |          |
|                         |                                                                                      |   |       |          |
|                         |                                                                                      |   |       |          |
|                         |                                                                                      |   |       |          |
|                         |                                                                                      |   |       |          |
|                         | < <u>Back</u> <u>Next</u> > <u>F</u> inish                                           |   | Cance |          |

Figure 5.1.26: Export Hardware - Specify XSA file name and Export to Directory

The XSA (Xilinx Support Archive) is a container file that contains all the information needed to build a platform for a users target device. One of the files here is the Hardware Hand-off File (HWH). This HWH file is created when the output products is ran on a Block Design (BD). Only the information in the Block Design (BD) will be contained in the HWH. The HWH file is used by the software tools to abstract all the information needed to build a targeted application to a users device; such as the CPU (or CPUs), Buses, IP and the ports and pins used in the system such as interrupts.

## 5. Launch Vitis. Generate Hello World Application in Vitis

- (a) In the main menu select **Tools**  $\Rightarrow$  **Launch Vitis IDE**;
- (b) Specify the workspace; embed/workspace/lab1 and click Launch
- (c) On the Vitis welcome screen click Create Platform Project See figure 5.1.27;









- (d) In the *New Platform Project* specify the *Platform project name*: **zybo\_system** or **zed\_system** depending on which board you are using. Click **Next** as shown in 5.1.28. Click **Next**.
- (e) In the Create a new platform from hardware XSA. Click Browse (5.1.29)to specify the XSA file. Xilinx hardware designs are created with the Vivado The XSA (Xilinx Support Archive) file was created when the project was exported from Vivado to Vitis. The XSA proprietary file format is used by the Vitis software platform to support the project in Vitis. Click Next
- (f) The Vitis IDE open with the platform project created (5.1.30). In the menu select **File**  $\Rightarrow$  **New**  $\Rightarrow$  **Application Project** for creating the application "Hello World". This will open the application project creation wizard (5.1.31). Click **Next**.
- (g) The next window is the domain selection window. for this first project we create standalone\_domain. Click **Next**. See 5.1.34.
- (h) In the new Application project examples select "Hello World" and click Finish.
- (i) In the file Explorer window right click on the zed\_project. Also expand the *hello\_world\_system* => hello\_world => src and double click on the hellowolrd.c .C file to opened in the editor window. Right click on the *hello\_word\_system* and select Build project.
- (j) If you worked with Zybo connect the board to your PC and power on.
- (k) If you worked with the Zedboard start *putty.exe* and login to *"mazsola"* to open a tunnel for the hardware server, where the Zedboard is connected. Also login to the computer *"nyolcas"*.
- For Zybo/Zed open RelTerm serial terminal. Select the UART port *CypresVirtualComO* and setup to *Baud: 115200, Parity: none, Data Bits: 8, Stop Bits: 1* then connect the terminal (Figure 5.1.39).
- (m) In the Main menu select Xilinx  $\Rightarrow$  XSCT Console. Then in the console window type *connect* press *Enter*, then type *reset* and press *Enter*. In the XSCT window should be displayed something similar like in 5.1.38.
- (n) In the Explorer window right click on the application project *hello\_world\_system* select *Run* as ⇒ *Run Configurations*. Once the *Run Configurations* windows opens, twice click on *System Project Debug* to create an application debug *SystemDebugger\_hello\_world\_system* (Figure 5.1.39). Then click on *Run*
- (o) "Hello World" appears on the RealTerm Terminal, as shown in the figure (5.1.40).











Figure 5.1.27: Vitis IDE start window

|                                                              |                                      | New Platform Pr       | oject 🗘 🖓 🗆 S                                                                                                                                                                                                                                                                                                                                                   |
|--------------------------------------------------------------|--------------------------------------|-----------------------|-----------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| eate new platform p                                          | roject                               |                       |                                                                                                                                                                                                                                                                                                                                                                 |
| nter a name for your pla                                     | tform project                        |                       |                                                                                                                                                                                                                                                                                                                                                                 |
| platform. A platform w                                       |                                      | options for the kerne | n the output of Vivado [Xilinx Shell Archive (XSA)] or from an existing<br>Is, BSPs, as well as settings required for creating new applications.<br>S.                                                                                                                                                                                                          |
| Platform project name                                        | e: zybo_system                       |                       |                                                                                                                                                                                                                                                                                                                                                                 |
| Processor                                                    | Platform<br>Project<br>Domain<br>XSA | System<br>Project     | <ul> <li>A platform provides hardware information and software environment settings.</li> <li>A system project contains one or more applications that run at the same time.</li> <li>A domain provides runtime for applications, such as operating system or SP.</li> <li>A workspace can contain unlimited platforms and unlimited system projects.</li> </ul> |
|                                                              |                                      |                       | a. You can specify the OS and processor to start with. The platform                                                                                                                                                                                                                                                                                             |
| From existing plat<br>Load the platform<br>platform project. |                                      | ing platform. You can | choose any platform from the platform repository as a base for your                                                                                                                                                                                                                                                                                             |
|                                                              |                                      |                       |                                                                                                                                                                                                                                                                                                                                                                 |

Figure 5.1.28: Create New Platform Project









| lardware S | pecificati  | on                                                     |                       |                       |                             |                    |
|------------|-------------|--------------------------------------------------------|-----------------------|-----------------------|-----------------------------|--------------------|
| KSA File:  | /home/va    | ajo/xup/zybo/lab1/system_                              | wrapper.xsa           |                       |                             | ▼ Browse           |
| oftware S  | necificatio |                                                        |                       |                       |                             |                    |
|            | e details i | for the initial domain to be                           | added to the platform | n. More domains can b | e after the platform is cre | ated by double     |
|            |             | standalone                                             | Ŧ                     |                       |                             |                    |
| Processor  |             | ps7_cortexa9_0                                         | -                     |                       |                             |                    |
| oot comp   | to add n    | in with selected operating<br>ew domains or change set | tings.                |                       | naronn me protonn pro       | Jee can be mounted |
| Genera     | ate boot c  | omponents                                              |                       |                       |                             |                    |
|            |             |                                                        |                       |                       |                             |                    |
|            |             |                                                        |                       |                       |                             |                    |
|            |             |                                                        |                       |                       |                             |                    |
|            |             |                                                        |                       |                       |                             |                    |

Figure 5.1.29: Create a new platform from hardware (XSA)

| le Edit Search Xilinx Project Window                                                                                                                                                                                        | Itala                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                            |                                                                                                                                         |                                                |       |                                                        |
|-----------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|--------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|-----------------------------------------------------------------------------------------------------------------------------------------|------------------------------------------------|-------|--------------------------------------------------------|
|                                                                                                                                                                                                                             |                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                  | ¢ +                                                                                                                                     |                                                | ٩     | 🔐 Design 🐉 Debug                                       |
| Explorer 🗱 😑 😫 🐘 🔋 🗆                                                                                                                                                                                                        | ✔ zed_system 😫                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                   |                                                                                                                                         |                                                |       | Be Outline 😫 👘 🗆                                       |
| Cated system (0.4-of-date) Cate 2-ad (system (0.4-of-date) Image: State 2-ad (system (0.4-of-date)) Image: State 2-ad (system (0.4-of-date)) Assistant 12 Cate 2-ad (system (0.4-of-date)) Cate 2-ad (system (0.4-of-date)) | type filta<br>■ Et 4 3 4<br>■ Et 4 4 | Platform: zed_sys<br>Name:<br>Hardware Specification:<br>Description:<br>Samples:<br>Senerate boot comp<br>Pre-built Component<br>FSBL: | zed_system<br>system_wrapper.xsa<br>zed_system | Brows | There is no active editor<br>that provides an outline. |
|                                                                                                                                                                                                                             | Main Hardware Specification                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                      |                                                                                                                                         |                                                |       |                                                        |
|                                                                                                                                                                                                                             | Console 2 Problems Vi<br>Platform Tcl Console<br>platform reade - name {zed_s<br>platform read {/hone/vajo/em<br>platform active {zed_system}                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                    | ystem) -hw {/home/vaj<br>bed/zybo/workspace/ze                                                                                          |                                                |       | [ps7_cortexa9_0] -os {s                                |

Figure 5.1.30: Vitis IDE with the platform project created











Figure 5.1.31: New Application Project Wizard



Figure 5.1.32: Select Platform









| ✓                                                                               | New Application Proje           | ct                             | ↑ □ X      |
|---------------------------------------------------------------------------------|---------------------------------|--------------------------------|------------|
| Application Project Details<br>Specify the application project name and its sys | stem project properties         |                                |            |
| Application project name: helo_world                                            |                                 |                                |            |
| System Project-<br>Create a new system project for the applica                  | ation or select an existing one | e from the workpsace 👔         |            |
| Select a system project                                                         | System project details          |                                |            |
| + Create new                                                                    | System project name:            | helo_world_system              |            |
|                                                                                 | Target processor                |                                |            |
|                                                                                 | Select target processo          | for the Application project.   |            |
|                                                                                 | Processor                       | Associated applications        |            |
|                                                                                 | ps7_cortexa9_0                  | helo_world                     |            |
|                                                                                 |                                 |                                |            |
|                                                                                 | Show all processors in          | the hardware specification 🗌 🚯 |            |
| 0                                                                               |                                 | < Back Next > Can              | cel Finish |

Figure 5.1.33: Specify the Application Project Name









| ✓                                                                                                           | New Application Project |                                               | <b></b> |  |
|-------------------------------------------------------------------------------------------------------------|-------------------------|-----------------------------------------------|---------|--|
| Domain<br>Select a domain for your project or create a new dom                                              | ain                     |                                               |         |  |
| Select the domain that the application would link to<br>Note: New domain created by this wizard will have a |                         | e application template selected in the next s | tep     |  |
| Select a domain                                                                                             | Domain details          |                                               |         |  |
| standalone_domain                                                                                           |                         |                                               |         |  |
| +Create new                                                                                                 |                         |                                               |         |  |
|                                                                                                             |                         | standalone                                    |         |  |
|                                                                                                             |                         |                                               |         |  |
|                                                                                                             |                         |                                               |         |  |
|                                                                                                             |                         |                                               |         |  |
|                                                                                                             |                         |                                               |         |  |
|                                                                                                             |                         |                                               |         |  |
|                                                                                                             |                         |                                               |         |  |
|                                                                                                             |                         |                                               |         |  |
|                                                                                                             |                         |                                               |         |  |
|                                                                                                             |                         |                                               |         |  |
|                                                                                                             |                         |                                               |         |  |
| ?                                                                                                           |                         | < Back Next > Cance                           |         |  |

Figure 5.1.34: Select domain as standalone\_platform

| ◀                                                                                                                                                                                                                                                                                                                                                                                  | New Application | Project                         | ↑ □ ×  |
|------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|-----------------|---------------------------------|--------|
| Templates                                                                                                                                                                                                                                                                                                                                                                          |                 |                                 |        |
| Select a template to create your project.                                                                                                                                                                                                                                                                                                                                          |                 |                                 |        |
| Available Templates:                                                                                                                                                                                                                                                                                                                                                               |                 |                                 |        |
| Find:                                                                                                                                                                                                                                                                                                                                                                              |                 | Hello World                     |        |
| SW development templates     Dhrystone     Empty Application     Empty Application     Will Echo Server     Will TCP Perf Client     Will TCP Perf Server     Will UDP Perf Server     Will UDP Perf Server     Will UDP Perf Server     Memory Tests     OpenAMP echo-test     OpenAMP RPC Demo     Peripheral Tests     RSA Authentication App     Zynq DRAM tests     Zynq FSBL |                 | – Let's say 'Hello World' in C. |        |
| 0                                                                                                                                                                                                                                                                                                                                                                                  |                 | < Back Next > Can               | Finish |

Figure 5.1.35: Select "Hello World" example project









"FŐNIX ME" – Megújuló Egyetem felsőoktatási intézményi fejlesztések a felsőfokú oktatás minőségének és hozzáférhetőségének együttes javítása érdekében EFOP 3.4.3-16-2016-00015

| 强 Explorer छ                      |                     | Ē | ₹Ę\$ | 2 | 000 |  |  |
|-----------------------------------|---------------------|---|------|---|-----|--|--|
| hello_world_system [ zed_system ] |                     |   |      |   |     |  |  |
| hello_world [ standalone_domain ] |                     |   |      |   |     |  |  |
| 🕨 🗊 Incl                          | ▶ 🔊 Includes        |   |      |   |     |  |  |
| 🔻 🔁 src                           |                     |   |      |   |     |  |  |
| 🕨 尾 h                             | elloworld.c         |   |      |   |     |  |  |
| ▶ <u>h</u> p                      | h platform_config.h |   |      |   |     |  |  |
| 🕨 尾 p                             | latform.c           |   |      |   |     |  |  |
| In platform.h                     |                     |   |      |   |     |  |  |
| 🛐 lscript.ld                      |                     |   |      |   |     |  |  |
| ■ Xilinx.spec                     |                     |   |      |   |     |  |  |
| 🕨 🕨 🕨 🕨                           |                     |   |      |   |     |  |  |
| 🔀 hell                            | o_world.prj         |   |      |   |     |  |  |
| 👗 hello_v                         | vorld_system.sprj   |   |      |   |     |  |  |
| 🔻 📑 zed_syste                     | em (Out-of-date)    |   |      |   |     |  |  |
| 🕨 🕞 export                        |                     |   |      |   |     |  |  |
| 🕨 📂 hw                            |                     |   |      |   |     |  |  |
| 🕨 🔁 logs                          |                     |   |      |   |     |  |  |
| 🕨 📥 ns7 co                        | n Pevatu            |   |      |   |     |  |  |

Figure 5.1.36: Application project "hello\_world" Explorer view

| 47              |                                                               |
|-----------------|---------------------------------------------------------------|
| 48              | <pre>#include <stdio.h></stdio.h></pre>                       |
| 49              | <pre>#include "platform.h"</pre>                              |
| 50              | <pre>#include "xil printf.h"</pre>                            |
| 51              |                                                               |
| 52              |                                                               |
| 53 <del>0</del> | int main()                                                    |
|                 | {                                                             |
| 55              | <pre>init platform();</pre>                                   |
| 56              | p.ac.o.m(/)                                                   |
| 57              | <pre>print("Hello World\n\r");</pre>                          |
|                 |                                                               |
| 58              | <pre>print("Successfully ran Hello World application");</pre> |
| 59              | <pre>cleanup_platform();</pre>                                |
| 60              | return 0;                                                     |
| 61              | }                                                             |
| 62              |                                                               |

Figure 5.1.37: The "Hello World" program









| RealTerm: Serial Capture Program 2.0.0.70                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                  | – 🗆 ×             |
|--------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|-------------------|
|                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                            | \n Clear Freeze ? |
| Display       Port       Capture       Pins       Send       Echo Port       I2C-2       I2CMisc       Misc         Baud       115200       Port       6 = VCypressVirtualCom0        Open       Space       Stop Bits        Open       Space       Stop Bits        Stop Bits        Stop Bits        Software Flow Control        Receive Xon Char:            Receive Xon Char:               17               Transmit Xoft Char:              Wireock is:             C Teinet               Wireock is:             C Teinet               Wireock is:             C Teinet               Wireock is:             C Teinet               Parte              Wireock is:             C Teinet               Second S | Stature           |

Figure 5.1.38: RealTerm terminal setup

| 🖬 XSCT Console ន                           |                                                                      |
|--------------------------------------------|----------------------------------------------------------------------|
| XSCT Process                               |                                                                      |
| xsct% connect                              |                                                                      |
| tcfchan#2                                  |                                                                      |
| xsct% reset                                |                                                                      |
| 00<br>18 C 00<br>18 ] 104 00<br>07 18 [ !p | [?3;41 <sup>00</sup> <sub>18</sub> [41 <sup>00</sup> <sub>18</sub> > |
| xsct%                                      |                                                                      |
|                                            |                                                                      |
|                                            |                                                                      |
|                                            |                                                                      |
| xsct%                                      |                                                                      |











"FŐNIX ME" – Megújuló Egyetem felsőoktatási intézményi fejlesztések a felsőfokú oktatás minőségének és hozzáférhetőségének együttes javítása érdekében EFOP 3.4.3-16-2016-00015

| 📲 RealTerm: Serial Capture Program 2.0.0.70                                                                                      | -          |                                 | х                        |
|----------------------------------------------------------------------------------------------------------------------------------|------------|---------------------------------|--------------------------|
| Hello World <sup>H4</sup> a<br>Successfully ran Hello Zed/Zybo World application                                                 |            |                                 | ~                        |
| Send Numbers Send ASCII                                                                                                          | Clear      | Status                          | nnect                    |
| Send Numbers     Send ASCII     +LF     After     After     After     Literal     Strip Spaces     Literal     Dump File to Port | ]          | RXD<br>TXD<br>CTS<br>DCD<br>DSR | (3)<br>(8)<br>(1)<br>(6) |
| Char Count 124 CPS:0                                                                                                             | Port: 611! | BRE4                            | чк                       |

Figure 5.1.40: Caption

In the part 1 of the laboratory work 1 (called Lab1) we passed thru the steps, which have to be done for each embedded system project using Zynq architecture. True there were not explained the steps. Detailed information about the development process and "what to do and why to do" are explained in the Xilinx documentations (search for User Guides ug940, ug1165). For other information, tutorials and video tutorials start the DocNav (Document Navigator), installed together with the Vitis installation. Some of previously presented "Hello World" project material are based on Xilinx XUP (Xilinx University Program) and other tutorials such as ug1165 material [Xil18a].

# 5.1.2 Lab 1 Part 2: Led Blinking through MIO

## Introduction

This part of the lab consists of creating a software application to blink a LED connected to PS. The LED is connected to the multiplexed IO (MIO), wich is directly accessible by the ARM A9 processors.

## Objectives

- Create a Vivado project for a Zynq system;
- Use IP Integrator to create a hardware system;
- Enable MIO in the Zynq IP;
- Use Vitis to create a standard "Hello World" test project;
- Edit the "Hello World" program to blink the MIO LED;









"FŐNIX ME" – Megújuló Egyetem felsőoktatási intézményi fejlesztések a felsőfokú oktatás minőségének és hozzáférhetőségének együttes javítása érdekében EFOP 3.4.3-16-2016-00015

• Run the test application on the board.

#### Procedure

In the first lab the design steps will be presented in detail to provide adequate instructions. Detailed instructions are given which must be followed in order to complete the lab.

This part of the lab consists of creating a software application to blink an LED connected to PS. No special hardware is required for this part but a minimal configuration is required (invoking and parameterizing the Zynq IP). Figure 5.1.41 resumes the steps to follow.



Figure 5.1.41: General Flow for Lab1 Part2

## **Create a Vivado Project**

#### 1. Launch Vivado and create an empty project targeting the ZedBoard, using the VHDL language.

- (a) Open Vivado by selecting: Start > All Programs > Xilinx Design Tools > Vivado 2020.2 > Vivado 2020.2
- (b) Open Vivado by starting the *xilinx.sh* -v script if you are logged in the lab. Select Vivado 2020.2 from the list.
- (c) Click **Create New Project** to start the wizard. You will see the *Create a New Vivado Project* dialog box. Click **Next**.
- (d) Click in the field of the Project Location and type /embed/zed/. Enter lab1part2 in the Project Name field. Make sure that the Create project subdirectory box is checked. Click Next. See figure 5.1.42.
- (e) In the **Project Type** form select *RTL Project*. Make sure that *Do not specify sources this time* box is checked and click **Next**. See figure 5.1.43.
- (f) For the Default Part window choose Boards and select Zybo or Zedboard click Next.
- (g) For *Zedboard* choose *em.avnet.com*, then select the board in the window or simply type in the search box the desired board and revision. The online Zedboard is rev D. See figure 5.1.44. Then click **Next** and finally click **Finish**.









#### "FŐNIX ME" – Megújuló Egyetem felsőoktatási intézményi fejlesztések a felsőfokú oktatás minőségének és hozzáférhetőségének együttes javítása érdekében EFOP 3.4.3-16-2016-00015

| 🙏 New Project                       |                                                                                 |        |        |        | ×      |
|-------------------------------------|---------------------------------------------------------------------------------|--------|--------|--------|--------|
| Project Name<br>Enter a name for yo | ur project and specify a directory where the project data files will be stored. |        |        |        | A      |
| Project name:                       | lab1part2                                                                       |        |        |        |        |
| Project location:                   | C:/Users/vajo/Documents/LABs                                                    |        |        |        | ⊗      |
| Create project                      | t subdirectory                                                                  |        |        |        |        |
| Project will be cr                  | eated at: C:/Users/vajo/Documents/LABs/lab1part2                                |        |        |        |        |
|                                     |                                                                                 |        |        |        |        |
|                                     |                                                                                 |        |        |        |        |
|                                     |                                                                                 |        |        |        |        |
|                                     |                                                                                 |        |        |        |        |
|                                     |                                                                                 |        |        |        |        |
|                                     |                                                                                 |        |        |        |        |
|                                     |                                                                                 |        |        |        |        |
|                                     |                                                                                 |        |        |        |        |
|                                     |                                                                                 |        |        |        |        |
|                                     |                                                                                 |        |        |        |        |
| ?                                   |                                                                                 | < Back | Next > | Einish | Cancel |

## Figure 5.1.42: Project Name Entry

| 1 | New Project                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                        | ×    |
|---|----------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|------|
|   | Project Type<br>Specify the type of project to create.                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                             | 4    |
|   | BTL Project     You will be able to add sources, create block designs in IP Integrator, generate IP, run RTL analysis, synthesis, implementation, design planning and analysis.     D pont specify sources at this time     Project and sources, view device resources, run design analysis, planning and implementation.     D on of specify sources at this time     JO Printing Project     Do not specify sources. You will be able to view partipackage resources.     Ignories Project     Create a Vixado project from a Synplify, XST or ISE Project File.     Example Project     Create a new Vixado project from a predefined template. |      |
|   | () Ca                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                              | ncel |

Figure 5.1.43: RTL Project selection









#### "FŐNIX ME" – Megújuló Egyetem felsőoktatási intézményi fejlesztések a felsőfokú oktatás minőségének és hozzáférhetőségének együttes javítása érdekében EFOP 3.4.3-16-2016-00015



Figure 5.1.44: Board selection window for Zedboard

## 2. Creating the System Using the IP Integrator

- (a) Use the IP Integrator to create a new Block Design, add the ZYNQ processing system block, and configure the processing system.
- (b) In the Flow Navigator, click Create Block Design under IP Integrator.
- (c) Enter *system* for the design name and click **OK**. See figure 5.1.45.
- (d) IP from the catalog can be added in different ways. Click + icon in the empty block diagram workspace or Add IP icon in the block diagram side bar or press Ctrl + I, or right-click anywhere in the Diagram workspace and select Add IP. See figure 5.1.46
- (e) Once the IP Catalog is open, type "z" into the Search bar, find and double click on ZYNQ7 Processing System entry, or click on the entry and hit the Enter key to add it to the design (See 5.1.47).
- (f) Notice the message at the top of the Diagram window that *Designer Assistance Available*. Click **Run Block Automation** and select /processing\_system7\_0. See figure 5.1.48
- (g) In the *Run Block Automation* window, leave the default settings, including *Apply Board Preset* checked, and click OK. See figure 5.1.49. Once Block Automation has been complete, notice that ports have been automatically added for the DDR and Fixed IO, and some additional ports are now visible. The imported configuration for the Zynq related to the Zybo/Zedboard board has been applied which will now be modified. See figure 5.1.50









"FŐNIX ME" – Megújuló Egyetem felsőoktatási intézményi fejlesztések a felsőfokú oktatás minőségének és hozzáférhetőségének együttes javítása érdekében EFOP 3.4.3-16-2016-00015

(h) Double-click on the added block to open its Customization window. Notice now the Customization window shows selected peripherals (with tick marks). This is the default configuration for the board applied by the block automation. See figure 5.1.51

| 🝌 Create Block Design |                  | ×      |
|-----------------------|------------------|--------|
| Please specify name   | of block design. | 4      |
| Design name:          | system           |        |
| Directory:            | Section 4        | ~      |
| Specify source set:   | 🗅 Design Sources | ~      |
| ?                     | ОК               | Cancel |

Figure 5.1.45: Create New Block Diagram

This design is empty. Press the 🕂 button to add IP.



Figure 5.1.46: Add IP to Block Diagram possibilities



Figure 5.1.47: Add IP ZYNQ7 Processing System











Figure 5.1.48: Run Block Automation Process









"FŐNIX ME" – Megújuló Egyetem felsőoktatási intézményi fejlesztések a felsőfokú oktatás minőségének és hozzáférhetőségének együttes javítása érdekében EFOP 3.4.3-16-2016-00015

| À Run Block Automation                                                    | X                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                     |
|---------------------------------------------------------------------------|-----------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| Automatically make connections in your design                             | by checking the boxes of the blocks to connect. Select a block on the left to display its configuration options on the right.                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                         |
| Q X +<br>→ All Automation (1 out of 1 selected)<br>→ processing_system?_0 | Description         This option sets the board preset on the Processing System. All current properties will be overwritten by the board preset This action cannot be undone. Zynq7 block automation applies current board preset and generates external connections for FIXED_IO, Trigger and DDR interfaces.         NOTE: Apply Board Preset will discard existing IP configuration - please uncheck this box, if you wish to retain previous configuration.         Instance: /processing_system7_0         Options         Make Interface External: FIXED_IO, DDR         Apply Board Preset:         Qross Trigger In:         Disable         Cross Trigger Out |
| (?)                                                                       | OK Cancel                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                             |

Figure 5.1.49: Selecting connections on Run Block Automation Process Settings





## 3. Configure the processing block with just GPIO MIO peripheral enabled.

(a) A block diagram of the Zynq should now be open again, showing various configurable blocks









"FŐNIX ME" – Megújuló Egyetem felsőoktatási intézményi fejlesztések a felsőfokú oktatás minőségének és hozzáférhetőségének együttes javítása érdekében EFOP 3.4.3-16-2016-00015

of the *Processing System*. At this stage, the designer can select or deselect various configurable blocks (highlighted in green) and change the system configuration.

- (b) Only the GPIO MIO is required for this lab, so all other peripherals will be deselected.
- (c) Click on one of the peripherals (in green) in the *I/O Peripherals* block, or **select** the **MIO Configuration** tab on the left to open the configuration form. The procedures are resumed in Figure 5.1.51 and Figure 5.1.52
  - i. Expand *I/O peripherals* if necessary, and ensure all the following I/O peripherals are deselected except **GPIO MIO**
  - ii. Expand Memory Interfaces to deselect Quad SPI Flash.
  - iii. Expand Application Processor Unit to disable Timer 0.
  - iv. Select the *PS-PL Configuration* tab on the left. Expand AXI Non Secure Enablement
     > GP Master AXI interface and select M AXI GP0 interface if not all ready selected(!).
  - v. Expand General > Enable Clock Resets and deselect the FCLK\_RESETO\_N option.
  - vi. Select the **Clock Configuration** tab on the left. Expand the **PL Fabric Clocks** and select the **FCLK\_CLK0** option and click **OK**
  - vii. In the block design connect **FCLK\_CLK0** with textbfM\_AXI\_GP0\_ACLK. Hover your mouse over the connector port until the pencil button appears then connect the two signals
  - viii. Click on the Validate Design button and make sure that there are no errors.









| YNQ7 Processing     | <b>j System (5.5)</b><br>Presets 📄 IP Location 🌼 Import XPS Se | ettings |                                              |
|---------------------|----------------------------------------------------------------|---------|----------------------------------------------|
| Page Navigator      | PS-PL Configuration                                            |         | Summary Report                               |
| Zynq Block Design   | ← Q ≍ ≑                                                        |         |                                              |
| PS-PL Configuration | Search: Q-                                                     |         |                                              |
|                     | Name                                                           | Select  | Description                                  |
| Peripheral I/O Pins | <ul> <li>Enable Clock Triggers</li> </ul>                      |         |                                              |
| IIO Configuration   | FLCK_CLKTRIG0                                                  |         | Enables PL clock trigger signal 0 used to ha |
|                     | FLCK_CLKTRIG1                                                  |         | Enables PL clock trigger signal 1 used to ha |
| Clock Configuration | FLCK_CLKTRIG2                                                  |         | Enables PL clock trigger signal 2 used to ha |
| DR Configuration    | FLCK_CLKTRIG3                                                  |         | Enables PL clock trigger signal 3 used to ha |
| Dir Comgulation     | <ul> <li>Enable Clock Resets</li> </ul>                        |         |                                              |
| SMC Timing Calcula  | FCLK_RESET0_N                                                  |         | Enables general purpose reset signal 0 for   |
| ataraunta           | FCLK_RESET1_N                                                  |         | Enables general purpose reset signal 1 for   |
| nterrupts           | FCLK_RESET2_N                                                  |         | Enables general purpose reset signal 2 for   |
|                     | FCLK_RESET3_N                                                  |         | Enables general purpose reset signal 3 for   |
|                     | <ul> <li>AXI Non Secure Enablement</li> </ul>                  | 0 ~     | Enable AXI Non Secure Transaction            |
|                     | <ul> <li>GP Master AXI Interface</li> </ul>                    |         | _                                            |
|                     | > M AXI GP0 interface                                          |         | Enables General purpose AXI master interfa   |
|                     | > M AXI GP1 interface                                          |         | Enables General purpose AXI master interfa   |
|                     | > GP Slave AXI Interface                                       |         |                                              |
|                     | > HP Slave AXI Interface                                       |         |                                              |
|                     | > ACP Slave AXI Interface                                      |         |                                              |
|                     | > DMA Controller                                               |         |                                              |
|                     | > PS-PL Cross Trigger interface                                |         | Enables PL cross trigger signals to PS and   |
|                     | <                                                              |         | >                                            |

Figure 5.1.51: ZYNQ 7 IP Processing System Settings









| 📏 Re-customize IP      |                             | 🙏 Re-customize IP            |                                        | 🝌 Re-customize IP   |                                          |
|------------------------|-----------------------------|------------------------------|----------------------------------------|---------------------|------------------------------------------|
| ZYNQ7 Processing S     | vstem (5.5)                 | ZYNQ7 Processing             | a System (5.5)                         | Page Navigator      | Clock Configuration                      |
|                        | Jorean (0.0)                | 2 mar 1 locessing            | y by stellin (0.0)                     | Zynq Block Design   | Basic Clocking Advanced C                |
| Documentation 🔅 Pre    | esets 📄 IP Location 🔅 Impoi | Ocumentation I Documentation | Presets 📄 IP Location 🔅 Import X       | PS-PL Configuration | Input Frequency (MHz) 33.33333           |
| Page Navigator –       | Peripheral I/O Pins         | Page Navigator               | MIO Configuration                      | Peripheral I/O Pins | ← Q ± ≑ ч                                |
| Zynq Block Design      | ← Q <u>∓</u> ≑ 0            | Zynq Block Design            | Bank 0 I/O Voltage LVCMOS 3.3V         | MIO Configuration   | Search: Q-                               |
| PS-PL Configuration    | Search: Q-                  | PS-PL Configuration          | ← Q ≍ ≑ +⊈ 0                           | Clock Configuration | Component<br>V Processor/Memory Clocks   |
| Peripheral I/O Pins    |                             | Peripheral I/O Pins          | Search: Q.                             | DDR Configuration   | CPU                                      |
|                        | Peripherals                 |                              | _                                      |                     | DDR                                      |
| MIO Configuration      | >  Ethernet 1               | MIO Configuration            | Peripheral                             | SMC Timing Calcula  | <ul> <li>IO Peripheral Clocks</li> </ul> |
| Clock Configuration    | USB 0                       | Clock Configuration          | D 12C 1                                | Interrupts          | SMC                                      |
|                        |                             |                              |                                        |                     | QSPI                                     |
| DDR Configuration      |                             | DDR Configuration            | > _ SPI 1                              |                     | ENET0                                    |
| SMC Timing Calculation | > 🗌 SD 0                    | SMC Timing Calcula           |                                        |                     | ENET1                                    |
|                        | > 🗌 SD 1                    |                              | > CAN 1                                |                     | SDIO                                     |
| Interrupts             | > SPI 0                     | Interrupts                   | V GPIO                                 |                     | SPI                                      |
|                        | > SPI 1                     |                              | > GPIO MIO                             |                     | ✓ CAN                                    |
|                        |                             |                              | EMIO GPIO (Width)                      |                     | CAN CLK                                  |
|                        |                             |                              | > ENET Reset                           |                     | CAN0 MIOCLK                              |
|                        | > UART 1                    |                              | > USB Reset                            |                     | CAN1 MIOCLK                              |
|                        | I2C 0                       |                              | > I2C Reset                            |                     | PL Fabric Clocks                         |
|                        | 12C 1                       |                              | Application Processor Unit     Timer 0 |                     | FCLK_CLK0                                |
|                        | > CAN 0                     |                              | Timer 1                                |                     |                                          |
|                        | > CAN 1                     |                              | Watchdog                               |                     |                                          |
|                        |                             |                              | Programmable Logic Test and E          |                     |                                          |
|                        |                             |                              |                                        |                     |                                          |
|                        |                             |                              | d[0:1]                                 |                     |                                          |
|                        | SWDT                        |                              | d[2:3]                                 |                     |                                          |
|                        | PJTAG                       |                              | d[4:7]                                 |                     |                                          |
|                        |                             |                              | d[8:15]                                |                     |                                          |
|                        | > C GPIO MIO                |                              | d[16:31]                               |                     |                                          |
|                        |                             |                              | D PJTAG                                |                     |                                          |
|                        |                             |                              | <                                      |                     |                                          |

Figure 5.1.52: ZYNQ 7 IP Processing System Peripheral, MIO and Clock Settings



Figure 5.1.53: Updated schematic block design

- 4. Generate IP Integrator Outputs, the top-level HDL, export the hardware to Vitis and start Vitis.
  - (a) Right-click on **system.bd**, and select **Create HDL Wrapper** to generate the top-level VHDL model. Leave the *Let Vivado manager wrapper and auto-update* option selected, and click









"FŐNIX ME" – Megújuló Egyetem felsőoktatási intézményi fejlesztések a felsőfokú oktatás minőségének és hozzáférhetőségének együttes javítása érdekében EFOP 3.4.3-16-2016-00015

**OK** The system\_wrapper.vhd file will be created and added to the project (Figure 5.1.54.

(b) In the sources panel, right-click again on system.bd, and select Generate Output Products and click Generate to generate the Implementation, Simulation and Synthesis files for the design. Select Global You can also click on Generate Block Design in the Flow Navigator pane to do the same.

Note: If the synthesis option is Global, only wrapper files are generated during the block design generation phase, and the design will be synthesized as a whole at the synthesis stage. If the synthesis option is **Out of context per IP** or **Out of context per Block design**, the wrapper of the IP or block design will be generated and synthesized during block design generation, and the generated netlists will be combined together at the synthesis stage. Double-click on the file to see the content in the Auxiliary pane.

- (c) Notice that the VHDL file is already Set As the Top module in the design, indicated by the icon in front of the system\_wrapper.vhd.
- (d) In the main menu Select File > Export > Hardware and click Next Note: Since we do not have any hardware in Programmable Logic (PL) there is no bitstream to generate, hence the *Include bitstream* option is not necessary at this time. Click **Next**.
- (e) Name the XSA file to **system\_wrapper** and specify the folder name where the project is created.



Figure 5.1.54: System Wrapper File Created

The XSA (Xilinx Support Archive) is a container file that contains all the information needed to build a platform for a users target device. One of the files here is the Hardware Handoff File (HWH). This HWH file is created when the output products is ran on a Block Design (BD). Only the information in the Block Design (BD) will be contained in the HWH. The HWH









"FŐNIX ME" – Megújuló Egyetem felsőoktatási intézményi fejlesztések a felsőfokú oktatás minőségének és hozzáférhetőségének együttes javítása érdekében EFOP 3.4.3-16-2016-00015

file is used by the software tools to abstract all the information needed to build a targeted application to a users device; such as the CPU (or CPUs), Buses, IP and the ports and pins used in the system such as interrupts.

- 5. Generate Hello World Application in Vitis
  - (a) In the main menu select **Tools** →Launch Vitis IDE;
  - (b) Specify the workspace and click Launch (Figure 5.1.55)
  - (c) On the Vitis welcome screen click Create Platform Project
  - (d) In the *New Platform Project* specify the *Platform project name*: zed\_system. Figure 5.1.57
  - (e) In the Create a new platform from hardware XSA. Click Browse (5.1.29)to specify the XSA file. Xilinx hardware designs are created with the Vivado The XSA (Xilinx Support Archive) file was created when the project was exported from Vivado to Vitis. The XSA proprietary file format is used by the Vitis software platform to support the project in Vitis. Click Next
  - (f) The Vitis IDE open with the platform project created (5.1.30). In the menu select File -> New -> Application Project for creating the application "Hello World". This will open the application project creation wizard (5.1.31). Click Next.
  - (g) The next window is the domain selection window. for this first project we create standalone\_domain. Click **Next**. See 5.1.34.
  - (h) In the new Application project examples select "Hello World" and click Finish.
  - (i) In the file Explorer window right click on the zed\_project. Also expand the *hello\_world\_system* -> hello\_world -> src and double click on the *hellowolrd.c*. C file to opened in the editor window. Right click on the *hello\_word\_system* and select Build project.
  - (j) If you worked with Zybo connect the board to your PC and power on.
  - (k) If you worked with the Zedboard start *putty.exe* and login to *"mazsola"* to open a tunnel for the hardware server, where the Zedboard is connected. Also login to the computer *"nyolcas"*.
  - For Zybo/Zed open RelTerm serial terminal. Select the UART port *CypresVirtualComO* and setup to *Baud: 115200, Parity: none, Data Bits: 8, Stop Bits: 1* then connect the terminal (Figure 5.1.39).
  - (m) In the Main menu select Xilinx →XSCT Console. Then in the console window type connect press Enter, then type reset and press Enter. In the XSCT window should be displayed something similar like in 5.1.38.
  - (n) In the Explorer window right click on the application project *hello\_world\_system* select *Run* as →*Run Configurations*. Once the *Run Configurations* windows opens, twice click on *System Project Debug* to create an application debug *SystemDebugger\_hello\_world\_system*(Figure 5.1.66). Then click on *Run*









"FŐNIX ME" – Megújuló Egyetem felsőoktatási intézményi fejlesztések a felsőfokú oktatás minőségének és hozzáférhetőségének együttes javítása érdekében EFOP 3.4.3-16-2016-00015

(o) "Hello World" appears on the RealTerm Terminal, as shown in the figure (5.1.67).

| 🚽 Vitis IDE La | auncher                                                                                                     | × |
|----------------|-------------------------------------------------------------------------------------------------------------|---|
|                | <b>ectory as workspace</b><br>s the workspace directory to store its preferences and development artifacts. |   |
| Workspace:     | C:\Users\vajo\Documents\LABs\Jab1part2 V Browse                                                             |   |
| Use this a     | s the default and do not ask again                                                                          |   |
| Restore of     | her Workspace                                                                                               |   |
| Recent We      | orkspaces                                                                                                   |   |
|                | Launch Cancel                                                                                               |   |

Figure 5.1.55: Lunch Vitis



Figure 5.1.56: Create New Platform Project









| ardware                   | Specificat               | ion                                                    |                       |                          |                         |                     |       |
|---------------------------|--------------------------|--------------------------------------------------------|-----------------------|--------------------------|-------------------------|---------------------|-------|
| (SA File:                 | /home/v                  | ajo/xup/zybo/lab1/system_                              | wrapper.xsa           |                          |                         | ▼ Br                | owse  |
| oftware S                 | pecificati               | on                                                     |                       |                          |                         |                     |       |
|                           | ne details<br>he platfor | for the initial domain to be<br>n.spr file             | added to the platform | n. More domains can b    | e after the platform is | s created by double | 9     |
| Operating                 | system:                  | standalone                                             | Ŧ                     |                          |                         |                     |       |
| Processor                 |                          | ps7 cortexa9 0                                         | -                     |                          |                         |                     |       |
| Not     Iate     oot comp | er to add n              | in with selected operating<br>ew domains or change set | tings.                | r will be added to the p | placom. The placom      | r project can be mi | Jamea |
|                           |                          | components                                             |                       |                          |                         |                     |       |
|                           |                          |                                                        |                       |                          |                         |                     |       |
|                           |                          |                                                        |                       |                          |                         |                     |       |
|                           |                          |                                                        |                       |                          |                         |                     |       |
|                           |                          |                                                        |                       |                          |                         |                     |       |

Figure 5.1.57: Create a new platform from hardware (XSA)

| le Edit Search Xilinx Project Window                                                                                                                                                                                        | Itala                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                            |                                                                                                                                              |                                                |                    |                                                        |
|-----------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|--------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|----------------------------------------------------------------------------------------------------------------------------------------------|------------------------------------------------|--------------------|--------------------------------------------------------|
|                                                                                                                                                                                                                             |                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                  | ¢ +                                                                                                                                          |                                                | ٩                  | 😰 Design 🐉 Debug                                       |
| Explorer 🗱 😑 😫 🔛 🔋 🙂 🗆                                                                                                                                                                                                      | ✓ zed_system 😫                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                   |                                                                                                                                              |                                                |                    | Be Outline 😫 📟 🗆                                       |
| Cated system (0.4-of-date) Cate 2-ad (system (0.4-of-date) Image: State 2-ad (system (0.4-of-date)) Image: State 2-ad (system (0.4-of-date)) Assistant 12 Cate 2-ad (system (0.4-of-date)) Cate 2-ad (system (0.4-of-date)) | type filta<br>■ Et 4 3 4<br>■ Et 4 4 | Platform: zed_sys<br>Name:<br>Hardware Specification:<br>Description:<br>Samples:<br>Senerate boot component<br>Pre-built Component<br>FSBL: | zed_system<br>system_wrapper.xsa<br>zed_system | Browg              | There is no active editor<br>that provides an outline. |
|                                                                                                                                                                                                                             | Main Hardware Specification                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                      |                                                                                                                                              |                                                |                    |                                                        |
|                                                                                                                                                                                                                             | Console 22 Problems Vi<br>Platform Tcl Console<br>platform create - name (zed_s<br>platform read {/home/vajo/em<br>platform active (zed_system)                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                  | ystem} -hw {/home/vajo<br>bed/zybo/workspace/zeo                                                                                             |                                                | apper.xsa) -proc + | [ps7_cortexa9_0) -os {s                                |

Figure 5.1.58: Vitis IDE with the platform project created











Figure 5.1.59: New Application Project Wizard



Figure 5.1.60: Select Platform









"FŐNIX ME" – Megújuló Egyetem felsőoktatási intézményi fejlesztések a felsőfokú oktatás minőségének és hozzáférhetőségének együttes javítása érdekében EFOP 3.4.3-16-2016-00015

| ✓                                                | New Application Project                               | ↑ □ X       |
|--------------------------------------------------|-------------------------------------------------------|-------------|
| Application Project Details                      |                                                       |             |
| Specify the application project name and its sys | stem project properties                               |             |
| Application project name: helo_world             |                                                       |             |
| Application project name: nelo_world             |                                                       |             |
| System Project                                   |                                                       |             |
| Create a new system project for the applica      | tion or select an existing one from the workpsace 🛛 🚯 |             |
| Select a system project                          | System project details                                |             |
| - Create new                                     | System project name: helo_world_system                |             |
|                                                  | Target processor                                      |             |
|                                                  | Select target processor for the Application project.  |             |
|                                                  | Processor Associated applications                     |             |
|                                                  | ps7_cortexa9_0 helo_world                             |             |
|                                                  |                                                       |             |
|                                                  |                                                       |             |
|                                                  |                                                       |             |
|                                                  |                                                       |             |
|                                                  |                                                       |             |
|                                                  | Show all processors in the hardware specification 🗌 👔 |             |
|                                                  |                                                       |             |
| 0                                                | < Back Next > Car                                     | ncel Finish |

Figure 5.1.61: Specify the Application Project Name









| ✓                                                              | New Application Project                                                                                                                                                                                     |                      | 4 |     |  |  |
|----------------------------------------------------------------|-------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|----------------------|---|-----|--|--|
| Domain<br>Select a domain for your project or create a new dom | ain                                                                                                                                                                                                         |                      |   | ••• |  |  |
|                                                                | Select the domain that the application would link to or create a new domain<br>Note: New domain created by this wizard will have all the requirements of the application template selected in the next step |                      |   |     |  |  |
| Select a domain                                                | Domain details                                                                                                                                                                                              |                      |   |     |  |  |
| standalone_domain                                              |                                                                                                                                                                                                             |                      |   |     |  |  |
| +Create new                                                    |                                                                                                                                                                                                             |                      |   |     |  |  |
|                                                                |                                                                                                                                                                                                             | standalone           |   |     |  |  |
|                                                                |                                                                                                                                                                                                             |                      |   |     |  |  |
|                                                                |                                                                                                                                                                                                             |                      |   |     |  |  |
|                                                                |                                                                                                                                                                                                             |                      |   |     |  |  |
|                                                                |                                                                                                                                                                                                             |                      |   |     |  |  |
|                                                                |                                                                                                                                                                                                             |                      |   |     |  |  |
|                                                                |                                                                                                                                                                                                             |                      |   |     |  |  |
|                                                                |                                                                                                                                                                                                             |                      |   |     |  |  |
|                                                                |                                                                                                                                                                                                             |                      |   |     |  |  |
|                                                                |                                                                                                                                                                                                             |                      |   |     |  |  |
|                                                                |                                                                                                                                                                                                             |                      |   |     |  |  |
| ?                                                              |                                                                                                                                                                                                             | < Back Next > Cancel |   |     |  |  |

Figure 5.1.62: Select domain as standalone\_platform

| ✓                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                         | New Application | Project                         | ↑ □ ×  |
|---------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|-----------------|---------------------------------|--------|
| Templates                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                 |                 |                                 |        |
| Select a template to create your project.                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                 |                 |                                 |        |
| Available Templates:                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                      |                 |                                 |        |
| Find:                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                     | ⊟ ⊞             | Hello World                     |        |
| SW development templates     Dhrystone     Empty Application     Empty Application (C++)     Hello World     WIP TCP Perf Client     WIP TCP Perf Client     WIP TCP Perf Client     WIP TCP Perf Client     WIP UDP Perf Client     WIP DP Perf Client     WIP DP Perf Client     WIP DP Perf Client     WIP UDP Perf Client     WIP DP Perf Client     WIP DP Perf Client     WIP DP Perf Client     WIP UDP     WIP UDP     WIP UDP     WIP UD |                 | – Let's say 'Hello World' in C. |        |
| 0                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                         |                 | < Back Next > Can               | Finish |

Figure 5.1.63: Select "Hello World" example project









"FŐNIX ME" – Megújuló Egyetem felsőoktatási intézményi fejlesztések a felsőfokú oktatás minőségének és hozzáférhetőségének együttes javítása érdekében EFOP 3.4.3-16-2016-00015

| 强 Explorer छ  |                                   | Ē | ₹Ę\$ | 2 | 000 |  |
|---------------|-----------------------------------|---|------|---|-----|--|
| 🕶 📻 hello_wor | hello_world_system [ zed_system ] |   |      |   |     |  |
| 🔻 🧿 hello_v   | world [ standalone_domain ]       |   |      |   |     |  |
| 🕨 🗊 Incl      | udes                              |   |      |   |     |  |
| 🔻 🔁 src       |                                   |   |      |   |     |  |
| 🕨 尾 h         | elloworld.c                       |   |      |   |     |  |
| 🕨 🕨 🕨         | latform_config.h                  |   |      |   |     |  |
| 🕨 尾 p         | latform.c                         |   |      |   |     |  |
| 🕨 🕨 🕨         | latform.h                         |   |      |   |     |  |
| دا 🛐          | script.ld                         |   |      |   |     |  |
| E X           | ilinx.spec                        |   |      |   |     |  |
| 🕨 🖌 🕨         |                                   |   |      |   |     |  |
| 🔀 hell        | o_world.prj                       |   |      |   |     |  |
| 👗 hello_v     | vorld_system.sprj                 |   |      |   |     |  |
| ▼             | em (Out-of-date)                  |   |      |   |     |  |
| 🕨 🕞 export    |                                   |   |      |   |     |  |
| 🕨 📂 hw        |                                   |   |      |   |     |  |
| 🕨 👝 logs      |                                   |   |      |   |     |  |
| 🕨 📥 ns7 rn    | ntevag n                          |   |      |   |     |  |

Figure 5.1.64: Application project "hello\_world" Explorer view

| 47              |                                                               |
|-----------------|---------------------------------------------------------------|
| 48              | <pre>#include <stdio.h></stdio.h></pre>                       |
| 49              | <pre>#include "platform.h"</pre>                              |
| 50              | <pre>#include "xil printf.h"</pre>                            |
| 51              |                                                               |
| 52              |                                                               |
| 53 <del>0</del> | int main()                                                    |
|                 | {                                                             |
| 55              | <pre>init platform();</pre>                                   |
| 56              | p.ac.o.m(/)                                                   |
| 57              | <pre>print("Hello World\n\r");</pre>                          |
|                 |                                                               |
| 58              | <pre>print("Successfully ran Hello World application");</pre> |
| 59              | <pre>cleanup_platform();</pre>                                |
| 60              | return 0;                                                     |
| 61              | }                                                             |
| 62              |                                                               |

Figure 5.1.65: The "Hello World" program









| RealTerm: Serial Capture Program 2.0.0.70                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                              | - 🗆 ×                 |
|------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|-----------------------|
|                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                        | \n  Clear  Freeze   ? |
| Display       Port       Capture       Pins       Send       Echo Port       I2C-2       I2CMisc       Misc         Baud       115200       Port       6 = VCypressVirtualCom0        Open       Space       Stop Bits        Open       Space       Stop Bits        Stop Bits        Stop Bits        Software Flow Control        Receive Xon Char:           Receive Xon Char:               17               Receive Xon Char:              17               Transmit Xoft Char:              Wirsock is:             C Teinet               Wirsock is:             C Teinet               Wirsock is:             C Teinet               C Misc              Wirsock is:             C Teinet               Set Teinet               Set Teinet <td>Status</td> | Status                |

Figure 5.1.66: RealTerm terminal setup

| 🖬 XSCT Console ន                           |                |
|--------------------------------------------|----------------|
| XSCT Process                               |                |
| xsct% connect                              |                |
| tcfchan#2                                  |                |
| xsct% reset                                |                |
| 00<br>18 C 00<br>18 ] 104 00<br>07 18 [ !p | ?3;4100 [4100> |
| xsct%                                      |                |
|                                            |                |
|                                            |                |
|                                            |                |
| xsct%                                      |                |

Figure 5.1.67: XSCT console connection view









"FŐNIX ME" – Megújuló Egyetem felsőoktatási intézményi fejlesztések a felsőfokú oktatás minőségének és hozzáférhetőségének együttes javítása érdekében EFOP 3.4.3-16-2016-00015

| 📲 RealTerm: Serial Capture Program 2.0.0.70                                                                                                                     | -           |                                                          | ×              |
|-----------------------------------------------------------------------------------------------------------------------------------------------------------------|-------------|----------------------------------------------------------|----------------|
| Hello World®<br>Successfully ran Hello Zed/Zybo World application                                                                                               |             |                                                          | ~              |
|                                                                                                                                                                 |             |                                                          |                |
| Display   Port   Capture   Pins   Send   Echo Port   12C   12C-2   12CMisc   Misc                                                                               | Clear       |                                                          | ?              |
| Send Numbers Send ASCII +CR → Before +CR → Atter     Send Numbers Send ASCII +CR → Atter     O ℃ LF Repeats 1 ♀ □ Literal □ Strip Spaces + FF Strip Spaces + FF | ]           | Status<br>Discor<br>RXD (3<br>TXD (3<br>CTS (8<br>DCD (1 | 2)<br>3)<br>1) |
| Dump File to Port                                                                                                                                               |             | DSR (I<br>BREAL<br>Error                                 | 6)<br>9)       |
| Char Count:124 CPS:0                                                                                                                                            | Port: 6 115 | 5200 8N1 N                                               | on //          |

Figure 5.1.68: Caption

In the part 1 of the laboratory work 1 (called Lab1) we passed thru the steps, which have to be done for each embedded system project using Zynq architecture. True there were not explained the steps. Detailed information about the development process and "what to do and why to do" are explained in the Xilinx documentations (search for User Guides ug940, ug1165). For other information, tutorials and video tutorials start the DocNav (Document Navigator), installed together with the Vitis installation. Some of previously presented "Hello World" project material are based on Xilinx XUP (Xilinx University Program) and other tutorials such as ug1165 material [Xil18a].

# 5.2 Lab 3: Create your own IP

## Introduction

In the previous **??** it was demonstrated how to use the Xilinx IP library for embedded system design. This lab consists of extending the processing system with a custom peripheral (own IP).

## Objectives

Some times the user want to design its own peripheral for this is necessary to use the "IP wizard". The AXI4Lite interface peripheral is created with the Vivado IP Packer. The reader became familiar with the IP design steps, which are demonstrated within a simple IP design. The IP read the switches from the board, and send it to the processing system. Figure 5.2.1 show the block schematic of the design.









"FŐNIX ME" – Megújuló Egyetem felsőoktatási intézményi fejlesztések a felsőfokú oktatás minőségének és hozzáférhetőségének együttes javítása érdekében EFOP 3.4.3-16-2016-00015

## Procedure

In the first step after Vivado was started the user will create its own Custom IP and export if to the IP library. Next in step 4 the Vivado project is created and the IP is imported. Finally the project is tested in Vitis. Figure 5.2.1 resumes the steps to follow.



Figure 5.2.1: General flow for Lab 3

The lab is divided in two parts. The first part creates and pack the IP and the second part of the lab create the processing system extended with the GPIO, BRAM and IP.

# 5.2.1 Create and Manage IP Project

## 1. Launch Vivado and create a Custom IP using the Create and Package IP Wizard









"FŐNIX ME" – Megújuló Egyetem felsőoktatási intézményi fejlesztések a felsőfokú oktatás minőségének és hozzáférhetőségének együttes javítása érdekében EFOP 3.4.3-16-2016-00015

- Click **Manage IP** (See figure 5.2.2) and select *New IP Location* and click **Next** in the *New IP Location* window. See for details in figure 5.2.3
- Select part **xc7z010clg400-1** Zynq device for this project, but later compatibility for other devices will be added to packaged IP.
- Select VHDL as the Target Language, Mixed as the Simulator Language and for IP location, type embed\sw\_ip and click Finish (leave other settings as defaults and click OK if prompted to create the directory) (figure 5.2.3)



Figure 5.2.2: Manage IP









#### "FŐNIX ME" – Megújuló Egyetem felsőoktatási intézményi fejlesztések a felsőfokú oktatás minőségének és hozzáférhetőségének együttes javítása érdekében EFOP 3.4.3-16-2016-00015

| 4                          | New IP Location        | + = ×                 |
|----------------------------|------------------------|-----------------------|
| Manage IP Settings         |                        |                       |
| Set options for creating a | and generating ir.     |                       |
|                            |                        |                       |
| Part:                      | @xc7z010clg400-1       | •••                   |
| Target language:           | VHDL                   | *                     |
| Target simulator:          | Vivado Simulator       | *                     |
| Simulator language:        | Mixed                  | ~                     |
| IP location:               | /home/vajo/embed/sw_ip | ⊗                     |
|                            |                        |                       |
|                            |                        |                       |
|                            |                        |                       |
|                            |                        |                       |
|                            |                        |                       |
|                            |                        |                       |
|                            |                        |                       |
|                            |                        |                       |
|                            |                        |                       |
|                            |                        |                       |
|                            |                        |                       |
|                            |                        |                       |
|                            |                        |                       |
|                            |                        |                       |
| ?                          | < Back                 | <u>F</u> inish Cancel |

Figure 5.2.3: New IP location form

## 2. Run the Create and Package IP Wizard

- (a) Select Tools => Create and Package IP
- (b) In the window, click Next
- (c) Select Create a new AXI4 peripheral, and click Next
- (d) Fill in the details for the IP: Name: sw\_ip; Display Name: sw\_ip\_v1\_0; Fill in a Description, Vendor Name and URL. Click Next. (See figure 5.2.4) Can be observed the Peripheral AXI interface details. Leave it as it is. For this lab is important that the peripheral will have 4 registers. Click Next.
- (e) Select Edit IP, overview of the peripheral generation summary (figure 5.2.6) . Click Finish









#### "FŐNIX ME" – Megújuló Egyetem felsőoktatási intézményi fejlesztések a felsőfokú oktatás minőségének és hozzáférhetőségének együttes javítása érdekében EFOP 3.4.3-16-2016-00015

| 4 | 2                                      | Create and Package New IP                                                               | ( + 🗆 × |
|---|----------------------------------------|-----------------------------------------------------------------------------------------|---------|
| F | Peripheral Deta<br>Specify name, versi | <b>ils</b><br>on and description for the new peripheral                                 | A       |
|   |                                        | sw_ip<br>1.0<br>sw_ip_v1.0<br>My new AXI IP<br>/home/vajo/embed/sw_ip/ip_repo<br>isting |         |
|   | ?                                      | < <u>B</u> ack <u>N</u> ext > <u>E</u> inish                                            | Cancel  |

Figure 5.2.4: Create new IP

- (f) In figure 5.2.4 the new IP parameters can be edited. Such as the IP name (for example you can cahnge it to S\_Axi) the interface type which now is AXI Lite but can be change to AXI Full or AXI Stream bus, which are different variants of the AXI bus as mentioned in 2. The interface should be a slave interface since the master will be the processing system. Data width is 32 bits as the PS is also 32 bits, and the number of user registers at this time is 4 (in this lab we will use only one register). Click Next.
- (g) As shown in 5.2.6 choose edit IP and Click Finish.









# "FŐNIX ME" – Megújuló Egyetem felsőoktatási intézményi fejlesztések a felsőfokú oktatás minőségének és hozzáférhetőségének együttes javítása érdekében EFOP 3.4.3-16-2016-00015

| <b>L</b>                                                | Create and Pa                | kage New IP                                                                                                                                                                   | + = 2                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                  |
|---------------------------------------------------------|------------------------------|-------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|----------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| Add Interfaces<br>Add AXI4 interfaces supported by your | peripheral                   |                                                                                                                                                                               | A                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                      |
| Enable Interrupt Support                                | + −<br>Interfaces<br>Soo_AXI | Name     S00_AXI       Interface Type     Lite       Interface Mode     Slave       Data Width (Bits)     32       Memory Size (Bytes)     64       Number of Registers     4 | <ul> <li></li> &lt;</ul> |
| (?)                                                     |                              | < <u>B</u> ack <u>N</u> ext >                                                                                                                                                 | <u>F</u> inish Cancel                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                  |

Figure 5.2.5: Add Interfaces screen









| 4            | Create and Package New IP                                        | ×□×  |
|--------------|------------------------------------------------------------------|------|
|              | Create Peripheral                                                |      |
| HLx Editions | Peripheral Generation Summary                                    |      |
|              | 1. IP (user.org:user:sw_ip:1.0) with 2 interface(s)              |      |
|              | 2. Driver(v1_00_a) and testapp more info                         |      |
|              | 3. AXI4 VIP Simulation demonstration design more info            |      |
|              | 4. AXI4 Debug Hardware Simulation demonstration design more info |      |
|              | Peripheral created will be available in the catalog :            |      |
|              | /home/vajo/embed/sw_ip/ip_repo                                   |      |
|              |                                                                  |      |
|              | Next Steps:                                                      |      |
|              | ○ Add IP to the repository                                       |      |
|              | Edit IP                                                          |      |
|              | ○ Verify Peripheral IP using AXI4 VIP                            |      |
|              | 🔿 Verify peripheral IP using JTAG interface                      |      |
|              |                                                                  |      |
| E XILINX.    | Click Finish to continue                                         |      |
|              |                                                                  |      |
| ?            | < <u>B</u> ack <u>N</u> ext > <u>Einish</u> Car                  | icel |
|              |                                                                  |      |

Figure 5.2.6: Create peripheral overview









#### "FŐNIX ME" – Megújuló Egyetem felsőoktatási intézményi fejlesztések a felsőfokú oktatás minőségének és hozzáférhetőségének együttes javítása érdekében EFOP 3.4.3-16-2016-00015

| PROJECT MANAGER - edit_sw_ip_v1_0                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                            |                                                                                                                                                                                        |                                                                                                                     |                                                                                                                                  | ? ×                                                                                                                             |
|--------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|----------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|---------------------------------------------------------------------------------------------------------------------|----------------------------------------------------------------------------------------------------------------------------------|---------------------------------------------------------------------------------------------------------------------------------|
| Sources ? _ D 🛚 🛪                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                            | Project Summary ×                                                                                                                                                                      | Package IP - sw_ip 🛛 🛛                                                                                              |                                                                                                                                  | 0 0                                                                                                                             |
| Q         X         ●         ●         ●           V © Dordgin Sources (2)         >         >         >         >         >         >         >         >         >         >         >         >         >         >         >         >         >         >         >         >         >         >         >         >         >         >         >         >         >         >         >         >         >         >         >         >         >         >         >         >         >         >         >         >         >         >         >         >         >         >         >         >         >         >         >         >         >         >         >         >         >         >         >         >         >         >         >         >         >         >         >         >         >         >         >         >         >         >         >         >         >         >         >         >         >         >         >         >         >         >         >         >         >         >         >         >         >         >         > <th>Packaging Steps       ✓     Identification       ✓     Compatibility       ✓     File Groups       ✓     Customization Par       ✓     Ports and Interfac       ✓     Addressing and M</th> <th>Identification<br/>Vendor:<br/>Library:<br/>Name:<br/>Version:<br/>Display name:<br/>Description:<br/>Vendor display name:</th> <th>user.org<br/>user<br/>sw_jp<br/>1.0<br/>sw_jp.y1.0<br/>W new X0 IP</th> <th>0<br/>0<br/>0<br/>0<br/>0</th> | Packaging Steps       ✓     Identification       ✓     Compatibility       ✓     File Groups       ✓     Customization Par       ✓     Ports and Interfac       ✓     Addressing and M | Identification<br>Vendor:<br>Library:<br>Name:<br>Version:<br>Display name:<br>Description:<br>Vendor display name: | user.org<br>user<br>sw_jp<br>1.0<br>sw_jp.y1.0<br>W new X0 IP                                                                    | 0<br>0<br>0<br>0<br>0                                                                                                           |
| Filerarchy   Ubraries Compile Order       Properties     ? _ □ □ □ ×       (m)     (m)       (m)     (m)       Select an object to see properties                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                            | Customization GUI     Review and Packa                                                                                                                                                 | Company url:<br>Root directory:<br>Xml file name:<br>Categories<br>+                                                | home/vajo/embed/ew_lp/ip_repo/sw_jp_1.0<br>/home/vajo/embed/ew_lp/ip_repo/sw_jp_1.0/component.xml                                |                                                                                                                                 |
| Tcl Console Messages Log Reports Design Runs x                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                               | < >                                                                                                                                                                                    |                                                                                                                     |                                                                                                                                  | ? _ 🗆 🛙                                                                                                                         |
| Q   素   ≑   !€   ≪   ▶   ≫   <b>+</b>   %                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                    |                                                                                                                                                                                        |                                                                                                                     |                                                                                                                                  |                                                                                                                                 |
| Name     Constral.     Status        T     Total Po       ∨ ▷     synt_l     constra_l     Not started         T     Total Po       ▷     impl_l     constra_l     Not started                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                               | . Falled Ro B                                                                                                                                                                          | U S Elap                                                                                                            | Run Strategy<br>Vivado Synthesis Defaults (Vivado Synthesis 2020)<br>Vivado Implementation Defaults (Vivado Implementation 2020) | Report Strategy<br>Vivado Synthesis Default Reports (Vivado Synthesis 2<br>Vivado implementation Default Reports (Vivado impler |

Figure 5.2.7: Edit IP general view

# 3. Create the interface to the Switches

- (a) In the sources panel, double-click the *sw\_ip\_v1\_0.vhd* file. (See 5.2.7) This file contains the VHDL code for the interface(s) selected above. The top level file contains a module which implements the AXI Lite interfacing logic, and an example design to write to and read from the number of registers specified above. This template is used as a basis for creating custom IP.
- (b) In the top level design the new input port *sw* Switch will be created. The AXI read data in the sub-module will be connected to the external *sw* port. Scroll down to line 7 where the user parameters space is provided in the *generic* part of the *entity*.
- (c) Add the parameter of the *sw\_width*, which is different for *Zybo* and *Zed* See figure 5.2.8. On the *Zybo* board there are 4 switches, while on the *Zedboard* there are 8 switches.









"FŐNIX ME" – Megújuló Egyetem felsőoktatási intézményi fejlesztések a felsőfokú oktatás minőségének és hozzáférhetőségének együttes javítása érdekében

EFOP 3.4.3-16-2016-00015



Figure 5.2.8: Declaring users port in the lower-level module for the Zybo

(d) Scroll down the VHDL code to line 54 where the sw\_ip\_v1\_0\_S00\_AXI component is declared and introduce the same generic (sw\_width) and port sw in the component declaration section. See figure 5.2.9









"FŐNIX ME" – Megújuló Egyetem felsőoktatási intézményi fejlesztések a felsőfokú oktatás minőségének és hozzáférhetőségének együttes javítása érdekében EFOP 3.4.3-16-2016-00015

| 50   |                                                        |
|------|--------------------------------------------------------|
| 51 Θ | architecture arch imp of sw ip v1 O is                 |
| 52   |                                                        |
| 53   | component declaration                                  |
| 54 🖯 | component sw_ip_v1_0_SO0_AXI is                        |
| 55   | generic (                                              |
| 56   | sw zybo = 4 zed = 8                                    |
| 57   | sw_width : <b>integer</b> := 4;                        |
| 58   | C_S_AXI_DATA_WIDTH : integer := 32;                    |
| 59   | C_S_AXI_ADDR_WIDTH : integer := 4                      |
| 60   | );                                                     |
| 61   | port (                                                 |
| 62   | sw : in <b>std_logic_vector</b> (sw_width-1 downto 0); |
| 63   | S_AXI_ACLK : in <b>std_logic;</b>                      |



(e) Scroll down the VHDL code to line 89 where the AXI BUS Interface SOO\_AXI component is instantiated. and instantiate the generic for sw\_width and connect the sw to the sw port of the sw\_ip\_v1\_0\_SOO\_AXI VDHL component (figure 5.2.10.

| 89   | Instantiation of Axi Bus Interface S00_AXI   |
|------|----------------------------------------------|
| 90 🖯 | sw_ip_v1_0_S00_AXI_inst : sw_ip_v1_0_S00_AXI |
| 91   | generic map (                                |
| 92   | sw_width => sw_width,                        |
| 93   | C_S_AXI_DATA_WIDTH => C_SOO_AXI_DATA_WIDTH,  |
| 94   | C_S_AXI_ADDR_WIDTH => C_SOO_AXI_ADDR_WIDTH   |
| 95   | )                                            |
| 96   | port map (                                   |
| 97   | sw => sw,                                    |
| 98   | S_AXI_ACLK => s00_axi_aclk,                  |

Figure 5.2.10: Completing the component instantiate part.

(f) Double click on the **sw\_ip\_v1\_0\_S00\_AXI.vhd** file to implement the IP. First add in the entity section the generic and the port as previously, such as in (figure 5.2.12) line 5-21.









"FŐNIX ME" – Megújuló Egyetem felsőoktatási intézményi fejlesztések a felsőfokú oktatás minőségének és hozzáférhetőségének együttes javítása érdekében EFOP 3.4.3-16-2016-00015

| 4 .           |                                                        |
|---------------|--------------------------------------------------------|
| 5 🖯 entii     | ty sw_ip_v1_0_SOO_AXI is                               |
| 6 0           | géneric (                                              |
| 7             | Users to add parameters here                           |
| 6 (<br>7<br>8 | sw_width : <b>integer</b> := 4;                        |
| 9 🖕           | User parameters ends                                   |
| 10            | Do not modify the parameters beyond this line          |
| 11            |                                                        |
| 12 🚊          | Width of S_AXI data bus                                |
| 13            | C_S_AXI_DATA_WIDTH : <b>integer</b> := <b>32;</b>      |
| 14            | Width of S_AXI address bus                             |
| 15            | C_S_AXI_ADDR_WIDTH : <b>integer</b> := 4               |
| 16            | ;                                                      |
|               | port (                                                 |
| 18 뒂          | Users to add ports here                                |
| 19 🗀          | sw is input                                            |
| 20            | sw : in <b>std_logic_vector</b> (sw_width-1 downto 0); |
| 21 🖯          | User ports ends                                        |
| 22            | Do not modify the ports beyond this line               |

Figure 5.2.11: Edit entity sw\_ip\_v1\_0\_S00\_AXI generic and port declaration

(g) One can analyze the IP template for write and read process. At the file end can be edited the *user logic part* of the IP. But since in this lab we only read the switches this can be done in the slave register read section of the IP as in figure 5.2.12 line 357, where the switches are read directly in the *reg\_data\_out(sw\_width-1 downto 0)*, which are the lower bits of the AXI read data register.



Figure 5.2.12: Peripheral read data from Switches process

(h) Click Run Synthesis and Save if prompted. (This is to check the design synthesizes correctly









"FŐNIX ME" – Megújuló Egyetem felsőoktatási intézményi fejlesztések a felsőfokú oktatás minőségének és hozzáférhetőségének együttes javítása érdekében EFOP 3.4.3-16-2016-00015

> before packaging the IP. If this was your own design, you would simulate it and verify functionality before proceeding) Check the Messages tab for any errors and correct if necessary before moving to the next step When Synthesis completes successfully, click **Cancel**.

# 4. Package the IP

The package IP steps can be followed in the figures from 5.2.13 – to 5.2.22

- (a) First in the *Identification* window you can edit the IP Identification details.
- (b) Such as in the [Xil] documents we change the in the IP Catalog the sw\_ip category, where the ip will be included. "For the IP to appear in the IP catalog in particular categories, the IP must be configured to be part of those categories. To change which categories the IP will appear in the IP catalog click the browse box on the *Categories* line. This opens the Choose IP Categories window. For the purpose of this exercise, uncheck the **AXI Peripheral** box and check the **Basic Elements** and click **OK**."
- (c) In the *Compatibility* window shows the different Xilinx families for which the IP was created. You can ad other Xilinx devices. In this case the *Zynq* devices are already set.
- (d) In the **File Groups** window you can see that some changes are not merged. Click on **Merge changes from the File Groups Wizard** to merge the changes. This will update the IP Packager with the changes that were made to the IP.
- (e) In the IP Customization Parameters window click again Merge changes from IP Customization Parameters Wizard. Notice that in the *IP Ports and Interfaces* window now shoes the user created sw port.
- (f) Select **Review and Package** window, notice tha path where th IP will be created. Click **Re-Package IP**. The project is packed and closed.
- (g) In the original Vivado window click File Menu => Close Project











Figure 5.2.14: Choose or Create an IP category window

| ackaging Steps           | Identification                    |                                                                                                    |   |
|--------------------------|-----------------------------------|----------------------------------------------------------------------------------------------------|---|
| Identification           | Vendor:                           | user.org                                                                                           | 8 |
| Compatibility            | Library:                          | user                                                                                               | 8 |
| File Groups              | Name:                             | sw_ip                                                                                              | 8 |
| ·                        | Version:                          | 1.0                                                                                                | 8 |
| Customization Parameters | Display name:                     | sw_ip_vl.0                                                                                         | 8 |
| Ports and Interfaces     | Description:                      | My new sw AXI IP                                                                                   | 8 |
| Addressing and Memory    | Vendor display name:              |                                                                                                    |   |
| Customization GUI        | Company url:                      |                                                                                                    |   |
| Review and Package       | Root directory:<br>Xml file name: | /home/vajo/embed/ip/ip_repo/sw/sw_ip_1.0<br>/home/vajo/embed/ip/ip_repo/sw/sw_ip_1.0/component.xml |   |
|                          | Categories                        |                                                                                                    |   |
|                          | + - + +                           |                                                                                                    |   |
|                          | AXI_Peripheral                    |                                                                                                    |   |
|                          |                                   |                                                                                                    |   |
|                          |                                   |                                                                                                    |   |
|                          |                                   |                                                                                                    |   |
|                          |                                   |                                                                                                    |   |
|                          |                                   |                                                                                                    |   |

Figure 5.2.13: Pack IP – sw\_ip window









| Proj | ect Summary × Package IP - | sw_ip × sw_ip_v1_0.vhd × sw_ip_v1_0_S00_AXI.vhd × | o c |
|------|----------------------------|---------------------------------------------------|-----|
| Pa   | ckaging Steps              | Compatibility                                     |     |
| 1    | Identification             | Family   Simulator                                |     |
| ~    | Compatibility              | + - + - Automatic family support Level 1 V        |     |
| 2    | File Groups                | Family Life Cycle                                 |     |
| 1    | Customization Parameters   |                                                   |     |
| 1    | Ports and Interfaces       |                                                   |     |
| ~    | Addressing and Memory      |                                                   |     |
| 2    | Customization GUI          |                                                   |     |
| 2    | Review and Package         |                                                   |     |
|      |                            |                                                   |     |
|      |                            |                                                   |     |
|      |                            |                                                   |     |
|      |                            |                                                   |     |
|      |                            |                                                   |     |
|      |                            |                                                   |     |
|      |                            |                                                   |     |

Figure 5.2.15: Compatibility window

| Compatibility         Q         X         I         C           File Groups         Name         Library<br>Include         Users<br>Include         Users<br>Users         Users<br>Include         Users<br>Users         Users<br>Include         Users<br>Users         Users<br>Include         Users<br>Users         Users<br>Include         Users         Users <thusers< th=""> <thuse< th=""><th>Identification     Q X + Image     Image</th><th>Identification         Q         X         Image: Compatibility         Image: Compatib</th><th>Compatibility         Name         Ubrary<br/>Name         Type         Is         Used in<br/>Include         File Group         Model           File Groups         Standard         Image: Standard</th><th>kaging Steps</th><th>File Groups</th><th></th><th></th><th></th><th></th><th></th><th></th><th></th></thuse<></thusers<> | Identification     Q X + Image                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                     | Identification         Q         X         Image: Compatibility         Image: Compatib                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                            | Compatibility         Name         Ubrary<br>Name         Type         Is         Used in<br>Include         File Group         Model           File Groups         Standard         Image: Standard                                                                            | kaging Steps            | File Groups             |                 |      |               |                     |  |            |  |
|----------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|--------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|----------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|---------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|-------------------------|-------------------------|-----------------|------|---------------|---------------------|--|------------|--|
| Compatibility         Q         X         I         C           File Groups         Name         Library<br>Include         Users<br>Include         Users<br>Users         Users<br>Include         Users<br>Users         Users<br>Include         Users<br>Users         Users<br>Include         Users<br>Users         Users<br>Include         Users         Users <thusers< th=""> <thuse< th=""><th>Compatibility         Q         Z         Q         Z         Q         Z         Q         Z         Z         Z         Z         Z         Z         Z         Z         Z         Z         Z         Z         Z         Z         Z         Z         Z         Z         Z         Z         Z         Z         Z         Z         Z         Z         Z         Z         Z         Z         Z         Z         Z         Z         Z         Z         Z         Z         Z         Z         Z         Z         Z         Z         Z         Z         Z         Z         Z         Z         Z         Z         Z         Z         Z         Z         Z         Z         Z         Z         Z         Z         Z         Z         Z         Z         Z         Z         Z         Z         Z         Z         Z         Z         Z         Z         Z         Z         Z         Z         Z         Z         Z         Z         Z         Z         Z         Z         Z         Z         Z         Z         Z         Z         Z         <thz< th="">         Z         <thz< th=""> <th< th=""><th>Compatibility         Q         Z         Q         Z         Q         Z         Q         Z         Z         Z         Z         Z         Z         Z         Z         Z         Z         Z         Z         Z         Z         Z         Z         Z         Z         Z         Z         Z         Z         Z         Z         Z         Z         Z         Z         Z         Z         Z         Z         Z         Z         Z         Z         Z         Z         Z         Z         Z         Z         Z         Z         Z         Z         Z         Z         Z         Z         Z         Z         Z         Z         Z         Z         Z         Z         Z         Z         Z         Z         Z         Z         Z         Z         Z         Z         Z         Z         Z         Z         Z         Z         Z         Z         Z         Z         Z         Z         Z         Z         Z         Z         Z         Z         Z         Z         Z         Z         Z         Z         Z         Z         Z         <thz< th="">         Z         <thz< th=""> <th< th=""><th>Compatibility         Q         Image         Image         User         User</th><th>Identification</th><th>Merge changes from File</th><th>Groups Wiz</th><th>ard</th><th></th><th></th><th></th><th></th><th></th></th<></thz<></thz<></th></th<></thz<></thz<></th></thuse<></thusers<>                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                      | Compatibility         Q         Z         Q         Z         Q         Z         Q         Z         Z         Z         Z         Z         Z         Z         Z         Z         Z         Z         Z         Z         Z         Z         Z         Z         Z         Z         Z         Z         Z         Z         Z         Z         Z         Z         Z         Z         Z         Z         Z         Z         Z         Z         Z         Z         Z         Z         Z         Z         Z         Z         Z         Z         Z         Z         Z         Z         Z         Z         Z         Z         Z         Z         Z         Z         Z         Z         Z         Z         Z         Z         Z         Z         Z         Z         Z         Z         Z         Z         Z         Z         Z         Z         Z         Z         Z         Z         Z         Z         Z         Z         Z         Z         Z         Z         Z         Z         Z         Z         Z         Z         Z         Z <thz< th="">         Z         <thz< th=""> <th< th=""><th>Compatibility         Q         Z         Q         Z         Q         Z         Q         Z         Z         Z         Z         Z         Z         Z         Z         Z         Z         Z         Z         Z         Z         Z         Z         Z         Z         Z         Z         Z         Z         Z         Z         Z         Z         Z         Z         Z         Z         Z         Z         Z         Z         Z         Z         Z         Z         Z         Z         Z         Z         Z         Z         Z         Z         Z         Z         Z         Z         Z         Z         Z         Z         Z         Z         Z         Z         Z         Z         Z         Z         Z         Z         Z         Z         Z         Z         Z         Z         Z         Z         Z         Z         Z         Z         Z         Z         Z         Z         Z         Z         Z         Z         Z         Z         Z         Z         Z         Z         Z         Z         Z         Z         Z         <thz< th="">         Z         <thz< th=""> <th< th=""><th>Compatibility         Q         Image         Image         User         User</th><th>Identification</th><th>Merge changes from File</th><th>Groups Wiz</th><th>ard</th><th></th><th></th><th></th><th></th><th></th></th<></thz<></thz<></th></th<></thz<></thz<> | Compatibility         Q         Z         Q         Z         Q         Z         Q         Z         Z         Z         Z         Z         Z         Z         Z         Z         Z         Z         Z         Z         Z         Z         Z         Z         Z         Z         Z         Z         Z         Z         Z         Z         Z         Z         Z         Z         Z         Z         Z         Z         Z         Z         Z         Z         Z         Z         Z         Z         Z         Z         Z         Z         Z         Z         Z         Z         Z         Z         Z         Z         Z         Z         Z         Z         Z         Z         Z         Z         Z         Z         Z         Z         Z         Z         Z         Z         Z         Z         Z         Z         Z         Z         Z         Z         Z         Z         Z         Z         Z         Z         Z         Z         Z         Z         Z         Z         Z         Z         Z         Z         Z         Z <thz< th="">         Z         <thz< th=""> <th< th=""><th>Compatibility         Q         Image         Image         User         User</th><th>Identification</th><th>Merge changes from File</th><th>Groups Wiz</th><th>ard</th><th></th><th></th><th></th><th></th><th></th></th<></thz<></thz<> | Compatibility         Q         Image         Image         User                                                                                                                                                                                                                                                                                                                                     | Identification          | Merge changes from File | Groups Wiz      | ard  |               |                     |  |            |  |
| Pile Groups         Name         Ubray Name         Name         Used in File Group Name         Name         Name           File Groups         Standard         Image         Image         Image         Image         Name         Name           Customization Parameters         Standard         Image         Image         Image         Image         Image         Image           Ports and Interfaces         Image                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                         | Ibid Groups         Name         Ibins Mark         Type         Is         Used in         Ibid Group         Made           Customization Parameters         Standard                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                            | Ibid Groups         Name         Ibins Mark         Type         Is         Used in         Ibid Group         Made           Customization Parameters         Standard                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                      | Name         Ubray<br>Name         Type         Is         Used in<br>Include         Ised Groups         Made           File Group         Standard         Image         Image         Image         Image         Name         Nadvaitaitaitaitaitaitaitaitaitaitaitaitaita                                                                                                                                                                                                                                                                                                             |                         | Q   X   \$  € +         |                 |      |               |                     |  |            |  |
| Customization Parameters         Standard         Image: Customization Parameters           Ports and Interfaces         > M+DL Synthesis (2)         Image: Customization Parameters         Standard           Addressing and Memory         > Software Driver (6)         Image: Customization Parameters         Standard           Customization GUI         > Software Driver (6)         Image: Customization Parameters         Standard                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                     | Customization Parameters         Standard         Image: Constraint of the standard           Ports and Interfaces         > W+DL Synthesis (2)         Image: Constraint of the standard         Swlp_Vl_0           Addressing and Memory         > Software Driver (6)         Image: Constraint of the standard         Swlp_Vl_0           Customization GUI         > Software Driver (6)         Image: Constraint of the standard         Swlp_Vl_0           Software Driver (6)         Image: Constraint of the standard         Image: Constraint of the standardd         Swlp_Vl_0           Customization GUI         > Software Driver (6)         Image: Constraint of the standardd         Image: Constraint of the standardd         Image: Constraint of the standardd                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                        | Customization Parameters         Standard         Image: Constraint of the standard           Ports and Interfaces         > W+DL Synthesis (2)         Image: Constraint of the standard         Swlp_Vl_0           Addressing and Memory         > Software Driver (6)         Image: Constraint of the standard         Swlp_Vl_0           Customization GUI         > Software Driver (6)         Image: Constraint of the standard         Swlp_Vl_0           Software Driver (6)         Image: Constraint of the standard         Image: Constraint of the standardd         Swlp_Vl_0           Customization GUI         > Software Driver (6)         Image: Constraint of the standardd         Image: Constraint of the standardd         Image: Constraint of the standardd                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                  | Customization Parameters         Standard         Image: Customization Parameters         Image: Customization Parameters           Ports and Interfaces         > WHDL Synthesis (2)         Image: Customization Parameters         Support Parameters         Support Parameters           Addressing and Memory         > Software Driver (6)         Image: Customization GUI         Support Parameters         Support Parameters           Customization GUI         > Block Diagram (1)         Image: Customization Parameters         Image: Customization Parameters         Image: Customization Parameters                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                        |                         | Name                    | Library<br>Name | Туре | ls<br>Include | Used In<br>Constant |  |            |  |
| Ports and Interfaces         > © VHDL Synthesis (2)                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                  | Ports and Interfaces         > © VHDL Synthesis (2)                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                | Ports and Interfaces         > © VHDL Synthesis (2)                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                          | Ports and Interfaces         > © VHDL Synthesis (2)                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                             | ine oroupa              | Standard                |                 |      |               |                     |  |            |  |
| VHDL Simulation (2)         Image: Section (2)         Image:                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                      | VHDL Simulation (2)         Image: Section (2)         Image:                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                    | VHDL Simulation (2)         Image: Section (2)         Image:                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                              | VHDL Simulation (2)         Image: Section (2)         Image: | ustomization Parameters |                         |                 |      |               |                     |  |            |  |
| > WHD L Simulation (2)         own jp_v1_0           Addressing and Memory         > Software Driver (6)         0         0           > Software Driver (6)         0         0         0           Customization GUI         > Block Diagram (1)         0         0                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                               | > WHD L Simulation (2)         own jp_v1_0           Addressing and Memory         > Software Driver (6)         0         0           > Software Driver (6)         0         0         0           Customization GUI         > Block Diagram (1)         0         0                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                             | > WHD L Simulation (2)         own jp_v1_0           Addressing and Memory         > Software Driver (6)         0         0           > Software Driver (6)         0         0         0           Customization GUI         > Block Diagram (1)         0         0                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                       | Solution (2)         Solution (2)<                                                                                                    | Ports and Interfaces    | > 🗁 VHDL Synthesis (2)  |                 |      |               |                     |  | sw_ip_v1_0 |  |
| Customization GUI         Image: Customi                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                              | Customization GUI         Image: Customi                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                            | Customization GUI         Image: Customi                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                      | Customization GUI         Image: Block Diagram (1)         Image: Diagram (1)         Im | Forts and interfaces    | > 🖹 VHDL Simulation (2) |                 |      |               |                     |  | sw_ip_v1_0 |  |
| Customization GUI                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                    | Customization GUI                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                  | Customization GUI                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                            | Customization GUI                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                               | Addressing and Memory   | > 📄 Software Driver (6) |                 |      |               |                     |  |            |  |
| > Block Diagram (1)                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                  | > Block Diagram (1)                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                | > Block Diagram (1)                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                          | Block Diagram (1)                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                               | Customination CUI       |                         |                 |      |               |                     |  |            |  |
| Review and Package                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                   | Review and Package                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                 | Review and Package                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                           | Review and Package                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                              | Customization GUI       | > 🗁 Block Diagram (1)   |                 |      |               |                     |  |            |  |
|                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                      |                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                    |                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                              |                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                 |                         |                         |                 |      |               |                     |  |            |  |

Figure 5.2.16: Merge changes from the File Groups Wizard Window









# "FŐNIX ME" – Megújuló Egyetem felsőoktatási intézményi fejlesztések a felsőfokú oktatás minőségének és hozzáférhetőségének együttes javítása érdekében EFOP 3.4.3-16-2016-00015

| ackage IP - sw_ip                         |                                         |                 |                      |               |                     |                                 |               |
|-------------------------------------------|-----------------------------------------|-----------------|----------------------|---------------|---------------------|---------------------------------|---------------|
| Packaging Steps                           | File Groups                             |                 |                      |               |                     |                                 |               |
| ✓ Identification                          | Q   ≚   ♦   🔣 +   C                     |                 |                      |               |                     |                                 |               |
| <ul> <li>Compatibility</li> </ul>         | Name                                    | Library<br>Name | Туре                 | ls<br>Include | Used In<br>Constant | File Group Name                 | Model<br>Name |
| ✓ File Groups                             | Standard                                |                 |                      |               |                     |                                 |               |
| • The Groups                              | V 🖨 Advanced                            |                 |                      |               |                     |                                 |               |
| Customization Parameters                  | VHDL Synthesis (2)                      |                 |                      |               |                     |                                 | sw_ip_v1_0    |
| Ports and Interfaces                      | hdl/sw_ip_v1_0_S00_AXI.vhd              |                 | vhdlSource           |               |                     | xilinx_vhdlsynthesis            |               |
| Ports and Interfaces                      | hdl/sw_ip_v1_0.vhd                      |                 | vhdlSource           |               |                     | xilinx_vhdlsynthesis            |               |
| <ul> <li>Addressing and Memory</li> </ul> | VHDL Simulation (2)                     |                 |                      |               |                     |                                 | sw_ip_v1_0    |
|                                           | hdl/sw_ip_v1_0_S00_AXI.vhd              |                 | vhdlSource           |               |                     | xilinx_vhdlbehavioralsimulation |               |
| Customization GUI                         | hdl/sw_ip_v1_0.vhd                      |                 | vhdlSource           |               |                     | xilinx_vhdlbehavioralsimulation |               |
| Review and Package                        | Software Driver (6)                     |                 |                      |               |                     |                                 |               |
| 2 Nevew and Fackage                       | drivers/sw_ip_v1_0/data/sw_ip.mdd       |                 | mdd driver_mdd       |               |                     | xilinx_softwaredriver           |               |
|                                           | drivers/sw_ip_v1_0/data/sw_ip.tcl       |                 | tclSource driver_tcl |               |                     | xilinx_softwaredriver           |               |
|                                           | drivers/sw_ip_v1_0/src/Makefile         |                 | driver_src           |               |                     | xilinx_softwaredriver           |               |
|                                           | drivers/sw_ip_v1_0/src/sw_ip.h          |                 | cSource driver_src   |               |                     | xilinx_softwaredriver           |               |
|                                           | drivers/sw_ip_v1_0/src/sw_ip.c          |                 | cSource driver_src   |               |                     | xilinx_softwaredriver           |               |
|                                           | drivers/sw_ip_v1_0/src/sw_ip_selftest.c |                 | cSource driver_src   |               |                     | xilinx_softwaredriver           |               |
|                                           | ULayout (1)                             |                 |                      |               |                     |                                 |               |
|                                           | xgui/sw_ip_v1_0.tcl                     |                 | tclSource            |               |                     | xilinx_xpgui                    |               |
|                                           | Block Diagram (1)                       |                 |                      |               |                     |                                 |               |
|                                           | □ bd/bd.tcl                             |                 | tclSource            |               |                     | bd tcl                          |               |



| ackaging Steps       | Customization Parameters    |                            |                      |            |                            |                 |               |
|----------------------|-----------------------------|----------------------------|----------------------|------------|----------------------------|-----------------|---------------|
| Identification       | Q   ¥   ♦   ¶ +   C         |                            |                      |            |                            |                 |               |
| Compatibility        | Name                        | Description                | Display Name         | Value      | Value Bit String<br>Length | Value<br>Format | Value<br>Sour |
| File Groups          | ~  Customization Parameters |                            |                      |            |                            |                 |               |
| File Groups          | C_S00_AXI_DATA_WIDTH        | Width of S_AXI data bus    | C S00 AXI DATA WIDTH | 32         | 0                          | long            | defa          |
| Customization Paran  | C_S00_AXI_ADDR_WIDTH        | Width of S_AXI address bus | C S00 AXI ADDR WIDTH | 4          | 0                          | long            | defa          |
|                      | C_S00_AXI_BASEADDR          |                            | C S00 AXI BASEADDR   | 0xFFFFFFFF | 32                         | bitString       | defa          |
| Ports and Interfaces | C_S00_AXI_HIGHADDR          |                            | C S00 AXI HIGHADDR   | 0x00000000 | 32                         | bitString       | defa          |
| Addressing and Men   | > 🗀 Hidden Parameters       |                            |                      |            |                            |                 |               |
|                      |                             |                            |                      |            |                            |                 |               |

# Figure 5.2.18: Customization Parameters Window









### "FŐNIX ME" – Megújuló Egyetem felsőoktatási intézményi fejlesztések a felsőfokú oktatás minőségének és hozzáférhetőségének együttes javítása érdekében EFOP 3.4.3-16-2016-00015

| Ports and Interfaces        |                   |                          |           |                 |              |               |                         |
|-----------------------------|-------------------|--------------------------|-----------|-----------------|--------------|---------------|-------------------------|
| Q   ¥   ≑   +   ⊕   C       |                   |                          |           |                 |              |               |                         |
| Name                        | Interface<br>Mode | Enablement<br>Dependency | Direction | Driver<br>Value | Size<br>Left | Size<br>Right | Size Left<br>Dependency |
| > 🕕 S00_AXI                 | slave             |                          |           |                 |              |               |                         |
| > 📄 Clock and Reset Signals |                   |                          |           |                 |              |               |                         |
| D sw                        |                   |                          | in        |                 | 3            | 0             | (sw_width - 1)          |

Figure 5.2.20: User Port imported

| Packaging Steps                          | Customization Parameters |                            |                      |            |                            |                 |              |
|------------------------------------------|--------------------------|----------------------------|----------------------|------------|----------------------------|-----------------|--------------|
| <ul> <li>Identification</li> </ul>       | Q   ¥   ♦   ■ +   C      |                            |                      |            |                            |                 |              |
| <ul> <li>Compatibility</li> </ul>        | Name                     | Description                | Display Name         | Value      | Value Bit String<br>Length | Value<br>Format | Valu<br>Sour |
| <ul> <li>File Groups</li> </ul>          | Customization Parameters |                            |                      |            |                            |                 |              |
|                                          | C_S00_AXI_DATA_WIDTH     | Width of S_AXI data bus    | C S00 AXI DATA WIDTH | 32         | 0                          | long            | defa         |
| <ul> <li>Customization Paran</li> </ul>  | C_S00_AXI_ADDR_WIDTH     | Width of S_AXI address bus | C S00 AXI ADDR WIDTH | 4          | 0                          | long            | defa         |
|                                          | C_S00_AXI_BASEADDR       |                            | C S00 AXI BASEADDR   | 0xFFFFFFFF | 32                         | bitString       | defa         |
| <ul> <li>Ports and interfaces</li> </ul> | C_S00_AXI_HIGHADDR       |                            | C S00 AXI HIGHADDR   | 0x00000000 | 32                         | bitString       | defa         |
| <ul> <li>Addressing and Men</li> </ul>   | 🗸 🗁 Hidden Parameters    |                            |                      |            |                            |                 |              |
|                                          | 🔅 sw width               | 1                          | Sw Width             | 4          | 0                          | long            | defa         |

Figure 5.2.19: User parameter imported

| Packaging Steps                                                                                         | Customization GUI                                                                                                                                |                                                         |                                                            |   |
|---------------------------------------------------------------------------------------------------------|--------------------------------------------------------------------------------------------------------------------------------------------------|---------------------------------------------------------|------------------------------------------------------------|---|
| <ul> <li>Identification</li> </ul>                                                                      | Layout                                                                                                                                           | Preview                                                 |                                                            |   |
| Compatibility File Groups Customization Paran Ports and Interfaces Addressing and Men Customization GUI | <ul> <li>C SOO AXI BASEADDR</li> <li>C SOO AXI HIGHADDR</li> <li>SW Width</li> <li>C SOO Axi Data Width</li> <li>C SOO Axi Addr Width</li> </ul> | Show disabled ports                                     | Component Name<br>C SOO AXI BASEADDR<br>C SOO AXI HIGHADDR | 6 |
| Review and Package                                                                                      | 🗖 Hidden Parameters                                                                                                                              | + 500_AXI<br>sw(3:0)<br>s00_axi_acik<br>s00_axi_aresetn |                                                            |   |

Figure 5.2.21: Customization Graphical User Interface GUI Window









"FŐNIX ME" – Megújuló Egyetem felsőoktatási intézményi fejlesztések a felsőfokú oktatás minőségének és hozzáférhetőségének együttes javítása érdekében EFOP 3.4.3-16-2016-00015

| Project Summary × sv                                                                                                     | r_jp_v1_0.vhd x sw_jp_v1_0_S00_AXI.vhd x Package IP - sw_jp x                                                                                                                     | Ľ |
|--------------------------------------------------------------------------------------------------------------------------|-----------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|---|
| Packaging Steps                                                                                                          | Review and Package                                                                                                                                                                |   |
| Identification     Compatibility     File Groups     Customization Paran     Ports and Interfaces     Addressing and Men | Summary<br>Display name: sw_jp_v1.0<br>Description: My new sw AXI IP<br>Root directory: /home/vajo/embed/ip/ip_repo/sw/sw_jp_1.0                                                  | - |
| Customization GUI     Review and Package                                                                                 | After Packaging<br>An archive will not be generated. Use the settings link below to change your preference<br>Project will be removed after completion<br>Edit packaging settings | - |
| <>                                                                                                                       | Package IP                                                                                                                                                                        |   |

Figure 5.2.22: Review and Package Window

# 5.2.2 Create the Vivado Project with User Designed IP

# Create New Project or continue with lab2 project

- 1. Launch Vivado and create an empty project targeting the ZedBoard, using the VHDL language or use the project lab2 presented in ?? and save the project as lab3.
  - (a) Open Vivado by selecting: Start => All Programs => Xilinx Design Tools => Vivado 2020.2
     => Vivado 2020.2
  - (b) Open Vivado by starting the *xilinx.sh* -v script if you are logged in the lab. Select Vivado 2020.2 from the list.
  - (c) Click **Create New Project** to start the wizard. You will see the *Create a New Vivado Project* dialog box. Click **Next**.
  - (d) Click in the field of the Project Location and type /embed/zed/. Enter lab3 in the Project Name field. Make sure that the Create project subdirectory box is checked. Click Next. See figure 5.2.23.
  - (e) In the **Project Type** form select *RTL Project*. Make sure that *Do not specify sources this time* box is checked and click **Next**. See figure 5.2.24.
  - (f) For the Default Part window choose Boards and select Zybo or Zedboard click Next.
  - (g) For *Zedboard* choose *em.avnet.com*, then select the board in the window or simply type in the search box the desired board and revision. The online Zedboard is rev D. See figure 5.2.25. Then click **Next** and finally click **Finish**.









| 🙏 New Project                       |                                                                                 |        |        |        | ×      |
|-------------------------------------|---------------------------------------------------------------------------------|--------|--------|--------|--------|
| Project Name<br>Enter a name for yo | ur project and specify a directory where the project data files will be stored. |        |        |        | A      |
| Project name:                       | lab1part2                                                                       |        |        |        |        |
| Project location:                   | C:/Users/vajo/Documents/LABs                                                    |        |        |        | ⊗      |
| Create project                      | t subdirectory                                                                  |        |        |        |        |
| Project will be cr                  | eated at: C:/Users/vajo/Documents/LABs/lab1part2                                |        |        |        |        |
|                                     |                                                                                 |        |        |        |        |
|                                     |                                                                                 |        |        |        |        |
|                                     |                                                                                 |        |        |        |        |
|                                     |                                                                                 |        |        |        |        |
|                                     |                                                                                 |        |        |        |        |
|                                     |                                                                                 |        |        |        |        |
|                                     |                                                                                 |        |        |        |        |
|                                     |                                                                                 |        |        |        |        |
|                                     |                                                                                 |        |        |        |        |
|                                     |                                                                                 |        |        |        |        |
| ?                                   |                                                                                 | < Back | Next > | Einish | Cancel |

Figure 5.2.23: Project Name Entry

| 💫 New Project                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                              | ×         |
|----------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|-----------|
| Project Type<br>Specify the type of project to create.                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                     | 4         |
| <ul> <li>BTL Project         You will be able to add sources, create block designs in IP Integrator, generate IP, run RTL analysis, synthesis, implementation, design planning and a         On not specify sources at this time         Project is an extensible Vitis platform         Project is an extensible Vitis platform         Do not specify sources at this time         Og not specify sources at this time         Do not specify sources at this time         Do not specify design sources. You will be able to view partipackage resources.         Uponted Project         Create a vixedo project from a Synplify. XST or ISE Project File.         Egample Project         Create a new Vixado project from a predefined template.         </li> </ul> | inalysis. |
| Sack Next> Einish                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                          | Cancel    |

Figure 5.2.24: RTL Project selection









"FŐNIX ME" – Megújuló Egyetem felsőoktatási intézményi fejlesztések a felsőfokú oktatás minőségének és hozzáférhetőségének együttes javítása érdekében EFOP 3.4.3-16-2016-00015

| Reset Al | I Filters                                                         |           |              |              |                 |               | Install/Updat | e Boards |
|----------|-------------------------------------------------------------------|-----------|--------------|--------------|-----------------|---------------|---------------|----------|
| endor:   | All 🗸                                                             | Name: All |              |              | ~               | Board Rev:    | Latest        | `        |
| Search:  | Q.                                                                | ~         |              |              |                 |               |               |          |
| Display  |                                                                   | Preview   | Vendor       | File Version | Part            | I/O Pin Count | Board Rev     | Availat  |
|          | ard Zyng Evaluation and Development I<br>mpanion Card Connections | Kit       | em.avnet.com | 1.4          | xc7z020clg484-1 | 484           | đ             | 200      |
|          | 7 ZC702 Evaluation Board<br>mpanion Card Connections              |           | xilinx.com   | 1.4          | xc7z020clg484-1 | 484           | 1.0           | 200      |
|          | 7 ZC706 Evaluation Board<br>mpanion Card Connections              |           | xilinx.com   | 1.4          | xc7z045ffg900-2 | 900           | 1.1           | 362      |

Figure 5.2.25: Board selection window for Zedboard

# **Modify Project settings**

- 1. Click Project Settings in the Flow Navigator pane.
- 2. Select IP in the left pane of the Project Settings form. Click to open.
- Select Repository and in the IP Repositories windows click + to add the user IP repository where the *sw\_ip* was created. Select the directory where the sw IP was created namely: */embed/ip/ip\_repo/sw*. See figure 5.2.26.



Figure 5.2.26: Set up IP repository

# **Create the System Block Design Using IP Integrator**

- 1. Use the IP Integrator to create a new Block Design, add the ZYNQ processing system block, and configure the processing system.
- 2. In the Flow Navigator, click Create Block Design under IP Integrator.
- 3. Enter *system* for the design name and click OK. See figure 5.2.27.









"FŐNIX ME" – Megújuló Egyetem felsőoktatási intézményi fejlesztések a felsőfokú oktatás minőségének és hozzáférhetőségének együttes javítása érdekében EFOP 3.4.3-16-2016-00015

- 4. IP from the catalog can be added in different ways. Click + icon in the empty block diagram workspace or Add IP icon in the block diagram side bar or press Ctrl + I, or right-click anywhere in the Diagram workspace and select Add IP. See figure 5.2.28
- 5. Once the IP Catalog is open, type "z" into the Search bar, find and double click on **ZYNQ7** Processing System entry, or click on the entry and hit the Enter key to add it to the design (See 5.2.29)
- 6. Notice the message at the top of the Diagram window that *Designer Assistance Available*. Click **Run Block Automation** and select /processing\_system7\_0. See figure 5.2.30
- 7. In the *Run Block Automation* window, leave the default settings, including *Apply Board Preset* checked, and click OK. See figure 5.2.31. Once Block Automation has been complete, notice that ports have been automatically added for the DDR and Fixed IO, and some additional ports are now visible. The imported configuration for the Zynq related to the Zybo/Zedboard board has been applied which will now be modified. See figure 5.2.32
- 8. Double-click on the added block to open its Customization window. Notice now the Customization window shows selected peripherals (with tick marks). This is the default configuration for the board applied by the block automation. See figure 5.2.33
- 9. A block diagram of the Zynq should now be open again, showing various configurable blocks of the *Processing System*. At this stage, the designer can select or deselect various configurable blocks (highlighted in green) and change the system configuration.
- 10. Configure the processing block with UARTO and GPIO MIO peripheral enabled.
  - (a) Only the UARTO and GPIO MIO is required for this lab, so all other peripherals will be deselected.
  - (b) Click on one of the peripherals (in green) in the *I/O Peripherals* block, or **select** the **MIO Configuration** tab on the left to open the configuration form. The procedures are resumed in Figure 5.2.33 and Figure 5.2.34
    - i. Expand *I/O peripherals* if necessary, and ensure all the following I/O peripherals are deselected except **GPIO MIO and UARTO**
    - ii. Expand *Memory Interfaces* to deselect *Quad SPI Flash*.
    - iii. Expand Application Processor Unit to disable Timer 0.
    - iv. Select the *PS-PL Configuration* tab on the left. Expand AXI Non Secure Enablement
       => GP Master AXI interface and select M AXI GP0 interface if not already selected(!).
    - v. Expand General => Enable Clock Resets and deselect the FCLK\_RESETO\_N option.
    - vi. Select the **Clock Configuration** tab on the left. Expand the **PL Fabric Clocks** and select the **FCLK\_CLK0** option and click **OK**
    - vii. In the block design connect **FCLK\_CLK0** with textbfM\_AXI\_GP0\_ACLK. Hover your mouse over the connector port until the pencil button appears then connect the two signals









"FŐNIX ME" – Megújuló Egyetem felsőoktatási intézményi fejlesztések a felsőfokú oktatás minőségének és hozzáférhetőségének együttes javítása érdekében EFOP 3.4.3-16-2016-00015

- viii. Click on the Validate Design button and make sure that there are no errors.
- (c) Enable **AXI\_M\_GP0** interface, **FCLK\_RESET0\_N**, and **FCLK\_CLK0** ports if already not enabled [Xil]. Click **OK** to close the Zynq Processing System configuration window.

| A Create Block Design X |                  |           |  |  |
|-------------------------|------------------|-----------|--|--|
| Please specify name     |                  |           |  |  |
|                         |                  |           |  |  |
| Design name:            | system           | $\otimes$ |  |  |
| Directory:              | Section 4        | ~         |  |  |
| Specify source set:     | 🗅 Design Sources | ~         |  |  |
| ?                       | ОК               | Cancel    |  |  |

Figure 5.2.27: Create New Block Diagram

This design is empty. Press the 🕂 button to add IP.



Figure 5.2.28: Add IP to Block Diagram possibilities



Figure 5.2.29: Add IP ZYNQ7 Processing System











Figure 5.2.30: Run Block Automation Process



120







| A Run Block Automation                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                      | × |
|-------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|---|
| Automatically make connections in your design by checking the boxes of the blocks to connect. Select a block on the left to display its configuration options on the right.                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                 |   |
| Q       ★         Image: A line Automation (1 out of 1 selected)         Image: A line Automation (1 out of 1 selected)         Image: A line Automation (1 out of 1 selected)         Image: A line Automation (1 out of 1 selected)         Image: A line Automation (1 out of 1 selected)         Image: A line Automation (1 out of 1 selected)         Image: A line Automation (1 out of 1 selected)         Image: A line Automation (1 out of 1 selected)         Image: A line Automation (1 out of 1 selected)         Image: A line Automation (1 out of 1 selected)         Image: A line Automation (1 out of 1 selected)         Image: A line Automation (1 out of 1 selected)         Image: A line Automation (1 out of 1 selected)         Image: A line Automation (1 out of 1 selected)         Image: A line Automation (1 out of 1 selected)         Image: A line Automation (1 out of 1 selected)         Image: A line Automation (1 out of 1 selected)         Image: A line Automation (1 out of 1 selected)         Image: A line Automation (1 out of 1 selected)         Image: A line Automation (1 out of 1 selected)         Image: A line Automation (1 out of 1 selected)         Image: A line Automation (1 out of 1 selected)         Image: A line Automation (1 out of 1 selected)         Image: A line Automation (1 out of 1 selected)         Image: A line Aut |   |
| (?) OK Cancel                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                               |   |

Figure 5.2.31: Selecting connections on Run Block Automation Process Settings



Figure 5.2.32: Schematic of the ZYNQ connected to DDR and FIXED\_IO









| YNQ7 Processing        | <b>j System (5.5)</b><br>Presets 📄 IP Location 🌼 Import XPS Se | ettings | <i>.</i>                                     |
|------------------------|----------------------------------------------------------------|---------|----------------------------------------------|
| Page Navigator         | PS-PL Configuration                                            |         | Summary Report                               |
| lynq Block Design      | ← Q ≍ ≑                                                        |         |                                              |
| S-PL Configuration     | Search: Q-                                                     |         |                                              |
|                        | Name                                                           | Select  | Description                                  |
| eripheral I/O Pins     | <ul> <li>Enable Clock Triggers</li> </ul>                      |         |                                              |
| IIO Configuration      | FLCK_CLKTRIG0                                                  |         | Enables PL clock trigger signal 0 used to ha |
|                        | FLCK_CLKTRIG1                                                  |         | Enables PL clock trigger signal 1 used to ha |
| Clock Configuration    | FLCK_CLKTRIG2                                                  |         | Enables PL clock trigger signal 2 used to ha |
| DR Configuration       | FLCK_CLKTRIG3                                                  |         | Enables PL clock trigger signal 3 used to ha |
| , or the orthogonation | <ul> <li>Enable Clock Resets</li> </ul>                        |         |                                              |
| SMC Timing Calcul:     | FCLK_RESET0_N                                                  |         | Enables general purpose reset signal 0 for   |
| nterrupts              | FCLK_RESET1_N                                                  |         | Enables general purpose reset signal 1 for   |
| nenupis                | FCLK_RESET2_N                                                  |         | Enables general purpose reset signal 2 for   |
|                        | FCLK_RESET3_N                                                  |         | Enables general purpose reset signal 3 for   |
|                        | <ul> <li>AXI Non Secure Enablement</li> </ul>                  | 0 、     | Enable AXI Non Secure Transaction            |
|                        | ✓ GP Master AXI Interface                                      |         |                                              |
|                        | > M AXI GP0 interface                                          |         | Enables General purpose AXI master interfa   |
|                        | > M AXI GP1 interface                                          |         | Enables General purpose AXI master interfa   |
|                        | > GP Slave AXI Interface                                       |         |                                              |
|                        | > HP Slave AXI Interface                                       |         |                                              |
|                        | > ACP Slave AXI Interface                                      |         |                                              |
|                        | > DMA Controller                                               |         |                                              |
|                        | > PS-PL Cross Trigger interface                                |         | Enables PL cross trigger signals to PS and   |
|                        | <                                                              |         |                                              |

Figure 5.2.33: ZYNQ 7 IP Processing System Settings









### "FŐNIX ME" – Megújuló Egyetem felsőoktatási intézményi fejlesztések a felsőfokú oktatás minőségének és hozzáférhetőségének együttes javítása érdekében EFOP 3.4.3-16-2016-00015

| Re-customize IP        |                                                 | 🝌 Re-customize IP               |                                                   | 🝌 Re-customize IP   |                                          |  |
|------------------------|-------------------------------------------------|---------------------------------|---------------------------------------------------|---------------------|------------------------------------------|--|
| ZYNQ7 Processing Sy    | sing System (5.5) ZYNQ7 Processing System (5.5) |                                 | a System (5.5)                                    | Page Navigator      | Clock Configuration                      |  |
| <b>_</b> ,             |                                                 |                                 |                                                   |                     | Basic Clocking Advanced Cl               |  |
| Documentation 🔅 Pre    | sets 📄 IP Location 🔅 Impoi                      | Occumentation I I Documentation | Presets 📄 IP Location 🔅 Import X                  | PS-PL Configuration | Input Frequency (MHz) 33.33333           |  |
| Page Navigator –       | Peripheral I/O Pins                             | Page Navigator                  | MIO Configuration                                 | Peripheral I/O Pins | ← Q ± ≑ +4                               |  |
| Zynq Block Design      | ← Q ≚ ≑ 9                                       | Zynq Block Design               | Bank 0 I/O Voltage LVCMOS 3.3V                    | MIO Configuration   | Search: Q-                               |  |
| PS-PL Configuration    | Search: Q-                                      | PS-PL Configuration             | ← Q ≍ ≑ щ 0                                       | Clock Configuration | Component<br>V Processor/Memory Clocks   |  |
| Peripheral I/O Pins    |                                                 | Peripheral I/O Pins             |                                                   | DDR Configuration   | CPU                                      |  |
|                        | Peripherals                                     |                                 | Search: Q.                                        |                     | DDR                                      |  |
| MIO Configuration      | >  Ethernet 1                                   | MIO Configuration               | Peripheral                                        | SMC Timing Calcula  | <ul> <li>IO Peripheral Clocks</li> </ul> |  |
| Clock Configuration    |                                                 | Clock Configuration             | 🗌 I2C 1                                           | Interrupts          | SMC                                      |  |
|                        |                                                 |                                 | > SPI 0                                           |                     | QSPI                                     |  |
| DDR Configuration      | USB 1                                           | DDR Configuration               | > 🗌 SPI 1                                         |                     | ENET0                                    |  |
| SMC Timing Calculation | > 🗆 SD 0                                        | SMC Timing Calcula              | > CAN 0                                           |                     | ENET1                                    |  |
|                        | > 🗌 SD 1                                        | > _ CAN 1                       |                                                   |                     | SDIO                                     |  |
| Interrupts             | >      SPI 0                                    | Interrupts                      | V GPIO                                            |                     | SPI                                      |  |
|                        | > SPI 1                                         |                                 | > GPIO MIO                                        |                     | CAN CLK<br>CAN OLK                       |  |
|                        |                                                 |                                 | EMIO GPIO (Width)                                 |                     |                                          |  |
|                        |                                                 |                                 | > ENET Reset                                      |                     |                                          |  |
|                        | > UART 1                                        |                                 | > USB Reset                                       |                     | CAN1 MIOCLK                              |  |
|                        | □ 12C 0                                         |                                 | >   I2C Reset                                     |                     | PL Fabric Clocks                         |  |
|                        | 🗌 I2C 1                                         |                                 | Application Processor Unit     Timer 0            |                     | FCLK_CLK0                                |  |
|                        | > CAN 0                                         |                                 | Timer 1                                           |                     |                                          |  |
|                        | CAN 1                                           |                                 | Watchdog                                          |                     |                                          |  |
|                        |                                                 |                                 | <ul> <li>Programmable Logic Test and D</li> </ul> |                     |                                          |  |
|                        |                                                 |                                 | V TRACE                                           |                     |                                          |  |
|                        |                                                 |                                 | d[0:1]                                            |                     |                                          |  |
|                        | SWDT                                            |                                 | d[2:3]                                            |                     |                                          |  |
|                        | PJTAG                                           |                                 | d[4:7]                                            |                     |                                          |  |
|                        | > 🗌 TPIU                                        |                                 | d[8:15]                                           |                     |                                          |  |
|                        | > 🕑 GPIO MIO                                    |                                 | d[16:31]                                          |                     |                                          |  |
|                        |                                                 |                                 | D PJTAG                                           |                     |                                          |  |

# Figure 5.2.34: ZYNQ 7 IP Processing System Peripheral, MIO and Clock Settings



Figure 5.2.35: Updated schematic block design









"FŐNIX ME" – Megújuló Egyetem felsőoktatási intézményi fejlesztések a felsőfokú oktatás minőségének és hozzáférhetőségének együttes javítása érdekében EFOP 3.4.3-16-2016-00015

# Add GPIO peripherals.

- 1. In the Sources panel choose Board (see figure 5.2.36), double click on the LED IP to add at the block diagram.
- Do the same for the Push Buttons but at this time choose in the pop-up window Connect Board Component => Create new IP => GPIO (Figure 5.2.37).
- 3. From the IP Catalog select and add the user created IP sw\_ip (see figure 5.2.38).
- 4. From the IP Catalog add Block Ram Controller and Block Memory Generator figure 5.2.40.
- 5. Run Connection Automation.
- 6. Rename the AXI GPIOs connected to the LEDs and Push Buttons to *leds* and *buttons* respectively click on each AXI GPIO and rename them on the *Block Properties window*.
- 7. Right click on the *sw\_ip* **sw** port and select **Make external**. Since is connected rename the external port to *sw* by clicking on the *sw\_0* port and in the Properties window change the name.
- 8. Double Click on the sw\_ip to re-customize the IP. Edit the number of switches i.e. *Sw width* corresponding to the Zed board (8) or Zybo (4) as seen in figure 5.2.42
- 9. Validate the design. The design should look like in figure 5.2.41
- 10. In the design **Sources** right click on the *system.bd* design and **Create HDL Wrapper**, select *Let Vivado menage wrapper and auto update* option.
- 11. In the Flow Navigator window select IP Integrator => Generate Block Design.
- 12. Run Synthesis











Figure 5.2.36: Adding Board IP LEDs

|                     | <b>ct Board Component</b><br>e for connecting board componen | it 'Push |
|---------------------|--------------------------------------------------------------|----------|
|                     |                                                              |          |
| Q,   素   ≑          |                                                              |          |
| Name                | VLNV                                                         |          |
| ∨ 👎 leds (AXI GPIO) | xilinx.com:ip:axi_gpio:2.0                                   | ^        |
| GPI02               |                                                              |          |
| ✓ Create new IP     |                                                              |          |
| AXI GPIO            | xilinx.com:ip:axi_gpio:2.0                                   |          |
| - GPIO              |                                                              |          |
| GPI02               |                                                              | _        |
| ✓ + IOModule        | xilinx.com:ip:iomodule:3.1                                   |          |
| GPI01               |                                                              |          |
| GPI02               |                                                              |          |
| GPI03               |                                                              | ~        |
|                     |                                                              |          |

Figure 5.2.37: New AXI GPIO selected for the Push Buttons









"FŐNIX ME" – Megújuló Egyetem felsőoktatási intézményi fejlesztések a felsőfokú oktatás minőségének és hozzáférhetőségének együttes javítása érdekében EFOP 3.4.3-16-2016-00015



Figure 5.2.38: labsys3

| <u>S</u> earch: | Q- axi bram    | 🛞 (1 match) |
|-----------------|----------------|-------------|
| 🌻 axi br        | RAM Controller |             |
|                 |                |             |

Figure 5.2.39: labsys4

|                                                                                      | Run Connection Automa                     | ion                                              |             | • E    |
|--------------------------------------------------------------------------------------|-------------------------------------------|--------------------------------------------------|-------------|--------|
| omatically make connections in your desig<br>figuration options on the right.        | n by checking the boxes of the interfaces | to connect. Select an interface on the left to c | lisplay its | - 🏄    |
| ಧ  ≚   ≑                                                                             | Description                               |                                                  |             |        |
| <ul> <li>✓ All Automation (1 out of 1 selected)</li> <li>✓ Ø ♥ axi_gpio_0</li> </ul> |                                           | S_AXI) to a selected Master address space.       |             |        |
|                                                                                      | Options                                   |                                                  |             |        |
|                                                                                      | Master Interface                          | /processing_system7_0/M_AXI_GP0 🛛 😽              |             |        |
|                                                                                      | Bridge IP                                 | New AXI Interconnect 🛛 😽                         |             |        |
|                                                                                      | Clock source for driving Bridge IP        | Auto                                             | ~           |        |
|                                                                                      | Clock source for Slave interface          | Auto                                             | ~           |        |
|                                                                                      | Clock source for Master interface         | /processing_system7_0/FCLK_CLK0 (100 MHz)        | $\sim$      |        |
|                                                                                      |                                           |                                                  |             |        |
|                                                                                      |                                           |                                                  |             |        |
|                                                                                      |                                           |                                                  |             |        |
|                                                                                      |                                           |                                                  |             |        |
|                                                                                      |                                           |                                                  |             |        |
|                                                                                      |                                           |                                                  |             |        |
|                                                                                      |                                           |                                                  |             |        |
|                                                                                      |                                           |                                                  |             |        |
|                                                                                      |                                           |                                                  | ок          | Cancel |

Figure 5.2.40: labsys2 run connection automation























"FŐNIX ME" – Megújuló Egyetem felsőoktatási intézményi fejlesztések a felsőfokú oktatás minőségének és hozzáférhetőségének együttes javítása érdekében EFOP 3.4.3-16-2016-00015

| 4                                                               | Re-customize II                                          |                    | ↑ □ ×    |
|-----------------------------------------------------------------|----------------------------------------------------------|--------------------|----------|
| sw_ip_v1.0 (1.0)                                                |                                                          |                    | 4        |
| 🚯 Documentation 🛛 📄 IP Location                                 |                                                          |                    |          |
| Show disabled ports                                             | Component Name sw_ip                                     |                    |          |
| ::+ S00_AXI<br>• sw(7:0)<br>• s00_axi_aclk<br>• s00_axi_aresetn | C SOO AXI BASEADDR 0<br>C SOO AXI HIGHADDR 0             |                    |          |
|                                                                 | Sw Width<br>C S00 Axi Data Width<br>C S00 Axi Addr Width | 8 ©<br>32 ©<br>4 © |          |
|                                                                 |                                                          | C                  | K Cancel |

Figure 5.2.42: Re-customize IP window

# **Open Synthesized Design and edit constraints**

The sw\_ip created has access to the Zedboard/Zybo switches. So in the constraints file the location and technology type must be introduced the. One of the possibilities is to open the synthesized design to edit the pin locations and use **IO Planning** layout.

- 1. Open Synthesized design and switch layout (in the right top corner of the Vivado to I/O Planning.
- 2. Click the sw(8) pin to open the sw IO ports loc (figure 5.2.43).
- 3. Edit the pin locations and technology for the corresponding board. Conform table edit the pad locations and set-up technology to LVCMOS33. The figure (5.2.44) shows the situation after editing the pin locations and technology for the Zed board.
- 4. Another way to add pin constraints is to download from the DigilentInc homepage the corresponding constrains file (.xdc) and add to the design.
  - (a) This can be done in the *Flow Navigator* pane click **Add Sources** => **Add or Create Constraints** and click **Next**.









- (b) Click **Add Files** browse to the directory where the *zed.xdc* or *zybo.xdc* was downloaded. Select the file and click **Finish** to add the file.
- (c) Edit the corresponding .xdc file and comment the lines which are not needed with the character "#", then save the file.

| Tcl Console Messages     | Log Repo  | orts | De | sig | n Runs  | Pack | age Pir      | ns I/O Por | ts ×               |   |
|--------------------------|-----------|------|----|-----|---------|------|--------------|------------|--------------------|---|
| Q   ¥   ♦   •€   +   ₩   | I I       |      |    |     |         |      |              |            |                    |   |
| Name                     | Direction |      |    |     | Package | Pin  | Fixed        | Bank       | I/O Std            |   |
| 🗸 📄 All ports (151)      |           |      |    |     |         |      |              |            |                    |   |
| > 🗟 btns_5bits_12642 (5) | IN        |      |    |     |         |      | $\checkmark$ | 34         | LVCM0S25*          |   |
| > 🗟 DDR_12642(71)        | INOUT     |      |    |     |         |      | ~            | 502        | (Multiple)*        |   |
| > 🕞 FIXED_I0_12642 (59)  | INOUT     |      |    |     |         |      | ~            | (Multiple) | (Multiple)*        |   |
| > 🗟 leds_8bits_12642 (8) | OUT       |      |    |     |         |      |              | 33         | LVCM0S33*          | Ŧ |
| 🗸 🕒 sw (8)               | IN        |      |    |     |         |      |              |            | default (LVCMOS18) |   |
| D sw[7]                  | IN        |      |    |     |         | ~    |              |            | default (LVCMOS18) |   |
| D sw[6]                  | IN        |      |    |     |         | ~    |              |            | default (LVCMOS18) |   |
| D sw[5]                  | IN        |      |    |     |         | ~    |              |            | default (LVCMOS18) |   |
| D sw[4]                  | IN        |      |    |     |         | ~    |              |            | default (LVCMOS18) |   |
| D sw[3]                  | IN        |      |    |     |         | ~    |              |            | default (LVCMOS18) |   |
| D sw[2]                  | IN        |      |    |     |         | ~    |              |            | default (LVCMOS18) |   |
| D sw[1]                  | IN        |      |    |     |         | ~    |              |            | default (LVCMOS18) | Ŧ |
| D sw[0]                  | IN        |      |    |     |         | ~    |              |            | default (LVCMOS18) | Ŧ |
| 🚍 Scalar ports (0)       |           |      |    |     |         |      |              |            |                    |   |

| Table 5.1: Zed Board DIP Switch Connections [Dig21a | )] |
|-----------------------------------------------------|----|
|-----------------------------------------------------|----|

| Signal Name | Zynq EPP pin |
|-------------|--------------|
| SW0         | F22          |
| SW1         | G22          |
| SW2         | H22          |
| SW3         | F21          |
| SW4         | H19          |
| SW5         | H18          |
| SW6         | H17          |
| SW7         | M15          |









#### "FŐNIX ME" – Megújuló Egyetem felsőoktatási intézményi fejlesztések a felsőfokú oktatás minőségének és hozzáférhetőségének együttes javítása érdekében EFOP 3.4.3-16-2016-00015

Table 5.2: Zybo Board DIP Switch Connections [Dig21b]

| Signal Name | Zynq EPP pin |
|-------------|--------------|
| SW0         | G15          |
| SW1         | P15          |
| SW2         | W13          |
| SW3         | T16          |

#### All ports (151) > 🗟 btns\_5bits\_12642 (5) IN 34 LVCM0S25\* $\checkmark$ > 🕞 DDR 12642 (71) INOUT 502 (Multiple)\* FIXED IO 12642 (59) INOUT ... (Multiple) (Multiple)\* > 🗇 leds 8bits 12642 (8) OUT 33 LVCM0S33\* 🌛 sw (8) IN ✓ (Multiple) LVCM0S33\* IN M15 34 LVCM0S33\* sw[7] sw[6] IN H17 35 LVCM0S33\* sw[5] IN H18 35 LVCM0S33\* IN 35 LVCMOS33\* ▶ sw[4] H19 IN F21 35 LVCM0S33\* sw[3] sw[2] IN H22 $\checkmark$ 35 LVCM0S33\* sw[1] IN 35 LVCM0S33\* G22 🕑 sw[0] IN F22 35 LVCM0S33\* ¥.

Figure 5.2.44: Constraints for the sw pins

# Generate IP Integrator Outputs, the top-level HDL, export the hardware to Vitis and start Vitis.

- 1. Right-click on **system.bd**, and select **Create HDL Wrapper** to generate the top-level VHDL model. Leave the *Let Vivado manager wrapper and auto-update* option selected, and click **OK** The **system\_wrapper.vhd** file will be created and added to the project (Figure 5.1.54.
- In the sources panel, right-click again on system.bd, and select Generate Output Products and click Generate to generate the Implementation, Simulation and Synthesis files for the design. Select Global You can also click on Generate Block Design in the *Flow Navigator pane* to do the same.

**Note**: If the synthesis option is **Global**, only wrapper files are generated during the block design generation phase, and the design will be synthesized as a whole at the synthesis stage. If the synthesis option is **Out of context per IP** or **Out of context per Block design**, the wrapper of the IP or block design will be generated and synthesized during block design generation, and the generated net lists will be combined together at the synthesis stage. Double-click on the file to see the content in the Auxiliary pane.

3. Notice that the VHDL file is already Set As the Top module in the design, indicated by the icon in front of the **system\_wrapper.vhd**.









"FŐNIX ME" – Megújuló Egyetem felsőoktatási intézményi fejlesztések a felsőfokú oktatás minőségének és hozzáférhetőségének együttes javítása érdekében EFOP 3.4.3-16-2016-00015

4. In the main menu Select File => Export => Hardware and click Next

**Note**: Since we do not have any hardware in Programmable Logic (PL) there is no bitstream to generate, hence the *Include bitstream* option is not necessary at this time. Click **Next**.

5. Name the XSA file to **system\_wrapper** and specify the folder name where the project is created.



Figure 5.2.45: System Wrapper File Created

# Generate Bitstream and Export the bitstream to Vitis

- 1. In the *Flow Navigator* pane **Run Synthesis** if Necessary (Vivado reports *Synthesis Design is Out of Date*).
- 2. In the Flow Navigator pane Run Implementation
- 3. In the Flow Navigator pane run Generate Bitstream

used in the system such as interrupts.

# 5.2.3 Launch Vitis and Generate the Test Application of the project

- 1. In the main menu select Tools => Launch Vitis IDE;
- 2. Specify the workspace and click Launch (Figure 5.2.46)
- 3. On the Vitis welcome screen click Create Platform Project
- 4. In the New Platform Project specify the Platform project name: zed\_system. Figure 5.2.47
- 5. In the **Create a new platform from hardware XSA**. Click **Browse** (5.2.48)to specify the XSA (Xilinx Support Archive) file for the hardware specification. Click **Next**









- The Vitis IDE open with the platform project created (5.2.49). In the menu select File => New => Application Project for creating the application "Hello World". This will open the application project creation wizard (5.2.50). Click Next.
- 7. The next window is the domain selection window. For this first project we create standalone\_domain (without operating system). Click **Next**. See 5.2.51.
- 8. In the new Application project examples select "Hello World" and click **Finish**.
- 9. In the file Explorer window right click on the **zed\_project**. Also expand the *hello\_world\_system* => *hello\_world=> src* and double click on the **hellowolrd.c** .C file to open it in the editor window.
- 10. Edit the **hellowolrd.c** program and add the program lines, which handle the LEDS and the switch IP. The program can be seen in the figure 5.2.56 and 5.2.57. Then save the program. Right click on the *hello\_word\_system* and select **Build project**.
- 11. If you worked with Zybo connect the board to your PC and power on.
- 12. If you worked with the Zedboard start *putty.exe* and login to *"mazsola"* to open a tunnel for the hardware server, where the Zedboard is connected. Also login to the computer *"nyolcas"*.
- 13. For Zybo/Zed open RelTerm serial terminal. Select the UART port *CypresVirtualComO* and setup to *Baud: 115200, Parity: none, Data Bits: 8, Stop Bits: 1* then connect the terminal (Figure 5.1.39).
- 14. In the Main menu select Xilinx →XSCT Console. Then in the console window type *connect* press *Enter*, then type *reset* and press *Enter*. In the XSCT window should be displayed something similar like in 5.1.38.
- 15. In the Explorer window right click on the application project *hello\_world\_system* select *Run as →Run Configurations*. Once the *Run Configurations* windows opens, twice click on *System Project Debug* to create an application debug *SystemDebugger\_hello\_world\_system*(Figure 5.1.39). Then click on *Run*
- 16. "Hello World" appears on the RealTerm Terminal, as shown in the figure (5.1.40).

| Select a directory as                       | workspace                                      |                       |       |
|---------------------------------------------|------------------------------------------------|-----------------------|-------|
| Vitis IDE uses the works                    | space directory to store its preferences and d | evelopment artifacts. |       |
| Workspace: C:\Users\                        | \vajo\Documents\LABs\lab1part2                 | ~                     | rowse |
| workspace. C.(osers)                        | (vajo (bocuments (bAbs (lab ipartz             |                       | nowse |
|                                             |                                                |                       |       |
| Use this as the defau                       | ılt and do not ask again                       |                       |       |
| Use this as the defau<br>Restore other Work | -                                              |                       |       |
| —                                           | space                                          |                       |       |

Figure 5.2.46: Lunch Vitis











Figure 5.2.47: Create New Platform Project

|           | Specificat               | on                                                                                                  |                                    |            |          |
|-----------|--------------------------|-----------------------------------------------------------------------------------------------------|------------------------------------|------------|----------|
| XSA File: | /home/v                  | ajo/xup/zybo/lab1/system_wrapper.xsa                                                                |                                    | -          | Browse   |
| Software  | Specificatio             | in                                                                                                  |                                    |            |          |
| Specify t |                          | or the initial domain to be added to the platform. More domains c                                   | an be after the platform is create | d by doul  | ble      |
|           |                          | standalone 👻                                                                                        |                                    |            |          |
| Processo  |                          | ps7_cortexa9_0                                                                                      |                                    |            |          |
|           |                          |                                                                                                     |                                    |            |          |
| Wollate   | e: A doma<br>er to add n | in with selected operating system and processor will be added to t<br>w domains or change settings. | the platform. The platform projec  | t can be r | modified |
| 9 100     |                          | a domains of change seedings.                                                                       |                                    |            |          |
| Boot com  | onents-                  |                                                                                                     |                                    |            |          |
| ✓ Gene    | rate boot o              | omponents                                                                                           |                                    |            |          |
|           |                          |                                                                                                     |                                    |            |          |
|           |                          |                                                                                                     |                                    |            |          |
|           |                          |                                                                                                     |                                    |            |          |
|           |                          |                                                                                                     |                                    |            |          |
|           |                          |                                                                                                     |                                    |            |          |
|           |                          |                                                                                                     |                                    |            |          |

Figure 5.2.48: Create a new platform from hardware (XSA)











Figure 5.2.49: Vitis IDE with the platform project created



Figure 5.2.50: New Application Project Wizard









| tform<br>he selected platform has unb                   | -               | · · ·                                            |            |                                                                   |
|---------------------------------------------------------|-----------------|--------------------------------------------------|------------|-------------------------------------------------------------------|
| ind:                                                    | epository E Cre | ate a new platform f                             | rom nardwa | + Add 🌣 Manage                                                    |
| Name                                                    | Board           | Flow                                             | Vendor     | Path                                                              |
| 🗳 zybo_system [custom]                                  |                 | Embedded SW Dev                                  | xilinx     | /home/vajo/xup/zybo/lab1/workspace/zybo_system                    |
|                                                         |                 |                                                  |            |                                                                   |
| Platform Info<br>General Info                           | Ac              | cceleration Resources                            |            | Domain Details                                                    |
| Name: zybo_system                                       |                 | cceleration Resources<br>The selected platform d |            | Domains                                                           |
| General Info<br>Name: zybo_system<br>Part: xc7z010clg40 |                 | The selected platform d                          |            | Domains Domain name Details standalone_domain CPU: ps7_cortexa9_0 |
| General Info<br>Name: zybo_system                       |                 | The selected platform d                          |            | Domains Domain name Details                                       |

Figure 5.2.51: Select Platform









"FŐNIX ME" – Megújuló Egyetem felsőoktatási intézményi fejlesztések a felsőfokú oktatás minőségének és hozzáférhetőségének együttes javítása érdekében EFOP 3.4.3-16-2016-00015

| ✓                                               | New Application Project                               | ↑ □ X       |
|-------------------------------------------------|-------------------------------------------------------|-------------|
| Application Project Details                     |                                                       |             |
| Specify the application project name and its sy | stem project properties                               |             |
| Application project name: helo_world            |                                                       |             |
| System Project                                  |                                                       |             |
|                                                 | ation or select an existing one from the workpsace () |             |
|                                                 | System project details                                |             |
| Select a system project                         | System project dedna                                  |             |
| +Create new                                     | System project name: helo_world_system                |             |
|                                                 | Target processor                                      |             |
|                                                 | Select target processor for the Application project.  |             |
|                                                 | Processor Associated applications                     |             |
|                                                 | ps7_cortexa9_0 helo_world                             |             |
|                                                 |                                                       |             |
|                                                 |                                                       |             |
|                                                 |                                                       |             |
|                                                 |                                                       |             |
|                                                 |                                                       |             |
|                                                 | Show all processors in the hardware specification 🗌 🚯 |             |
|                                                 |                                                       |             |
| ?                                               | < Back Next > Ca                                      | ncel Finish |

Figure 5.2.52: Specify the Application Project Name









| ✓                                                                                                           | New Application Project |                                               | <b></b> |     |
|-------------------------------------------------------------------------------------------------------------|-------------------------|-----------------------------------------------|---------|-----|
| Domain<br>Select a domain for your project or create a new dom                                              | ain                     |                                               |         | ••• |
| Select the domain that the application would link to<br>Note: New domain created by this wizard will have a |                         | e application template selected in the next s | tep     |     |
| Select a domain                                                                                             | Domain details          |                                               |         |     |
| standalone_domain                                                                                           |                         |                                               |         |     |
| +Create new                                                                                                 |                         |                                               |         |     |
|                                                                                                             |                         | standalone                                    |         |     |
|                                                                                                             |                         |                                               |         |     |
|                                                                                                             |                         |                                               |         |     |
|                                                                                                             |                         |                                               |         |     |
|                                                                                                             |                         |                                               |         |     |
|                                                                                                             |                         |                                               |         |     |
|                                                                                                             |                         |                                               |         |     |
|                                                                                                             |                         |                                               |         |     |
|                                                                                                             |                         |                                               |         |     |
|                                                                                                             |                         |                                               |         |     |
|                                                                                                             |                         |                                               |         |     |
| ?                                                                                                           |                         | < Back Next > Cance                           |         |     |

Figure 5.2.53: Select domain as standalone\_platform

| ✓                                                                                                                                                                                                                                                                                                                                                           | New Application | Project                                           | ↑ □ ×        |
|-------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|-----------------|---------------------------------------------------|--------------|
| Templates                                                                                                                                                                                                                                                                                                                                                   |                 |                                                   |              |
| Select a template to create your project.                                                                                                                                                                                                                                                                                                                   |                 |                                                   |              |
| Available Templates:                                                                                                                                                                                                                                                                                                                                        |                 |                                                   |              |
| Find:                                                                                                                                                                                                                                                                                                                                                       |                 | Hello World                                       |              |
| SW development templates<br>Dhrystone<br>Empty Application<br>Empty Application (C++)<br>Hello World<br>IwIP TCP Perf Server<br>IwIP TCP Perf Server<br>IwIP UDP Perf Server<br>IwIP UDP Perf Server<br>Memory Tests<br>OpenAMP matrix multiplication Dem<br>OpenAMP RPC Demo<br>Peripheral Tests<br>RSA Authentication App<br>Zynq DRAM tests<br>Zynq FSBL | 10              | <ul> <li>Let's say 'Hello World' in C.</li> </ul> |              |
| 0                                                                                                                                                                                                                                                                                                                                                           |                 | < Back Next > C                                   | ancel Finish |

Figure 5.2.54: Select "Hello World" example project









"FŐNIX ME" – Megújuló Egyetem felsőoktatási intézményi fejlesztések a felsőfokú oktatás minőségének és hozzáférhetőségének együttes javítása érdekében EFOP 3.4.3-16-2016-00015

| 强 Explorer छ                      |                   | Ē | <b>₽</b> ₽ | 2 | 000 |  |
|-----------------------------------|-------------------|---|------------|---|-----|--|
| hello_world_system [ zed_system ] |                   |   |            |   |     |  |
| hello_world [ standalone_domain ] |                   |   |            |   |     |  |
| ▶ 🗊 Includes                      |                   |   |            |   |     |  |
| 🔻 🚖 src                           |                   |   |            |   |     |  |
| helloworld.c                      |                   |   |            |   |     |  |
| ▶ <u>In</u> p                     | latform_config.h  |   |            |   |     |  |
| 🕨 尾 p                             | latform.c         |   |            |   |     |  |
| 🕨 庙 platform.h                    |                   |   |            |   |     |  |
| 🛐 Iscript.ld                      |                   |   |            |   |     |  |
| 📄 Xilinx.spec                     |                   |   |            |   |     |  |
| 🕨 📂 🕨                             | )                 |   |            |   |     |  |
| 💥 hell                            | o_world.prj       |   |            |   |     |  |
| 👗 hello_v                         | world_system.sprj |   |            |   |     |  |
| ▼ 🔄 zed_system (Out-of-date)      |                   |   |            |   |     |  |
| 🕨 🗁 export                        |                   |   |            |   |     |  |
| 🕨 🔁 hw                            |                   |   |            |   |     |  |
| 🕨 👝 logs                          |                   |   |            |   |     |  |
| b ← nc7 cortexaQ 0                |                   |   |            |   |     |  |

Figure 5.2.55: Application project "hello\_world" Explorer view

| 47 |                                                        |
|----|--------------------------------------------------------|
|    | <pre>#include <stdio.h></stdio.h></pre>                |
| 49 | <pre>#include "platform.h"</pre>                       |
| 50 | <pre>#include "xil_printf.h"</pre>                     |
| 51 | <pre>#include "xparameters.h"</pre>                    |
| 52 | <pre>#include "sw_ip.h"</pre>                          |
| 53 | <pre>#include "xgpio.h"</pre>                          |
| 54 | #define LEDs 0x5                                       |
| 55 | <pre>#define LED_CHANNEL 1</pre>                       |
| 56 | <pre>//#define led_device_id XPAR_LEDS_DEVICE_ID</pre> |
| 57 | <pre>int status_LED_GPI0, status_sw;</pre>             |
| EO |                                                        |

Figure 5.2.56: The "Hello World" program include section.









```
60⊖ int main()
61 {
62
        //char led = LEDs;
63
       XGpio dip, Gpio;
64
        char led = LEDs;
65
        char dip check;
66
67
        init_platform();
68
        // sw initialize
69
       //XGpio Initialize(&dip, XPAR SW IP DEVICE ID);
70
        //XGpio SetDataDirection(&dip, 1, 0xfffffff);
71
        // leds init
72
       // LED PL
73
            /* GPIO driver initialisation */
74
        status LED GPIO = XGpio Initialize(&Gpio, XPAR SW IP DEVICE ID);
75
       if (status LED GPIO != XST SUCCESS) {
76
            xil_printf("GPIO output to the LEDs failed!\r\n");
77
                }
78
            /*Set the direction for the LEDs to output. */
79
        xil printf ("GPIO leds %x\r\n", status LED GPIO);
80
       XGpio SetDataDirection(&Gpio, LED CHANNEL, 0x00);
81
82
        print("Hello World\n\r");
83
       print("Successfully ran Hello World application\r\n");
84
       while (1)
85
            {
86
              //SW_IP_mReadReg(&dip, unsigned RegOffset)
              //dip_check = SW_IP_mReadReg(&dip, 0);
87
              //xil_printf("Switch Status %x\r\n", dip_check);
88
89
              XGpio_DiscreteWrite(&Gpio, LED_CHANNEL, led);
90
              xil_printf("led %lx\r\n", 0x0f&led);
91
              led = ~led;
92
              dip_check = SW IP_mReadReg(XPAR_SW IP_S00_AXI_BASEADDR, 0);
93
              xil_printf("switch %lx\r\n", dip_check);
94
              sleep(1);
95
            }
96
97
        cleanup platform();
98
        return 0;
99
   }
```

Figure 5.2.57: The application program for lab3









| 堶 RealTerm: Serial Ca                                                                          | pture Program 2.0.0.70 |                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                |       | -         |                                                                                                                                                              | Х                                  |
|------------------------------------------------------------------------------------------------|------------------------|--------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|-------|-----------|--------------------------------------------------------------------------------------------------------------------------------------------------------------|------------------------------------|
| Display Port Capture                                                                           | Pins Send Echo Pot 12C | 12C-2   12CMisc   Misc                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                         | 1 a   | Close     | Freeze                                                                                                                                                       | 2                                  |
| Baud 115000 Port<br>Parity Data Bits<br>© None C 7 bits<br>C Even C 5 bits<br>C Space C 5 bits | 6 = \CypressVitualCom0 | Spy Change With Change With Control Co |       |           | Status           Conne           RXD (;           TXD (;           CTS (;           DCD (;           DCD (;           DSR (;           BREAL           Error | cted<br>2)<br>))<br>))<br>))<br>)) |
|                                                                                                |                        | Char Count:0                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                   | CPS:0 | Port: 157 | 600 8N1 No                                                                                                                                                   | ne /                               |

Figure 5.2.58: RealTerm terminal setup

| led A switch F<br>led 5<br>switch F<br>led A switch F                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                            | input. | -              |              |               |                     |   | Li |
|------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|--------|----------------|--------------|---------------|---------------------|---|----|
| switch F<br>led 5<br>switch F<br>led A<br>switch F<br>led 5<br>switch B<br>led 5<br>switch B<br>led 5<br>switch B<br>led 4<br>switch B<br>led 5<br>switch B<br>led 5<br>switch B<br>led 5<br>switch B<br>led 5<br>switch B<br>led 4<br>switch B<br>led 5<br>switch B<br>led 4<br>switch B<br>led 5<br>switch B<br>led 5<br>switch B<br>led 4<br>switch B<br>led 4<br>switch B<br>led 5<br>switch B<br>led 5<br>switch B<br>led 5<br>switch B<br>led 4<br>switch B<br>led 5<br>switch B<br>led 5<br>switch B<br>led 5<br>switch B<br>led 5<br>switch B<br>led 5<br>switch B<br>led 5<br>switch B<br>led 4<br>switch B<br>led 5<br>switch B<br>led 7<br>switch B<br>led 7<br>switch B<br>led 7<br>switch B<br>led 7<br>switch B<br>led 7<br>switch B<br>led 7<br>switch B<br>switch B<br>swit |        | F              |              |               |                     | - |    |
| led 5<br>switch F<br>led A<br>switch F<br>led 5<br>switch B<br>led 4<br>switch B<br>led 4<br>switch B<br>led 4<br>switch B<br>led 5<br>switch B<br>led 4<br>switch B<br>led 4<br>switch B<br>led 4<br>switch B<br>led 4<br>switch B<br>led 4<br>switch B<br>led 5<br>switch B<br>led 5<br>switch B<br>led 4<br>switch B<br>led 4<br>switch B<br>led 5<br>switch B<br>led 5<br>switch B<br>led 5<br>switch B<br>led 5<br>switch B<br>led 5<br>switch B<br>switch B<br>led 5<br>switch B<br>switch B                  |        |                |              |               |                     |   | st |
| led 3   switch F   led 4   switch F   led 5   switch B   led 4   switch B   led 5   switch B   led 4   switch B   led 5   switch B   led 5   switch B   led 5   switch B   led 5   switch B   led 4   switch B   led 5   switch B   led 4   switch B   led 5   switch B   led 4   switch B   led 5   switch B                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                    |        | F              |              |               |                     |   | m  |
| led A         switch F         led A         switch B         led A                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                    |        | -              |              |               |                     |   |    |
| switch F<br>led 5<br>switch F<br>led A<br>switch B<br>led 5<br>switch B<br>led 5<br>switch B<br>led 4<br>switch B<br>led 4<br>switch B<br>led 5<br>switch B<br>switch B<br>s                   |        | . F            |              |               |                     |   |    |
| switch B<br>led A<br>switch B<br>led A<br>switch B<br>led 5<br>switch B<br>led 5<br>switch B<br>led 5<br>switch B<br>led 5<br>switch B<br>led 5<br>switch B<br>led 5<br>switch B<br>led 4<br>switch B<br>led 5<br>switch B<br>switch B<br>led 5<br>switch B<br>switch B<br>swit                   |        | -              |              |               |                     |   |    |
| switch F<br>led A<br>switch B<br>led 5<br>switch B<br>led 4<br>switch B<br>led 5<br>switch B<br>led 5<br>switch B<br>led 4<br>switch B<br>led 4<br>switch B<br>led 5<br>switch B<br>led 4<br>switch B<br>led 4<br>switch B<br>led 4<br>switch B<br>led 4<br>switch B<br>led 4<br>switch B<br>led 4<br>switch B<br>led 5<br>switch B<br>led 4<br>switch B<br>led 5<br>switch B<br>led 4<br>switch B<br>led 4<br>switch B<br>led 4<br>switch B<br>led 4<br>switch B<br>led 4<br>switch B<br>led 5<br>switch B<br>led 5<br>switch B<br>led 5<br>switch B<br>led 5<br>switch B<br>led 4<br>switch B<br>led 5<br>switch B<br>led 5<br>switch B<br>led 4<br>switch B<br>switch B<br>swi                       | Switci | - F            |              |               |                     |   |    |
| Switch B<br>led A<br>switch B<br>led 5<br>switch B<br>led 5<br>switch B<br>led 4<br>switch B<br>led 5<br>switch B<br>led 5<br>switch B<br>led 5<br>switch B<br>led 5<br>switch B<br>led 4<br>switch B                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                            |        | -              |              |               |                     |   |    |
| switch B<br>led 5<br>switch B<br>led A<br>switch B<br>led 5<br>switch B<br>led A<br>switch B<br>led A<br>switch B<br>led A<br>switch B<br>led A<br>switch B<br>led A<br>switch B                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                 | Switch | F              |              |               |                     |   |    |
| led 5         switch B         led A         switch B         led A         switch B         led 5         switch B         led 4         switch B         led 5         switch B         led 4         switch B         led 5         switch B         switc                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                  |        |                |              |               |                     |   |    |
| ied 3         switch B         ied 4         switch B         ied 5         switch B         ied 4         switch B         ied 4         switch B                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                     |        | в              |              |               |                     |   |    |
| Switch B<br>led A<br>switch B<br>led 5<br>switch B<br>led 5<br>switch B<br>led 5<br>switch B<br>led 5<br>switch B<br>led 4<br>switch B                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                           | leas   | -              |              |               |                     |   |    |
| switch B<br>led 5<br>switch B<br>led A<br>switch B<br>led 5<br>switch B<br>led 5<br>switch B<br>led 5<br>switch B<br>led 4<br>switch B<br>led 4<br>switch B<br>led 5<br>switch B<br>led 6<br>switch B<br>led 7<br>switch B<br>led 7<br>switch B<br>led 7<br>switch B<br>led 7<br>switch B<br>led 7<br>switch B<br>led 7<br>switch B<br>switch B<br>led 7<br>switch B<br>led 7<br>switch B<br>led 7<br>switch B<br>led 7<br>switch B<br>led 7<br>switch B<br>switch B<br>switch B<br>led 7<br>switch B<br>switch B<br>swi                                         | Switch | в              |              |               |                     |   |    |
| led 5<br>switch B<br>led A<br>switch B<br>led 5<br>switch B<br>led 4<br>switch B<br>led 5<br>switch B<br>led 4<br>switch B                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                       |        |                |              |               |                     |   |    |
| led S<br>switch B<br>led A<br>switch B<br>led 5<br>switch B<br>led 5<br>switch B<br>led 5<br>switch B<br>led 4<br>switch B                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                       |        | в              |              |               |                     |   |    |
| led A<br>switch B<br>led 5<br>switch B<br>led A<br>switch B<br>led 5<br>switch B<br>led A                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                        | lea 5  | -              |              |               |                     |   |    |
| switch B<br>led 5<br>switch B<br>led A<br>switch B<br>led A<br>switch B<br>led A<br>switch B                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                     |        | в              |              |               |                     |   |    |
| led 5<br>switch B<br>led A<br>switch B<br>led 5<br>switch B<br>led A<br>switch B                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                 |        |                |              |               |                     |   |    |
| switch B<br>led A<br>switch B<br>led 5<br>switch B<br>led A<br>switch B                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                          |        | в              |              |               |                     |   |    |
| vitch B<br>led 5<br>switch B<br>led A<br>switch B                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                | led 5  |                |              |               |                     |   |    |
| vitch B<br>led 5<br>switch B<br>led A<br>switch B                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                | switch | в              |              |               |                     |   |    |
| led 5<br>switch B<br>led A<br>switch B                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                           | IEU A  | _              |              |               |                     |   |    |
| switch B<br>led A<br>switch B                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                    |        | в              |              |               |                     |   |    |
| switch B                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                         |        |                |              |               |                     |   |    |
| switch B                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                         | Switci | в              |              |               |                     |   |    |
|                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                  |        | _              |              |               |                     |   |    |
|                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                  | switch | в              |              |               |                     |   |    |
| Clear Hex output Logging to: /home/vajo/cutecom.log                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                              |        |                |              |               |                     | - |    |
|                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                  | Cle    | ar He <u>x</u> | output 🗌 Log | ging to: /hor | ne/vajo/cutecom.log |   | 1  |
| Device: Digilent Digilent Adept USB Device @ttyUSB1 Connection: 115200 @ 8-N-1                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                   |        |                |              |               |                     |   |    |

Figure 5.2.59: Lab 3 program run result terminal widow.

In the part 1 of the laboratory work 1 (called Lab1) we passed through the steps, which have to be done for each embedded system project using Zynq architecture. True there were not explained the steps. Detailed information about the development process and "what to do and why to do" are explained in the Xilinx documentations (search for User Guides ug940, ug1165). For other information,









"FŐNIX ME" – Megújuló Egyetem felsőoktatási intézményi fejlesztések a felsőfokú oktatás minőségének és hozzáférhetőségének együttes javítása érdekében EFOP 3.4.3-16-2016-00015

tutorials and video tutorials start the DocNav (Document Navigator), installed together with the Vitis installation. In Lab 2 there was presented the hardware design with Vivado IP library and lab3 presented the steps how to create a user specified IP Some of previously presented "Hello World" project material are based on Xilinx XUP (Xilinx University Program) and other tutorials such as ug1165 material [Xil18a].









## **Chapter 6**

# **Directed Projects**

For both projects presented in this chapter, a laboratory configuration has been set and is showed in Figure 6.0.1



Figure 6.0.1









### 6.1 Project 1: GPS parsing using SoC for Position Determination. Simulation then HW/SW Implementation

The goal of this work is to create an embedded system based on SoC and a GPS module to extract and display GPS coordinates.

#### Software Requirements:

Vivado Serial Terminal (eg Realterm, TeraTerm, PuTTY...) com0com (free virtual serial port) Any IDE for C/C++ simulation

Hardware Requirements:

ZedBoard GPS module 1Hz

### 6.1.1 Phase 1: Coding and Simulation

Taking into account that the final goal is to reach the implementation in ZYNQ SoC, it is advisable to code in C/C++ in order that it will be easier to implement on hardware. Other languages can be used but it is on the risk of the students since it is harder to find open resources and support. It is sad to see that the simulation is working on a language then getting trouble to find the useful tools for the hardware implementation. For ZYNQ the most used high level languages are C/C++ and MATLAB, then comes Python recently adopted.

The first checkpoint is to show me the simulation, if validated, you can start the hardware implementation phase

(please carefully read and understand the phase 2 too)

Data coming from GPS module are logged (see appendices), then 2 files are generated for you: one contains a 10 seconds text sent by the GPS module in case of a stable status of the module with full information, and a second text was sent by the same module in unstable situation because of some artifacts (e.g. number of satellites is not enough, noise...). Your design should consider both situations. Consider that the coordinates should be displayed in the following format:

(Latitude: -18.836228, Longitude: -159.782770)

#### 6.1.2 Phase 2: Hardware design, Implementation and Test

During this step you should design the hardware of the solution, adapt your C/C++ program to the xilinx SDK syntax (including the necessary and compatible libraries/drivers).

It is allowed to only use PS for this purpose. But I give extra points for those who use PL as a hardware accelerator to compute GPS data after collection through UART.









### 6.2 Project 2: Remote DC Motor Control using SoC and Hall effect Sensor

The aim of this project is to precisely control a DC motor using Zybo and hall effect sensor.

#### Statement

The shaft of the DC motor has to perform a complete rotation than changes the direction to perform another complete rotation then change again the direction (loop). The rotation speed should be low (around half rotation per second). (Figure 6.0.1 shows the required setup for the project) The motor driver (Motor Shield V2.0 based on L298 double H bridge chip) is connected to PMOD C. The PWM signal should pass through the port JC2. JC3 and JC4 are for setting the direction of the motor. The hall effect sensor provides a square signal whose frequency is proportional to the speed of rotation of the motor. The sensor is connected to JB2 port. For one rotation of the shaft, there should be 700 impulses sent to the zybo.









# Chapter 7

## Exercises

### 7.1 Multiple Choice Quizzes

- 1) DAC is used for
  - □ converting analog signals to digital signals
  - □ generating periodic signals
  - $\Box$  generating sine wave signals
- 2) ADC converts
  - □ a continuous-time signal to discrete-time signal
  - □ a continuous-amplitude signal to discrete-amplitude signal
- 3) Conversion time is:
  - □ measured in samples per second
  - $\hfill\square$  the inverse of the conversion rate
  - $\hfill\square$  the sum of sampling time and quantization time and coding time
- 4) Conversion rate is
  - $\hfill\square$  measured in samples per second
  - $\hfill\square$  the inverse of the sampling time
- 5) Suppose Ts1 and Ts2 are sampling periods of respectively ADC1 and ADC2 where Ts1>Ts2.
  - □ ADC1 performs better conversions than ADC2
  - $\hfill\square$  ADC2 performs better conversions than ADC1









- □ The change of sampling period does not affect the quality of the conversion
- 6) A comparator is a
  - □ 1bit ADC
  - □ 2bit ADC
  - □ multiplexer
  - □ Analog component
- 7) (Justify your answer(s)) SOC is a
  - □ Software on Chip
  - □ System on Chip
  - □ Single Chip Component
  - □ Integrated Circuit
  - □ Embedded System
- 8) (Justify your answer(s)) Deign productivity gap
  - $\hfill\square$  means: design productivity outpaces chip complexity
  - □ means: chip complexity outpaces design productivity
  - $\hfill\square$  means: the number of transistors per chip increases faster than the number of transistors per staff-month
  - $\hfill\square$  could be reduced by integrating IPs

### 7.2 Questions

1) In order to have an embedded system based on two noisy sensors:

- a) what can you suggest to put between ADC and sensors? (Suggest three elements)
- b) explain your choice
- c) draw a qualitative schematic of the solution

2) What can be the difference between a sensor and an actuator?

- 3) Give examples of 2 actuators and define the input and the output of each one.
- 4) Give 3 types of analog-to-digital converters. Mention the fastest ADC you know.

5) Give an alternative term to "voltage resolution"

6) What is the voltage resolution of a 3bit ADC if  $V_{ref} = 4V$  ?

7) Why an ADC is required for most of embedded systems based on analog sensors ? (in a short sentence)

8) Here is a signal (figure 7.2.1):









- a) is it a time domain or frequency domain representation ?
- b) what type of signal (waveform) is ?
- c) give the period and the frequency of this signal.
- d) what are the maximal and minimal amplitudes of this signal ?



Figure 7.2.1

9) Suggest a schematic of a typical data acquisition/processing/displaying system (from physical quantity capture to display)

10) Consider a LED brightness controller (as shown in figure 7.2.2) as an embedded computer system based on rotational potentiometer.



Figure 7.2.2

a) What are the inputs of the controller?

b) What are the inputs and outputs of the whole system?

c) By describing the missing component, suggest two solutions to change the brightness of the LED

d) Then, what will be the output of the controller for every solution you suggest?

e) Suggest a completely different configuration to set the brightness of the LED. (by schematic)

11) Consider an Analog-to-Digital Converter having the following properties: 16-bit resolution and  $V_{ref} = 2.5V$ . A temperature sensor is connected the ADC and delivers 900mV for an unknown temperature.









"FŐNIX ME" – Megújuló Egyetem felsőoktatási intézményi fejlesztések a felsőfokú oktatás minőségének és hozzáférhetőségének együttes javítása érdekében EFOP 3.4.3-16-2016-00015

Assuming that at  $20^{o}C$  the sensor delivers 700mV and the sensitivity is  $40mV/^{o}C$ , what are the unknown temperature and the output of the ADC ?

- 12) Give 3 common points and 3 differences between  $\mu C$ ,  $\mu P$  and SoC
- 13) What is the resolution of an ADC if the Vref = 4V and VLSB = 250mV ?
- 14) Give a title to the figure 7.2.3



Figure 7.2.3

15) Make a qualitative drawing of a 2 bits digitalized sine wave.

16) What is the minimal wiring connection required for a full-duplex communication on UART? (illustrate by schematic)

17) Let be the figure 7.2.4



Figure 7.2.4

a) what type of waveform is the continuous signal represented in the figure?

b) give the Period, the Frequency and the Peak-to-Peak voltage of the continuous signal

c) what represents the discrete signal on the figure?

d) give its Sampling Period, Sampling Frequency, Resolution and Quantum

c) in this case, are the frequency components of this signal aliased? (Justify your answer)

18) For the purpose of measuring the depth of a diver, you need to create a low-cost, low power and small size embedded system which has the purpose of indicating to the diver if the depth is less or more









"FŐNIX ME" – Megújuló Egyetem felsőoktatási intézményi fejlesztések a felsőfokú oktatás minőségének és hozzáférhetőségének együttes javítása érdekében EFOP 3.4.3-16-2016-00015

than 3m. Two LEDs are the indicators such that if the level is less than 3m, the red LED should light up and the green LED lights off, and vice versa... You open your locker, (ignoring the packaging parts) you find: - a red LED and a green LED,

- 2 analog pressure sensors; sensorA and sensorB (their behavior is described on figure 7.2.5)
- $\mu C$
- $\mu P$

- Some ICs (ADC, PWM, Comparator, Logic Inverter, Variable Reference Voltage)

- LCD
- Battery





Assuming that the depth can be expressed with the figure 7.2.6



Figure 7.2.6

a) Propose two different solutions for the same purpose by drawing bloc diagrams justifying every choice of the components.









"FŐNIX ME" – Megújuló Egyetem felsőoktatási intézményi fejlesztések a felsőfokú oktatás minőségének és hozzáférhetőségének együttes javítása érdekében EFOP 3.4.3-16-2016-00015

b) Give a detailed explanation of the process. (A code is also allowed (to support your answer) if is followed by detailed comments).

19) Assuming you have an infinite budget, propose a completely different solution for the same purpose by means of the same LEDs (red and green).

20) We are trying to make a communication between two devices via UART in order to transmit the character "b". The UART setup is 115200/8/1/N

- a) Draw the equivalent frame to perform the communication
- b) Define every parameter of the abbreviation 115200/8/1/N
- c) What is the necessary time to send the entire frame?
- d) Draw the frame if the communication is based on RS232 instead of UART









# **Appendix A**

# **Additional Content**

### A.1 GPS Data

### A.1.1 10 seconds 1Hz GPS NMEA (correct data)

\$GPGGA,084356.00,4804.98959,N,02046.07578,E,1,06,1.90,139.3,M,38.1,M,,\*5D \$GPGSA,A,3,31,01,04,21,11,32,,,,,3.02,1.90,2.34\*0B \$GPGSV,2,1,08,01,74,155,25,04,33,206,29,08,01,184,07,09,00,218,\*7C \$GPGSV,2,2,08,11,35,173,27,21,43,145,33,31,28,088,33,32,18,047,24\*76 \$GPGLL,4804.98959,N,02046.07578,E,084356.00,A,A\*64 \$GPRMC,084357.00,A,4804.98967,N,02046.07574,E,0.028,,041120,,,A\*71 \$GPVTG,,T,,M,0.028,N,0.052,K,A\*2E \$GPGGA,084357.00,4804.98967,N,02046.07574,E,1,06,1.90,139.6,M,38.1,M,,\*58 \$GPGSA,A,3,31,01,04,21,11,32,,,,,3.02,1.90,2.34\*0B \$GPGSV,2,1,08,01,74,155,25,04,33,206,29,08,01,184,07,09,00,218,\*7C \$GPGSV,2,2,08,11,35,173,27,21,43,145,32,31,28,088,33,32,18,047,24\*77 \$GPGLL,4804.98967,N,02046.07574,E,084357.00,A.A\*64 \$GPRMC,084358.00,A,4804.98969,N,02046.07574,E,0.057,,041120,,,A\*78 \$GPVTG,,T,,M,0.057,N,0.106,K,A\*26 \$GPGGA,084358.00,4804.98969,N,02046.07574,E,1,06,1.90,140.0,M,38.1,M,\*51 \$GPGSA,A,3,31,01,04,21,11,32,,,,,3.02,1.90,2.34\*0B \$GPGSV,2,1,08,01,74,155,24,04,33,206,29,08,01,184,,09,00,218,\*7A \$GPGSV,2,2,08,11,35,173,27,21,43,145,32,31,28,088,33,32,18,047,24\*77 \$GPGLL,4804.98969,N,02046.07574,E,084358.00,A,A\*65 \$GPRMC,084359.00,A,4804.98974,N,02046.07573,E,0.107,,041120,,,A\*76 \$GPVTG,,T,,M,0.107,N,0.199,K,A\*24 \$GPGGA,084359.00,4804.98974,N,02046.07573,E,1,06,1.90,140.5,M,38.1,M,,\*5E \$GPGSA,A,3,31,01,04,21,11,32,,,,,3.02,1.90,2.35\*0A \$GPGSV,2,1,08,01,74,155,23,04,33,206,29,08,01,184,,09,00,218,\*7D \$GPGSV,2,2,08,11,35,173,27,21,43,145,32,31,28,088,33,32,18,047,24\*77 \$GPGLL,4804.98974,N,02046.07573,E,084359.00,A,A\*6F \$GPRMC,084400.00,A,4804.98975,N,02046.07577,E,0.330,,041120,,,A\*7E \$GPVTG,,T,,M,0.330,N,0.611,K,A\*25 \$GPGGA,084400.00,4804.98975,N,02046.07577,E,1,06,1.90,141.0,M,38.1,M,,\*54 \$GPGSA,A,3,31,01,04,21,11,32,,,,,,3.02,1.90,2.35\*0A \$GPGSV,2,1,08,01,74,155,22,04,33,206,28,08,01,184,,09,00,218,\*7D









\$GPGSV,2,2,08,11,35,173,27,21,43,145,32,31,28,088,33,32,18,047,25\*76 \$GPGLL.4804.98975.N.02046.07577.E.084400.00.A.A\*61 \$GPRMC,084401.00,A,4804.98986,N,02046.07569,E,0.213,,041120,,,A\*7C \$GPVTG,,T,,M,0.213,N,0.394,K,A\*2D \$GPGGA,084401.00,4804.98986,N,02046.07569,E,1,06,1.90,141.5,M,38.1,M,,\*53 \$GPGSA,A,3,31,01,04,21,11,32,,,,,3.02,1.90,2.35\*0A \$GPGSV,2,1,08,01,74,155,21,04,33,206,28,08,01,184,,09,00,218,\*7E \$GPGSV,2,2,08,11,35,173,26,21,43,145,32,31,28,088,32,32,18,047,25\*76 \$GPGLL,4804.98986,N,02046.07569,E,084401.00,A,A\*63 \$GPRMC,084402.00,A,4804.98996,N,02046.07563,E,0.062,,041120,,,A\*70 \$GPVTG,,T,,M,0.062,N,0.115,K,A\*22 \$GPGGA,084402.00,4804.98996,N,02046.07563,E,1,06,1.90,142.1,M,38.1,M,,\*5C \$GPGSA,A,3,31,01,04,21,11,32,,,,,3.02,1.90,2.35\*0A \$GPGSV,2,1,08,01,74,155,22,04,33,206,28,08,01,184,,09,00,218,\*7D \$GPGSV,2,2,08,11,35,173,26,21,43,145,32,31,28,088,32,32,18,047,25\*76 \$GPGLL,4804.98996,N,02046.07563,E,084402.00,A,A\*6B \$GPRMC,084403.00,A,4804.99008,N,02046.07557,E,0.107,,041120,,,A\*7B \$GPVTG,,T,,M,0.107,N,0.197,K,A\*2A \$GPGGA,084403.00,4804.99008,N,02046.07557,E,1,06,1.90,142.7,M,38.1,M,,\*53 \$GPGSA,A,3,31,01,04,21,11,32,,,,,,3.02,1.90,2.35\*0A \$GPGSV,2,1,08,01,74,155,21,04,33,206,28,08,01,184,,09,00,218,\*7E \$GPGSV,2,2,08,11,35,173,26,21,43,145,31,31,28,088,32,32,18,047,25\*75 \$GPGLL,4804.99008,N,02046.07557,E,084403.00,A,A\*62 \$GPRMC,084404.00,A,4804.99013,N,02046.07555,E,0.017,,041120,,,A\*74 \$GPVTG,,T,,M,0.017,N,0.031,K,A\*27 \$GPGGA,084404.00,4804.99013,N,02046.07555,E,1,06,1.90,143.0,M,38.1,M,,\*5A \$GPGSA,A,3,31,01,04,21,11,32,,,,,3.02,1.90,2.35\*0A \$GPGSV,2,1,08,01,74,155,21,04,33,206,28,08,01,184,,09,00,218,\*7E \$GPGSV,2,2,08,11,35,173,26,21,43,145,31,31,28,088,32,32,18,047,25\*75 \$GPGLL,4804.99013,N,02046.07555,E,084404.00,A,A\*6D \$GPRMC,084405.00,A,4804.99021,N,02046.07544,E,0.043,,041120,,,A\*75 \$GPVTG,,T,,M,0.043,N,0.079,K,A\*2A \$GPGGA,084405.00,4804.99021,N,02046.07544,E,1,06,1.90,143.3,M,38.1,M,,\*59 \$GPGSA,A,3,31,01,04,21,11,32,,,,,3.02,1.90,2.35\*0A \$GPGSV,2,1,08,01,74,155,22,04,33,206,28,08,01,184,,09,00,218,\*7D \$GPGSV,2,2,08,11,35,173,26,21,43,145,31,31,28,088,32,32,18,047,25\*75 \$GPGLL,4804.99021,N,02046.07544,E,084405.00,A,A\*6D \$GPRMC,084406.00,A,4804.99032,N,02046.07518,E,0.277,,041120,,,A\*78 \$GPVTG,,T,,M,0.277,N,0.514,K,A\*21

#### A.1.2 10 seconds 1Hz GPS NMEA (incorrect data)

\$GPGGA,,,,,0,00,99.99,,,,,\*48 \$GPGSA,A,1,,,,,99.99,99.99,99.99.99.30 \$GPGSV,1,1,00\*79 \$GPGCL,,,,,V,N\*64 \$GPRMC,V,,,,,,N\*53 \$GPVTG,,,,,,N\*30 \$GPGGA,,,0,0,99.99,,,,\*48 \$GPGSA,A,1,,,,,99.99,99.99,99.99\*30 \$GPGSV,1,1,00\*79 \$GPGSU,1,1,00\*79 \$GPGLL,,,,V,N\*64 \$GPTXT,01,01,02,ANTSTATUS=INIT\*25 \$GPRMC,V,,,,,,N\*53









\$GPVTG,,,,,N\*30 \$GPGGA,,,,,0,00,99.99,,,,,\*48 \$GPGSA,A,1,,,,,,99.99,99.99,99.99\*30 \$GPGSV,1,1,00\*79 \$GPGLL,,,,,V,N\*64 \$GPTXT,01,01,02,ANTSTATUS=OK\*3B \$GPRMC,,V,,,,,,,,N\*53 \$GPVTG,,,,,N\*30 \$GPGGA,,,,,0,00,99.99,,,,,\*48 \$GPGSA,A,1,,,,,,,99.99,99.99,99.99\*30 \$GPGSV,1,1,00\*79 \$GPGLL,,,,,V,N\*64 \$GPRMC,,V,,,,,,,N\*53 \$GPVTG,,,,,,N\*30 \$GPGGA,,,,,0,00,99.99,,,,,\*48 \$GPGSA,A,1,,,,,,,99.99,99.99,99.99\*30 \$GPGSV,1,1,00\*79 \$GPGLL,,,,,V,N\*64 \$GPRMC,,V,,,,,,,N\*53 \$GPVTG,,,,,,N\*30 \$GPGGA,,,,,0,00,99.99,,,,,\*48 \$GPGSA,A,1,,,,,,99.99,99.99,99.99\*30 \$GPGSV,1,1,00\*79 \$GPGLL,,,,,V,N\*64 \$GPRMC,,V,,,,,,,N\*53 \$GPVTG,,,,,,N\*30 \$GPGGA,,,,,0,00,99.99,,,,,\*48 \$GPGSA,A,1,,,,,,,,99.99,99.99,99.99\*30 \$GPGSV,1,1,00\*79 \$GPGLL,,,,,V,N\*64 \$GPRMC,,V,,,,,,,N\*53 \$GPVTG,,,,,N\*30 \$GPGGA,,,,,0,00,99.99,,,,,\*48 \$GPGSA,A,1,,,,,,99.99,99.99,99.99\*30 \$GPGSV,1,1,00\*79 \$GPGLL,,,,V,N\*64 \$GPRMC,,V,,,,,,,N\*53 \$GPVTG,,,,,N\*30 \$GPGGA,,,,,0,00,99.99,,,,,\*48 \$GPGSA,A,1,,,,,,99.99,99.99,99.99\*30 \$GPGSV,1,1,00\*79 \$GPGLL,,,,V,N\*64 \$GPRMC,,V,,,,,,,N\*53 \$GPVTG,,,,,N\*30 \$GPGGA,,,,,0,00,99.99,,,,,\*48 \$GPGSA,A,1,,,,,,99.99,99.99,99.99\*30 \$GPGSV,1,1,00\*79 \$GPGLL,,,,V,N\*64 \$GPRMC,,V,,,,,,,N\*53 \$GPVTG,,,,,N\*30









# Bibliography

- [ARMa] ARM. Amba documentation, https://developer.arm.com/architectures/system-architectures/amba.
- [ARMb] ARM. Cortex a9 revision: r4p1 technical reference manual, https://developer.arm.com/documentation/ddi0407/g.
- [CEES14] Louise Helen Crockett, Ross Elliot, Martin Enderwitz, and Robert Stewart. *The Zynq Book: Embedded Processing with the Arm Cortex-A9 on the Xilinx Zynq-7000 All Programmable Soc.* Strathclyde Academic Media, 2014.
- [CGL<sup>+</sup>20] Marcello Coppola, Miltos D Grammatikakis, Riccardo Locatelli, Giuseppe Maruccia, and Lorenzo Pieralisi. *Design of cost-efficient interconnect processing units: Spidergon STNoC.* CRC press, 2020.
- [Cor76] Intel Corp. Data Catalog. 1976.
- [Dig21a] Digilent. Zedboard, hardware user's guide, 2021.
- [Dig21b] Digilent. Zybo z7 reference manual, 2021.
- [GD99] Göran Herrman Gerd Dost. Entwurf und Technologie von Mikroprozessoren. Fachbuchverlag Leipzig, 1999.
- [GK83] Daniel D Gajski and Robert H Kuhn. New vlsi tools. Computer, 16(12):11–14, 1983.
- [HKM08] Takuji Hara, Norio Kambayashi, and Noboru Matsushima. Industrial innovation in Japan. Routledge, 2008.
- [Jr.07] George M. Phillips Jr. The Collector's guide to Vintage Intel Microchips. 2007.
- [KS13] Abderahman Kriouile and Wendelin Serwe. Formal analysis of the ace specification for cache coherent systems-on-chip. In International Workshop on Formal Methods for Industrial Critical Systems, pages 108–122. Springer, 2013.
- [Mak02] Tsugio Makimoto. The hot decade of field programmable technologies. In 2002 IEEE International Conference on Field-Programmable Technology, 2002.(FPT). Proceedings., pages 3–6. IEEE, 2002.
- [Moo98] Gordon E Moore. Cramming more components onto integrated circuits. Proceedings of the IEEE, 86(1):82-85, 1998.
- [Pre14] Intel Free Press. Apple watch revealed: The original, https://newsroom.intel.com/editorials/apple-watch-revealed-iwatch-intelmicroma, Sep 2014.
- [SSW04] Andrew Sloss, Dominic Symes, and Chris Wright. ARM system developer's guide: designing and optimizing system software. Elsevier, 2004.
- [STGH19] Sahil Shah, Hakan Töreyin, Cihan Berk Güngör, and Jennifer Hasler. A real-time vital-sign monitoring in the physical domain on a mixed-signal reconfigurable platform. *IEEE transactions on biomedical circuits and systems*, 13(6):1690–1699, 2019.
- [tec] Two new apple socs, two market events: Apple a14 and m1, https://www.techinsights.com/ja/node/33562.
- [VSM01] Andrew M Volk, Peter A Stoll, and Paul Metrovich. Recollections of early chip development at intel. Intel Technology journal, 2001.
- [Xil] Embedded system design flow on zynq using vivado, https://www.xilinx.com/support/university/vivado/vivadoworkshops/vivado-embedded-design-flow-zynq.html.
- [Xil18a] Xilinx. Lab workbook, use vivado to build an embedded system, https://www.xilinx.com/support/university/vivado/vivadoworkshops/vivado-embedded-design-flow-zynq.html, 2018.









