

# Developing Zynq Software

With Xilinx Software Development Kit 2017.4



SPEEDWAY

AVNET®

Reach Further™

15 February 2018



AVNET®

[www.minized.org](http://www.minized.org)

# SDK Application Development Flow



# Objectives

---

- Introduce developers to Xilinx SDK
- Explore how SDK makes your job easier
- Connect SDK to hardware for execution and debug
- Utilize a peripheral interrupt to show real-time software response
- Show a basic example of how to use an external sensor module

# Agenda

| Lecture    | Description                       | Labs   |
|------------|-----------------------------------|--------|
| Chapter 1  | Zynq System Architecture Basics   | Lab 1  |
| Chapter 2  | Xilinx SDK Overview               | Lab 2  |
| Chapter 3  | Standalone Board Support Package  | Lab 3  |
| Chapter 4  | Developing Applications           | Lab 4  |
| Chapter 5  | Connecting Hardware and Debugging | Lab 5  |
| Chapter 6  | First Stage Boot Loader           | Lab 6  |
| Chapter 7  | Flash Programming and Boot-up     | Lab 7  |
| Chapter 8  | SDK Project Management            | Lab 8  |
| Chapter 9  | Interrupts                        | Lab 9  |
| Chapter 10 | Xilinx Libraries                  | Lab 10 |
| Chapter 11 | TE Sensor Pmod                    | Lab 11 |
| Chapter 12 | Next Steps                        |        |

# Agenda

| Lecture    | Description                       | Labs   |
|------------|-----------------------------------|--------|
| Chapter 1  | Zynq System Architecture Basics   | Lab 1  |
| Chapter 2  | Xilinx SDK Overview               | Lab 2  |
| Chapter 3  | Standalone Board Support Package  | Lab 3  |
| Chapter 4  | Developing Applications           | Lab 4  |
| Chapter 5  | Connecting Hardware and Debugging | Lab 5  |
| Chapter 6  | First Stage Boot Loader           | Lab 6  |
| Chapter 7  | Flash Programming and Boot-up     | Lab 7  |
| Chapter 8  | SDK Project Management            | Lab 8  |
| Chapter 9  | Interrupts                        | Lab 9  |
| Chapter 10 | Xilinx Libraries                  | Lab 10 |
| Chapter 11 | TE Sensor Pmod                    | Lab 11 |
| Chapter 12 | Next Steps                        |        |

# SDK Application Development Flow



# Introducing Zynq-7000S Devices



## Application Processors

- Zynq-7000S
- Single-Core
- Up to 766MHz

- Zynq-7000
- Dual-Core
- Up to 1GHz



Integrated Memory Mapped Peripherals  
• e.g. USB2.0, GigE



## Integrated Analog

- Dual multi-channel 12-bit ADC
- Up to 1Msps
- Temp & Voltage sensors

## Programmable Logic

- Zynq-7000S
- Artix-7 Series FPGA
- 23K-65K Logic Cells

- Zynq-7000
- 7 Series FPGA
- 28K-440K Logic Cells



## High Bandwidth Memory

- L1/L2 CPU Caches
- Dedicated On-Chip Memory (OCM)
- DDR3, DDR2, LPDDR2 w/ ECC



## Tightly Coupled Domains

- 3000+ PS/PL interconnects
- Low Latency
- Up to 100Gb of bandwidth



## Extensive IP Portfolio

- Standardized AXI4 interfaces
- Enables peripheral expansion
- Includes software drivers

# Zynq-7000S AP SoC Basic Architecture



# Zynq-7000S AP SoC Block Diagram



# Zynq-7000 Device Portfolio Summary

*Scalable platform offers easy migration between devices*

| Processing System (PS)  | Cost-Optimized Devices                                                                         |                                                                                                                  |                     |                                                   |                   | Mid-Range Devices                                              |                   |                   |                   |                   |              |  |  |  |  |  |
|-------------------------|------------------------------------------------------------------------------------------------|------------------------------------------------------------------------------------------------------------------|---------------------|---------------------------------------------------|-------------------|----------------------------------------------------------------|-------------------|-------------------|-------------------|-------------------|--------------|--|--|--|--|--|
|                         | Z-7007S<br>XC7Z007S                                                                            | Z-7012S<br>XC7Z012S                                                                                              | Z-7014S<br>XC7Z014S | Z-7010<br>XC7Z010                                 | Z-7015<br>XC7Z015 | Z-7020<br>XC7Z020                                              | Z-7030<br>XC7Z030 | Z-7035<br>XC7Z035 | Z-7045<br>XC7Z045 | Z-7100<br>XC7Z100 |              |  |  |  |  |  |
|                         | Processor Core                                                                                 | Single-Core<br>ARM® Cortex™-A9 MPCore™<br>Up to 766MHz                                                           |                     | Dual-Core<br>ARM Cortex-A9 MPCore<br>Up to 866MHz |                   | Dual-Core<br>ARM Cortex-A9 MPCore<br>Up to 1GHz <sup>(1)</sup> |                   |                   |                   |                   |              |  |  |  |  |  |
|                         | Processor Extensions                                                                           | NEON™ SIMD Engine and Single/Double Precision Floating Point Unit per processor                                  |                     |                                                   |                   |                                                                |                   |                   |                   |                   |              |  |  |  |  |  |
|                         | L1 Cache                                                                                       | 32KB Instruction, 32KB Data per processor                                                                        |                     |                                                   |                   |                                                                |                   |                   |                   |                   |              |  |  |  |  |  |
|                         | L2 Cache                                                                                       | 512KB                                                                                                            |                     |                                                   |                   |                                                                |                   |                   |                   |                   |              |  |  |  |  |  |
|                         | On-Chip Memory                                                                                 | 256KB                                                                                                            |                     |                                                   |                   |                                                                |                   |                   |                   |                   |              |  |  |  |  |  |
|                         | External Memory Support <sup>(2)</sup>                                                         | DDR3, DDR3L, DDR2, LPDDR2                                                                                        |                     |                                                   |                   |                                                                |                   |                   |                   |                   |              |  |  |  |  |  |
|                         | External Static Memory Support <sup>(2)</sup>                                                  | 2x Quad-SPI, NAND, NOR                                                                                           |                     |                                                   |                   |                                                                |                   |                   |                   |                   |              |  |  |  |  |  |
|                         | DMA Channels                                                                                   | 8 (4 dedicated to PL)                                                                                            |                     |                                                   |                   |                                                                |                   |                   |                   |                   |              |  |  |  |  |  |
|                         | Peripherals                                                                                    | 2x UART, 2x CAN 2.0B, 2x I2C, 2x SPI, 4x 32b GPIO                                                                |                     |                                                   |                   |                                                                |                   |                   |                   |                   |              |  |  |  |  |  |
|                         | Peripherals w/ built-in DMA <sup>(2)</sup>                                                     | 2x USB 2.0 (OTG), 2x Tri-mode Gigabit Ethernet, 2x SD/SDIO                                                       |                     |                                                   |                   |                                                                |                   |                   |                   |                   |              |  |  |  |  |  |
|                         | Security <sup>(3)</sup>                                                                        | RSA Authentication of First Stage Boot Loader,<br>AES and SHA 256b Decryption and Authentication for Secure Boot |                     |                                                   |                   |                                                                |                   |                   |                   |                   |              |  |  |  |  |  |
|                         | Processing System to Programmable Logic Interface Ports (Primary Interfaces & Interrupts Only) | 2x AXI 32b Master, 2x AXI 32b Slave<br>4x AXI 64b/32b Memory<br>AXI 64b ACP<br>16 Interrupts                     |                     |                                                   |                   |                                                                |                   |                   |                   |                   |              |  |  |  |  |  |
| Programmable Logic (PL) | 7 Series PL Equivalent                                                                         | Artix®-7                                                                                                         | Artix-7             | Artix-7                                           | Artix-7           | Artix-7                                                        | Kintex®-7         | Kintex-7          | Kintex-7          | Kintex-7          |              |  |  |  |  |  |
|                         | Logic Cells                                                                                    | 23K                                                                                                              | 55K                 | 65K                                               | 28K               | 74K                                                            | 85K               | 125K              | 275K              | 350K              | 444K         |  |  |  |  |  |
|                         | Look-Up Tables (LUTs)                                                                          | 14,400                                                                                                           | 34,400              | 40,600                                            | 17,600            | 46,200                                                         | 53,200            | 78,600            | 171,900           | 218,600           | 277,400      |  |  |  |  |  |
|                         | Flip-Flops                                                                                     | 28,800                                                                                                           | 68,800              | 81,200                                            | 35,200            | 92,400                                                         | 106,400           | 157,200           | 343,800           | 437,200           | 554,800      |  |  |  |  |  |
|                         | Total Block RAM (# 36Kb Blocks)                                                                | 1.8Mb (50)                                                                                                       | 2.5Mb (72)          | 3.8Mb (107)                                       | 2.1Mb (60)        | 3.3Mb (95)                                                     | 4.9Mb (140)       | 9.3Mb (265)       | 17.6Mb (500)      | 19.1Mb (545)      | 26.5Mb (755) |  |  |  |  |  |
|                         | DSP Slices                                                                                     | 60                                                                                                               | 120                 | 170                                               | 80                | 160                                                            | 220               | 400               | 900               | 900               | 2,020        |  |  |  |  |  |
|                         | PCI Express <sup>(4)</sup>                                                                     | —                                                                                                                | Gen2 x4             | —                                                 | Gen2 x4           | —                                                              | Gen2 x4           | Gen2 x8           | Gen2 x8           | Gen2 x8           |              |  |  |  |  |  |
|                         | Analog Mixed Signal (AMS) / XADC <sup>(2)</sup>                                                | 2x 12 bit, MSPS ADCs with up to 17 Differential Inputs                                                           |                     |                                                   |                   |                                                                |                   |                   |                   |                   |              |  |  |  |  |  |
|                         | Security <sup>(3)</sup>                                                                        | AES & SHA 256b Decryption & Authentication for Secure Programmable Logic Config                                  |                     |                                                   |                   |                                                                |                   |                   |                   |                   |              |  |  |  |  |  |
|                         | Speed Grades                                                                                   | Commercial                                                                                                       | -1                  | -2                                                | -2,-3             | -1,-2,-1L                                                      | -1                | -2,-3             | -1,-2,-2L         | -1,-2,-2L         |              |  |  |  |  |  |
|                         |                                                                                                | Extended                                                                                                         | -2                  | -1,-2                                             | -1,-2,-1L         | -1,-2,-1L                                                      | -1,-2,-2L         | -1,-2,-2L         | -1,-2,-2L         | -1,-2,-2L         |              |  |  |  |  |  |
|                         |                                                                                                | Industrial                                                                                                       | -1,-2               | -1,-2,-1L                                         | -1,-2,-1L         | -1,-2,-1L                                                      | -1,-2,-2L         | -1,-2,-2L         | -1,-2,-2L         | -1,-2,-2L         |              |  |  |  |  |  |

Minized →

# Connecting HW and SW

- **Hardware Designer Perspective**
  - Peripheral blocks can be standard core offerings or custom logic cores
  - Logic controls exposed to Processor System via register interface



- **Software Developer Perspective**
  - Processor System controls Programmable Logic blocks via exposed register interface
  - From ARM processor's perspective, everything is memory mapped



# The Zynq Hardware Platform

- Output from Vivado
  - Hardware description in XML format
  - FPGA bitstream
  - Block RAM Memory Map (BMM) file
- Includes
  - Zynq processor configuration
  - PS Peripheral and MIO assignments
  - PL design and pinout
- Pre-built for this course
- To learn how to create hardware platforms, look at the *Developing Zynq Hardware* course



# Lab 1 – Explore an Exported Hardware Platform

- Created in Vivado
- Pre-built
- This lab includes the complete Vivado project
  - Not necessary to have the full project
  - The export directory alone is enough
- No Xilinx tools required for this lab



# Questions

---

- What tool suite creates the Zynq hardware platform archive?
  - Vivado is the currently recommended tool for creating Zynq hardware platforms
- Which file in the hardware platform archive is most comparable to a ‘datasheet’ for the hardware platform?
  - ps7\_init.html
- Which file contains the information that SDK will later use to build a BSP?
  - The Hardware Handoff File (HWH in XML format) file – Z\_system.hwh
- Which file will later be used to initialize the Zynq PS during a debug session?
  - The TCL file – ps7\_init.tcl

# Agenda

| Lecture    | Description                       | Labs   |
|------------|-----------------------------------|--------|
| Chapter 1  | Zynq System Architecture Basics   | Lab 1  |
| Chapter 2  | Xilinx SDK Overview               | Lab 2  |
| Chapter 3  | Standalone Board Support Package  | Lab 3  |
| Chapter 4  | Developing Applications           | Lab 4  |
| Chapter 5  | Connecting Hardware and Debugging | Lab 5  |
| Chapter 6  | First Stage Boot Loader           | Lab 6  |
| Chapter 7  | Flash Programming and Boot-up     | Lab 7  |
| Chapter 8  | SDK Project Management            | Lab 8  |
| Chapter 9  | Interrupts                        | Lab 9  |
| Chapter 10 | Xilinx Libraries                  | Lab 10 |
| Chapter 11 | TE Sensor Pmod                    | Lab 11 |
| Chapter 12 | Next Steps                        |        |

# SDK Application Development Flow

- Automatic BSP generation
- GNU cross-compiler toolchain
- Common application templates
- Automated linker script generation
- TCF-based multi-core debugger
- Hardware and software download
- Hardware/Software cross-probing
- Multi-processor debugging
- Application profiling and performance analysis
- Boot image creation
- Flash memory programming



# Basic Eclipse Concepts

---

- Workbench
  - Refers to the Eclipse IDE
- Workspace
  - Keeps Workbench session information
  - Stores Eclipse preferences
  - Only one active Workspace at a time per Workbench
  - Manages C/C++ projects
- Perspectives
  - Collection of functionally related views, editors, menu items, and toolbar buttons
  - Layout of views in perspective can be customized
- Views
  - Basic user interface element
  - Provides information, control, or navigation

# SDK Workbench Views – C/C++ Perspective

**Project Explorer**  
displays the projects with  
icons for easy  
identification

C/C++ editor for  
integrated software  
creation

Code outline displays  
elements of the software  
file under development  
with icons for easy  
identification

Problems, Console, and  
Properties views list  
output information

Active Perspective  
indicated here

SDK Log



# Xilinx Plug-ins

- Plug-ins provide a way to customize Eclipse
- Xilinx plug-ins include:
  - Project creation wizard
  - Xilinx specific managed build
  - Xilinx specific toolchain and utilities
  - Xilinx specific menu items
  - Debug integration
  - Linker script generator
  - Boot image creation
  - Flash programmer
  - Xilinx documentation



# Application Dependencies



- Every workspace has one Hardware Platform
  - Specified through an XML file
  - XML file is generated in Vivado
- Multiple Board Support Packages (BSPs) can reference a single Hardware Platform
  - Xilinx provides a Standalone BSP
- Multiple C/C++ projects can reference a single BSP

# Lab 2 – SDK Workspace and Hardware Platform

- Launch SDK
- Create a workspace
- Import Hardware Platform Definition
- Examine results in SDK and Windows Explorer



# Questions

---

- What is the purpose of the SDK Workspace?
  - The Workspace holds a collection of projects related to your software application development. It will typically contain one hardware platform and one or more BSPs and software applications. The workspace contains your SDK settings, software sources, and logs.
- When you need to share an SDK Workspace, is it a good idea to simply zip it up and send it over?
  - NO! In Lab 8, we'll show you the proper way to archive your workspace
- What is address range for the DDR3 (ps7\_ddr\_0)?
  - 0x00100000 to 0x1FFFFFFF (MiniZed)
- How large is the QSPI Flash in the system?
  - $0xFCFFFFFF - 0xFC000000 + 1 = 0x1000000 = 16\text{ MB} = 128\text{ Mb}$  addressable space
- Where will you find the hardware datasheet for the ps7\* peripherals?
  - The Zynq-7000 Technical Reference Manual (TRM) – UG585

# Agenda

| Lecture    | Description                       | Labs   |
|------------|-----------------------------------|--------|
| Chapter 1  | Zynq System Architecture Basics   | Lab 1  |
| Chapter 2  | Xilinx SDK Overview               | Lab 2  |
| Chapter 3  | Standalone Board Support Package  | Lab 3  |
| Chapter 4  | Developing Applications           | Lab 4  |
| Chapter 5  | Connecting Hardware and Debugging | Lab 5  |
| Chapter 6  | First Stage Boot Loader           | Lab 6  |
| Chapter 7  | Flash Programming and Boot-up     | Lab 7  |
| Chapter 8  | SDK Project Management            | Lab 8  |
| Chapter 9  | Interrupts                        | Lab 9  |
| Chapter 10 | Xilinx Libraries                  | Lab 10 |
| Chapter 11 | TE Sensor Pmod                    | Lab 11 |
| Chapter 12 | Next Steps                        |        |

# Xilinx Provides Drivers and Services



# Board Support Package (BSP)

Board Support Packages are collections of parameterized drivers for a specific microprocessing system



## MSS

### Peripheral Drivers

Drivers present in the Board Support Package.

|                      |          |                               |
|----------------------|----------|-------------------------------|
| axi_gpio_0           | gpio     | <a href="#">Documentation</a> |
| ps7_ddr_0            | generic  | <a href="#">Documentation</a> |
| ps7_ddrc_0           | generic  | <a href="#">Documentation</a> |
| ps7_dev_cfg_0        | devcfg   | <a href="#">Documentation</a> |
| ps7_dma_ns           | dmaps    | <a href="#">Documentation</a> |
| ps7_dma_s            | dmaps    | <a href="#">Documentation</a> |
| ps7_ethernet_0       | emacps   | <a href="#">Documentation</a> |
| ps7_gpio_0           | gpiops   | <a href="#">Documentation</a> |
| ps7_iop_bus_config_0 | generic  | <a href="#">Documentation</a> |
| ps7_qspi_0           | qspips   | <a href="#">Documentation</a> |
| ps7_qspi_linear_0    | generic  | <a href="#">Documentation</a> |
| ps7_ram_0            | generic  | <a href="#">Documentation</a> |
| ps7_ram_1            | generic  | <a href="#">Documentation</a> |
| ps7_scugic_0         | scugic   | <a href="#">Documentation</a> |
| ps7_scutimer_0       | scutimer | <a href="#">Documentation</a> |
| ps7_scuwdt_0         | scuwdt   | <a href="#">Documentation</a> |
| ps7_sd_0             | generic  | <a href="#">Documentation</a> |
| ps7_slcr_0           | generic  | <a href="#">Documentation</a> |
| ps7_ttc_0            | ttcps    | <a href="#">Documentation</a> |
| ps7_uart_1           | uartps   | <a href="#">Documentation</a> |

**libxil.a**

# UART Device Driver Example



# GCC Low-Level Runtime Library

---

- Zynq uses standard C libraries from libgcc.a
- Included and statically linked from toolchain install folder

C:\Xilinx\SDK\2017.4\gnu\arm\lib\gcc\arm-none-eabi\6.2.1

- Routines provided
  - Integer library routines
  - Soft float library routines
  - Decimal float library routines
  - Fixed-point fractional library routines
  - Exception handling routines
  - Miscellaneous routines
- Look at Xilinx ***OS and Libraries Document Collection*** (UG645) for more information

# Lab 3 – Board Support Package

- Create the BSP
- Examine what was created
- Explore a built-in device driver



# Questions

---

- What are the base addresses for the OCM segments,  
`XPAR_PS7_RAM_0_S_AXI_BASEADDR` and  
`XPAR_PS7_RAM_1_S_AXI_BASEADDR`?
  - 0x00000000 and 0xFFFFC0000
- What size is PS7\_RAM\_0 ?
  - $0x0003FFFF - 0x00000000 + 1 = 0x40000 = 262144$  bytes= 256 KB
- What parameter name would you access for the PWM peripheral interrupt?
  - `XPAR_FABRIC_PWM_W_INT_0_INTERRUPT_OUT_INTR`, which happens to be set to interrupt #61

# Agenda

| Lecture    | Description                       | Labs   |
|------------|-----------------------------------|--------|
| Chapter 1  | Zynq System Architecture Basics   | Lab 1  |
| Chapter 2  | Xilinx SDK Overview               | Lab 2  |
| Chapter 3  | Standalone Board Support Package  | Lab 3  |
| Chapter 4  | Developing Applications           | Lab 4  |
| Chapter 5  | Connecting Hardware and Debugging | Lab 5  |
| Chapter 6  | First Stage Boot Loader           | Lab 6  |
| Chapter 7  | Flash Programming and Boot-up     | Lab 7  |
| Chapter 8  | SDK Project Management            | Lab 8  |
| Chapter 9  | Interrupts                        | Lab 9  |
| Chapter 10 | Xilinx Libraries                  | Lab 10 |
| Chapter 11 | TE Sensor Pmod                    | Lab 11 |
| Chapter 12 | Next Steps                        |        |

# Example Code

Peripheral Drivers  
Drivers present in the Board Support Package.

|                 |                |                               |                                 |                                 |
|-----------------|----------------|-------------------------------|---------------------------------|---------------------------------|
| PWM_w_Int_0     | PWM_w_Int      | <a href="#">Documentation</a> | <a href="#">Import Examples</a> |                                 |
| axi_bram_ctrl_0 | bram           | <a href="#">Documentation</a> | <a href="#">Import Examples</a> |                                 |
| axi_gpio_0      | gpio           | <a href="#">Documentation</a> | <a href="#">Import Examples</a> |                                 |
| axi_gpio_1      | gpio           | <a href="#">Documentation</a> | <a href="#">Import Examples</a> |                                 |
| axi_iic_0       | iic            | <a href="#">Documentation</a> | <a href="#">Import Examples</a> |                                 |
| MSS             | axi_iic_1      | iic                           | <a href="#">Documentation</a>   | <a href="#">Import Examples</a> |
|                 | axi_iic_2      | iic                           | <a href="#">Documentation</a>   | <a href="#">Import Examples</a> |
|                 | bluetooth_uart | uartns550                     | <a href="#">Documentation</a>   | <a href="#">Import Examples</a> |

Xilinx provides example code for nearly every included peripheral driver

## Example Applications for the driver **uartps\_v2\_2**

- [xuartps\\_hello\\_world\\_example.c \(source\)](#)
- [xuartps\\_intr\\_example.c \(source\)](#)
- [xuartps\\_low\\_echo\\_example.c \(source\)](#)
- [xuartps\\_polled\\_example.c \(source\)](#)
- [xuartps\\_selftest\\_example.c \(source\)](#)



The screenshot shows a Windows File Explorer window with the following path:  
Computer > OSDisk (C:) > Xilinx > SDK > 2017.4 > data > embeddedsw > XilinxProcessorIPLib > drivers > uartps\_v3\_5 > examples

| Organize                      | Include in library | Share with    | Burn  | New folder |
|-------------------------------|--------------------|---------------|-------|------------|
| Favorites                     |                    |               |       |            |
| Desktop                       |                    |               |       |            |
| Downloads                     |                    |               |       |            |
| Recent Places                 |                    |               |       |            |
| Libraries                     |                    |               |       |            |
| Documents                     |                    |               |       |            |
| Git                           |                    |               |       |            |
| Name                          | Date modified      | Type          | Size  |            |
| index.html                    | 12/13/2017 6:27 PM | HTML Document | 1 KB  |            |
| readme.txt                    | 12/13/2017 6:27 PM | Text Document | 2 KB  |            |
| xuartps_hello_world_example.c | 12/13/2017 6:27 PM | C Source File | 6 KB  |            |
| xuartps_intr_example.c        | 12/13/2017 6:27 PM | C Source File | 16 KB |            |
| xuartps_low_echo_example.c    | 12/13/2017 6:27 PM | C Source File | 7 KB  |            |
| xuartps_polled_example.c      | 12/13/2017 6:27 PM | C Source File | 7 KB  |            |
| xuartps_selftest_example.c    | 12/13/2017 6:27 PM | C Source File | 5 KB  |            |

# New C Project Sample Applications

- Empty Application
  - Will setup the project references
  - Can be used to import an existing application
- Hello World
  - Directs stdout output to PS UART
- lwIP Echo Server
  - Simple example using the lwIP Ethernet stack
  - Not useful for MiniZed, works with wired Ethernet
- Memory Tests
  - Tests all available memories
- Peripheral Tests
  - Basic peripheral tests
- Zynq FSBL
  - First stage bootloader

## Available Templates:

Dhrystone  
**Empty Application**  
Hello World  
lwIP Echo Server  
Memory Tests  
OpenAMP echo-test  
OpenAMP matrix multiplication Demo  
OpenAMP RPC Demo  
Peripheral Tests  
RSA Authentication App  
Zynq DRAM tests  
Zynq FSBL

# Linker Script Generator



- Provides an easy way to modify the linker script
  - Advanced tab allows individual section assignments
  - Modify the Heap and Stack sizes



# Memories in the Lab Hardware Platform



# Build Errors and Warnings

- Errors and Warning are displayed
  - In the Problems View, double clicking problem takes you to Editor View line of code



- In the Editor margin, hover over marker to see the related warning or error



# Project Explorer View



- Lists all the projects alphabetically
- One Hardware Platform Definition Project
- Multiple BSPs allowed
  - With different settings or libraries
- Multiple C projects
- All the files can be opened with the editor
  - Hardware specification file shows the memory map, core used, and contains links to the datasheets
  - BSP Settings file lists the device drivers used and contains links to the drivers documentation

# Lab 4 – Developing Applications

- Create a new Xilinx C/C++ application
- Use Example Code
  - Hello World
- Use a built-in template
  - Memory Test Application
  - Peripheral Test Application
- Explore the code
- Use the Generate Linker Script tool to modify a linker script



# Questions

---

- You've been assigned a task to develop code to test reading and writing to the PL BRAM (peripheral axi\_bram\_ctrl\_0 in this hardware platform). What do you do?
  - When starting to work with a new peripheral and its associated driver, the best place to start is the example code provided by Xilinx. Go to the system.mss Overview. Find the BRAM peripheral. Click on the Import Examples link to get to the example code.
- To what memory region(s) is the Test\_Peripherals application targeted?
  - DDR3 for everything – Code, Data, heap, and stack
- To what memory region(s) is the Test\_Memory application targeted?
  - ps7\_ram\_0\_S\_AXI\_BASEADDR for the Code, Data, heap, and stack sections
- How much memory is tested by default?
  - 4096 bytes
- How many memories are tested? Which ones?
  - Three memories: DDR3, axi\_bram, and ram\_1
  - ram\_0 is not actually tested as this is where the code, data, heap and stack reside.

# Agenda

| Lecture    | Description                       | Labs   |
|------------|-----------------------------------|--------|
| Chapter 1  | Zynq System Architecture Basics   | Lab 1  |
| Chapter 2  | Xilinx SDK Overview               | Lab 2  |
| Chapter 3  | Standalone Board Support Package  | Lab 3  |
| Chapter 4  | Developing Applications           | Lab 4  |
| Chapter 5  | Connecting Hardware and Debugging | Lab 5  |
| Chapter 6  | First Stage Boot Loader           | Lab 6  |
| Chapter 7  | Flash Programming and Boot-up     | Lab 7  |
| Chapter 8  | SDK Project Management            | Lab 8  |
| Chapter 9  | Interrupts                        | Lab 9  |
| Chapter 10 | Xilinx Libraries                  | Lab 10 |
| Chapter 11 | TE Sensor Pmod                    | Lab 11 |
| Chapter 12 | Next Steps                        |        |

# Lab Hardware - MiniZed



**MINIZED™**  
[www.minized.org](http://www.minized.org)

**AVNET®**

# Configurations

- Configuration = settings associated with running or debugging within SDK
- Run and Debug options
- Set up for
  - Processor reset
  - Processor initialization
  - Download bitstream
  - Data download
  - Terminal
  - Profiling
  - Remote debug
  - Passing arguments



# Application Debugging

- System Debugger for source and assembly
  - 3<sup>rd</sup> Party trace tools available – **Debugging ARM Processor Systems** online training



# Lab 5 – Connecting Hardware

- Connect the hardware
- Download an application over JTAG
- Debug an application over JTAG



# Questions

---

- For what can the JTAG interface be used?
  - Read and write ARM registers
  - Configure the PL with a bitstream
  - Program attached QSPI Flash
  - Upload application code to OCM or DDR3L
  - Application debug
  - Performance analysis and profiling
- Under what conditions must the hardware platform first be downloaded into the PL?
  - If the application only uses the Zynq PS, then programming the PL is not necessary. If the application makes use of something in the PL, then the PL must be programmed first.
- How does the ARM get initialized when running an application from SDK?
  - ps7\_init.tcl that was provided with the hardware platform
- How much memory is tested by default?
  - 4 KB

# Agenda

| Lecture    | Description                       | Labs   |
|------------|-----------------------------------|--------|
| Chapter 1  | Zynq System Architecture Basics   | Lab 1  |
| Chapter 2  | Xilinx SDK Overview               | Lab 2  |
| Chapter 3  | Standalone Board Support Package  | Lab 3  |
| Chapter 4  | Developing Applications           | Lab 4  |
| Chapter 5  | Connecting Hardware and Debugging | Lab 5  |
| Chapter 6  | First Stage Boot Loader           | Lab 6  |
| Chapter 7  | Flash Programming and Boot-up     | Lab 7  |
| Chapter 8  | SDK Project Management            | Lab 8  |
| Chapter 9  | Interrupts                        | Lab 9  |
| Chapter 10 | Xilinx Libraries                  | Lab 10 |
| Chapter 11 | TE Sensor Pmod                    | Lab 11 |
| Chapter 12 | Next Steps                        |        |

# Zynq-7000 Configuration and Boot

- Processor First! CPU configures the PS and PL
  - Standalone PL configuration (without PS configuration) is not supported
  - Configuration under external host control is also possible via JTAG
- Two boot modes
  - Secure boot
  - Non-secure boot
- Four master boot methods (secure or non-secure boot)
  - QSPI (16MB, 50MB/Sec)\*
  - NOR (64MB, 20MB/Sec)\*
  - NAND (tested up to 1GB, 10MB/Sec)\*
    - \* cannot be used in the same design
  - SD (Up to 32GB)
- One slave boot method (non-secure)
  - JTAG for debug and development



# Non-Secure Boot – Stage 0

- CPU starts executing code from ROM
  1. Initializes the Cortex-A9 CPU 0
  2. Checks CRC on ROM code
  3. Reads the **boot mode pins** to determine Stage 1 boot mode
    - Can boot from QSPI, NAND, NOR, SD card, or JTAG
  4. Typically, a **first stage boot loader** is read from external non-volatile memory and copied into the OCM (192KB max)
    - If the Execute In Place (XIP) feature is enabled, first stage boot executed directly from QSPI or NOR
    - Stage 1 boot header specifies the use of XIP feature



Arrow showing direction of master

# First Stage Boot Loader (FSBL)

- First Stage Boot Loader Functions
  - Initialize Processing System blocks
  - PLL
  - External memory controller
  - MIO
  - Configure Programmable Logic with Bitstream (optional)
  - Provides for secure boot option
  - Execute application code
- Application created automatically directly from the SDK FSBL new project template

The screenshot shows a software interface with two main panes. The top pane displays the contents of the file 'fsbl.h' in a code editor. The code defines various macros related to boot ROM image offsets and reboot status register defines. A green arrow points from the bottom-left towards this pane. The bottom pane shows a 'Templates' section with a heading 'Create one of the available templates to generate a fully-functioning application project.' Below this, there is a list of 'Available Templates' including 'Dhrystone', 'Empty Application', 'Hello World', 'lwIP Echo Server', 'Memory Tests', 'OpenAMP echo-test', 'OpenAMP matrix multiplication Demo', 'OpenAMP RPC Demo', 'Peripheral Tests', 'RSA Authentication App', 'Zynq DRAM tests', and 'Zynq FSBL'. The 'Zynq FSBL' template is highlighted with a blue background. To the right of the template list, a detailed description of the 'First Stage Bootloader (FSBL) for Zynq' is provided.

```
/* Boot ROM Image defines */
#define IMAGE_WIDTH_CHECK_OFFSET      (0x020) /*< 0xaa995566 Width Detection w/o.
#define IMAGE_IDENT_OFFSET           (0x024) /*< 0x584C4E58 "XLNX" */
#define IMAGE_ENC_FLAG_OFFSET        (0x028) /*< undefined could be used as */
#define IMAGE_USR_DEF_OFFSET         (0x02C) /*< start address of image */
#define IMAGE_SOURCE_ADDR_OFFSET     (0x030) /*< length of image> in bytes */
#define IMAGE_BYTE_LEN_OFFSET        (0x034) /*< destination address in OCM */
#define IMAGE_DEST_ADDR_OFFSET       (0x038) /*< address to start executing at */
#define IMAGE_EXECUTE_ADDR_OFFSET    (0x03C) /*< total length of image in bytes */
#define IMAGE_TOT_BYTE_LEN_OFFSET   (0x040) /*< QSPI configuration data */
#define IMAGE_QSPI_CFG_WORD_OFFSET  (0x044) /*< Header Checksum offset */
#define IMAGE_CHECKSUM_OFFSET        (0x048) /*< XLNX pattern */
#define IMAGE_IDENT                  (0x584C4E58) /*< XLNX pattern */

/* Reboot status register defines:
 * 0xF0000000 for FSBL fallback mask to notify Boot Rom
 * 0x60000000 for FSBL to mark that FSBL has not handoff yet
 * 0x00FFFFFF for user application to use across soft reset
 */
#define FSBL_FAIL_MASK      0xF0000000
```

**Templates**  
Create one of the available templates to generate a fully-functioning application project.

**Available Templates:**

|                                                                                                                                                                                                                                                       |                                                                                                                                                                                                                                                                                                                                                                                         |
|-------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|-----------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| Dhrystone<br>Empty Application<br>Hello World<br>lwIP Echo Server<br>Memory Tests<br>OpenAMP echo-test<br>OpenAMP matrix multiplication Demo<br>OpenAMP RPC Demo<br>Peripheral Tests<br>RSA Authentication App<br>Zynq DRAM tests<br><b>Zynq FSBL</b> | First Stage Bootloader (FSBL) for Zynq.<br>The FSBL configures the FPGA with HW bit stream (if it exists) and loads the Operating System (OS) Image or Standalone (SA) Image or 2nd Stage Boot Loader image from the non-volatile memory (NAND/NOR/QSPI) to RAM (DDR) and starts executing it. It supports multiple partitions, and each partition can be a code image or a bit stream. |
|-------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|-----------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|

# Non-Secure Boot – Stage 1

- CPU starts executing code from OCM (FSBL)
  - Code execution can also be performed directly from QSPI or NOR if the Execute In Place (XIP) feature is used
    - 192KB code size limit is removed
  - 1. DDR controller, clock generation module, and selected peripherals are initialized
  - 2. PS application and/or second stage boot is loaded into the DDR memory
  - 3. Optionally, bitstream is loaded from non-volatile memory and PL is configured
  - 4. Second stage boot is optionally enabled



# Stage 2 Boot

- Stage 2 boot loader such as U-Boot runs from the DDR memory
  - Responsible for loading OS kernel
  - OS image can be sourced from any of the following peripherals
    - NAND
    - NOR
    - QSPI
    - USB
    - GigE
    - SD
  - Optionally configure PL in stage 2

Get U-Boot source code from Xilinx's Github Repository  
Learn more from <http://wiki.xilinx.com/zynq-uboot>



# Lab 6 – FSBL

- Create the FSBL
- Analyze the code



# Questions

---

- What is the size of the FSBL application with the Debug configuration?
  - ~ 159596 bytes
- What is the target memory for the FSBL?
  - ps7\_ram\_0\_S\_AXI\_BASEADDR, which is the 192 KB on-chip RAM
- What is the size of the FSBL application with the Release configuration?
  - 153788 bytes => 5808 bytes (or 3.9%) smaller
- In what file was the FSBL main() function?
  - main.c
- Which files included all of the ARM register settings? Where did they originate (prior to FSBL generation)?
  - ps7\_init.c and ps7\_init.h files
  - The imported Hardware Platform Definition. Remember Lab 1?

# Agenda

| Lecture    | Description                       | Labs   |
|------------|-----------------------------------|--------|
| Chapter 1  | Zynq System Architecture Basics   | Lab 1  |
| Chapter 2  | Xilinx SDK Overview               | Lab 2  |
| Chapter 3  | Standalone Board Support Package  | Lab 3  |
| Chapter 4  | Developing Applications           | Lab 4  |
| Chapter 5  | Connecting Hardware and Debugging | Lab 5  |
| Chapter 6  | First Stage Boot Loader           | Lab 6  |
| Chapter 7  | Flash Programming and Boot-up     | Lab 7  |
| Chapter 8  | SDK Project Management            | Lab 8  |
| Chapter 9  | Interrupts                        | Lab 9  |
| Chapter 10 | Xilinx Libraries                  | Lab 10 |
| Chapter 11 | TE Sensor Pmod                    | Lab 11 |
| Chapter 12 | Next Steps                        |        |

# Create Zynq Boot Image in SDK

- Graphical front end to command line bootgen

- Partitions

1. FSBL
2. Bitstream
3. Application



# Boot Process Overview for Zynq



# SDK Flash Programming Utility

- Supports multiple non-volatile types
  - Single QSPI will be used in the labs
- Interprets BIN and MCS format files
- Capable of programming at offset
- Erase check and write verify options
- FSBL must be specified



# Lab 7 – Flash Programming and Configuration

- Create the boot images
- Copy to QSPI
- Boot from QSPI



# Questions

---

- Is the order of the boot images critical? If so, list the order.
  - YES! FSBL ELF first, then bitstream, then application ELF
- True or False? The Create Zynq Boot Image tool creates a boot image for the QSPI Flash.
  - True. SDK uses a utility called *bootgen* to generate a boot container file that contains the FSBL, the Programmable Logic bitstream (optional), and the Standalone user application.

# Agenda

| Lecture    | Description                       | Labs   |
|------------|-----------------------------------|--------|
| Chapter 1  | Zynq System Architecture Basics   | Lab 1  |
| Chapter 2  | Xilinx SDK Overview               | Lab 2  |
| Chapter 3  | Standalone Board Support Package  | Lab 3  |
| Chapter 4  | Developing Applications           | Lab 4  |
| Chapter 5  | Connecting Hardware and Debugging | Lab 5  |
| Chapter 6  | First Stage Boot Loader           | Lab 6  |
| Chapter 7  | Flash Programming and Boot-up     | Lab 7  |
| Chapter 8  | SDK Project Management            | Lab 8  |
| Chapter 9  | Interrupts                        | Lab 9  |
| Chapter 10 | Xilinx Libraries                  | Lab 10 |
| Chapter 11 | TE Sensor Pmod                    | Lab 11 |
| Chapter 12 | Next Steps                        |        |

# Sharing SDK Workspaces and Projects

- SDK workspaces are location and directory sensitive
- *Do not move workspaces via Windows navigation*
- Two ways to export and import with SDK
  - Archive file – zip and tar formats
  - Directory structure



# Importing C/C++ Source Files

- Create an Empty Application project
  - Set HW platform and BSP as needed
- Select Import in the File Menu
- Select File System option under General import source type
- Select the C/C++ project
  - Directories or individual files



# Software Repositories

- May include
  - Custom Drivers
  - Custom Libraries
  - Custom Board Support Packages
  - Could be a modified Xilinx driver or library
  - Repository sub-directories
    - bsp
    - drivers
    - sw\_services
- Prioritized



# Lab 8 – Project Management

- Export your complete workspace
  - Hardware Platform
  - BSP
  - All applications
- Create a new Workspace
- Re-create your previous Workspace in the new Workspace



# Questions

---

- What is the advantage of exporting your Workspace items as opposed to simply zipping the workspace?
  - If you zip and share your SDK workspace, there is a very good chance that it will not work when opened again. The SDK workspace is full of absolute paths, so unless the recipient unzips the SDK workspace to the exact same location, it won't fully work. It might appear to work initially, but it is likely not going to build properly.
  - If you export the workspace, it is fully transportable.

# Agenda

| Lecture    | Description                       | Labs   |
|------------|-----------------------------------|--------|
| Chapter 1  | Zynq System Architecture Basics   | Lab 1  |
| Chapter 2  | Xilinx SDK Overview               | Lab 2  |
| Chapter 3  | Standalone Board Support Package  | Lab 3  |
| Chapter 4  | Developing Applications           | Lab 4  |
| Chapter 5  | Connecting Hardware and Debugging | Lab 5  |
| Chapter 6  | First Stage Boot Loader           | Lab 6  |
| Chapter 7  | Flash Programming and Boot-up     | Lab 7  |
| Chapter 8  | SDK Project Management            | Lab 8  |
| Chapter 9  | Interrupts                        | Lab 9  |
| Chapter 10 | Xilinx Libraries                  | Lab 10 |
| Chapter 11 | TE Sensor Pmod                    | Lab 11 |
| Chapter 12 | Next Steps                        |        |

# Interrupts and Exceptions

- Hardware interrupt
  - An asynchronous signal from hardware, originating outside the processor core, indicating a peripheral's need for attention
- Software Interrupt
  - A synchronous event in software indicating the need for a change in execution, also referred to as an exception
- Occurring events which need immediate responses



# Zynq Interrupts - Generic Interrupt Controller (GIC)



# Interrupt Handling

- When an interrupt occurs, an Interrupt Handler should respond to the event by calling the appropriate ISR



# Process of Handling an Interrupt

1. Interrupt is received, and current executing instruction completes
2. Save processor status
  - Copies CPSR into SPSR\_irq
  - Stores the return address in LR\_irq
3. Change processor status for exception
  - Mode field bits
  - Interrupt disable bits (if appropriate)
  - Sets PC to vector address
4. Execute top-level exception handler
  - Top-level handler branches to the appropriate registered ISR
5. Return to main application
  - Restore CPSR from SPSR\_irq
  - Restore PC from LR\_irq
  - When re-enabling interrupts change to system mode (CPS)



---

# ISR Tips and Tricks

---

- Keep the code short and simple; ISRs can be difficult to debug
- Do not allow servicing of other interrupts while in the ISR
- Time is of the essence!
  - Spend as little time as possible in the ISR
  - Do not perform tasks that can be done in the background
  - Use flags to signal background functions
- Make use of the callback argument (or parameter) passed in ISR registration
- Make use of the provided interrupt support functions when using IP drivers
- Be sure to enable interrupts when leaving the registered handler or ISR

# Lab 9 – Interrupts

- Add an ISR to an existing application
- Register the ISR and enable the related interrupt source



# Questions

---

- What happens when a value outside of the requested range of 0-9 is entered?
  - The value is accepted, multiplied by the brightness clock multiplier and write that value into the PWM hardware block control registers. However, the custom IP block detects the out of range value and triggers an interrupt.
- Are interrupts currently enabled in the example application provided?
  - Hardware interrupts are currently provided from the PWM hardware block which are then routed to the GIC in the hardware platform. However, the software application at this point does not configure the GIC to allow the application execution to be interrupted so the software end of the interrupt is not currently enabled.
- When does the function PWMIsr() get called?
  - The PWMIsr() is the interrupt service routine callback function. It is registered with the interrupt subsystem as the callback interrupt handler through the call to XScuGic\_Connect() during our interrupt setup.
- GROUP DISCUSSION QUESTION – We handled the event handling within the ISR, what is another way of doing this?
  - Alternatively, we could have the ISR just set a flag and then wait for the main (background execution thread) function process the flag and write a message to the console.

# Agenda

| Lecture    | Description                       | Labs   |
|------------|-----------------------------------|--------|
| Chapter 1  | Zynq System Architecture Basics   | Lab 1  |
| Chapter 2  | Xilinx SDK Overview               | Lab 2  |
| Chapter 3  | Standalone Board Support Package  | Lab 3  |
| Chapter 4  | Developing Applications           | Lab 4  |
| Chapter 5  | Connecting Hardware and Debugging | Lab 5  |
| Chapter 6  | First Stage Boot Loader           | Lab 6  |
| Chapter 7  | Flash Programming and Boot-up     | Lab 7  |
| Chapter 8  | SDK Project Management            | Lab 8  |
| Chapter 9  | Interrupts                        | Lab 9  |
| Chapter 10 | Xilinx Libraries                  | Lab 10 |
| Chapter 11 | TE Sensor Pmod                    | Lab 11 |
| Chapter 12 | Next Steps                        |        |

# SDK BSP - Supported Libraries

- BSP settings allow for system access library options



# System Access Libraries

Xilinx provides several important system access libraries

- Generic FAT file system: **xilffs**
- Open source lightweight TCP/IP stack support: **lwip141**
- Access the RSA 2048 and SHA2 algorithms for performing boot authentication: **xilrsa**
- Can be used for secure boot programming of eFUSE and BBRAM: **xilskey**
- In-system serial flash support: **xilisf**
  - Support for Micron QSPI flash device on MiniZed



# Adding xilisf Library Support to a BSP

- Select xilisf library within BSP settings



# Configuring the xilisf Library

- Initialize xilisf parameter types
  - Flash family type
  - Flash interface type



# Leverage Example Code for Libraries

- Example code found within the Xilinx xilisf library folder

C:\Xilinx\SDK\2017.4\data\embedded\lib\sw\_services\xilisf\_v5\_9\examples\

|                                           |                           |               |              |
|-------------------------------------------|---------------------------|---------------|--------------|
| xilisf_atmel_buffer_rdwr_example.c        | 10/13/2013 3:08 PM        | C File        | 17 KB        |
| xilisf_atmel_rdwr_polled_example.c        | 10/13/2013 3:08 PM        | C File        | 11 KB        |
| xilisf_atmel_read_write_example.c         | 10/13/2013 3:08 PM        | C File        | 16 KB        |
| xilisf_atmel_spr_example.c                | 10/13/2013 3:08 PM        | C File        | 22 KB        |
| xilisf_intel_otp_rdwr_example.c           | 10/13/2013 3:08 PM        | C File        | 16 KB        |
| xilisf_intel_rdwr_polled_example.c        | 10/13/2013 3:08 PM        | C File        | 13 KB        |
| xilisf_intel_read_write_example.c         | 10/13/2013 3:08 PM        | C File        | 18 KB        |
| xilisf_intel_spr_example.c                | 10/13/2013 3:08 PM        | C File        | 24 KB        |
| xilisf_qspips_stm_intr_example.c          | 10/13/2013 3:08 PM        | C File        | 23 KB        |
| <b>xilisf_qspips_stm_polled_example.c</b> | <b>10/13/2013 3:08 PM</b> | <b>C File</b> | <b>17 KB</b> |
| xilisf_spips_sst_intr_example.c           | 10/13/2013 3:08 PM        | C File        | 22 KB        |
| xilisf_spips_sst_polled_example.c         | 10/13/2013 3:08 PM        | C File        | 16 KB        |
| xilisf_stm_quad_flash_example.c           | 10/13/2013 3:08 PM        | C File        | 26 KB        |
| xilisf_stm_rdwr_polled_example.c          | 10/13/2013 3:08 PM        | C File        | 11 KB        |
| xilisf_stm_read_write_example.c           | 10/13/2013 3:08 PM        | C File        | 16 KB        |
| xilisf_stm_spr_example.c                  | 10/13/2013 3:08 PM        | C File        | 21 KB        |
| xilisf_winbond_quad_flash_example.c       | 10/13/2013 3:08 PM        | C File        | 23 KB        |
| xilisf_winbond_rdwr_polled_example.c      | 10/13/2013 3:08 PM        | C File        | 11 KB        |
| xilisf_winbond_read_write_example.c       | 10/13/2013 3:08 PM        | C File        | 16 KB        |
| xilisf_winbond_spr_example.c              | 10/13/2013 3:08 PM        | C File        | 21 KB        |

# Lab 10 – Serial Flash Library

- Use xilisf library to access flash memory to store a system configuration parameter
  - Erase a page of flash memory
  - Write data to a piece of memory
  - Read data back from that piece of memory



# Questions

---

- What if you wanted to reuse part of this application on your own Zynq design but you prefer to use Microchip Flash instead of Micron Flash?
  - Avnet also distributes Microchip (Atmel) devices and the only part of this software application that would need to be changed is the serial\_flash\_family field from Experiment 1, Step 10.
- Why is a separate BSP created for this application? Why not reuse the standalone\_bsp\_0 from earlier lab activities?
  - A separate BSP was created since the Xilinx xilisf library was to be added specifically to support this MAC programming application. We could have instead modified the standalone\_bsp\_0 to add the xilisf library but that would cause the library code to built into the BSP each time the project is cleaned and rebuilt. This would unnecessarily increase build time for the full workspace which might not be desirable. However, if xilisf were built into the BSP but not called by our other applications, it would NOT affect their executable code size.
- How were functions created within the application code which accesses the flash? Were these functions written entirely from scratch?
  - Not really, the flash access functions found within the xilisf\_qspips\_flash\_polled.c source file are adapted from the example code found within the Xilinx xilisf library folder

# Agenda

| Lecture    | Description                       | Labs   |
|------------|-----------------------------------|--------|
| Chapter 1  | Zynq System Architecture Basics   | Lab 1  |
| Chapter 2  | Xilinx SDK Overview               | Lab 2  |
| Chapter 3  | Standalone Board Support Package  | Lab 3  |
| Chapter 4  | Developing Applications           | Lab 4  |
| Chapter 5  | Connecting Hardware and Debugging | Lab 5  |
| Chapter 6  | First Stage Boot Loader           | Lab 6  |
| Chapter 7  | Flash Programming and Boot-up     | Lab 7  |
| Chapter 8  | SDK Project Management            | Lab 8  |
| Chapter 9  | Interrupts                        | Lab 9  |
| Chapter 10 | Xilinx Libraries                  | Lab 10 |
| Chapter 11 | TE Sensor Pmod                    | Lab 11 |
| Chapter 12 | Next Steps                        |        |

# AXI IIC IP Block



# Xilinx Standalone iic\_v3\_4 Driver Documentation



## iic\_v3\_4

Xilinx SDK Drivers API Documentation

Overview

Data Structures

APIs

File List

### iic\_v3\_4 Documentation

**Xlic** is the driver for an IIC master or slave device. In order to reduce the memory requirements of the driver the driver supports multimaster features of the driver, the user must call functions (`Xlic_SlaveInclude` and `Xlic_MultiMasterInclude`) to enable them.

Two sets of higher level API's are available in the **Xlic** driver that can be used for Transmission/Reception in Master mode:

- [`Xlic\_MasterSend\(\)`/`Xlic\_MasterRecv\(\)`](#) which is used in normal mode.
- [`Xlic\_DynMasterSend\(\)`/`Xlic\_DynMasterRecv\(\)`](#) which is used in Dynamic mode.

Similarly two sets of lower level API's are available in **Xlic** driver that can be used for Transmission/Reception in Slave mode:

- [`Xlic\_Send\(\)`/`Xlic\_Recv\(\)`](#) which is used in normal mode

# Expansion Through Pmod Interface

- Two 2x6 Pmods provide expansion using 16 PL I/Os



HTU21D

|                          |          |        |                      |             |                  |  |
|--------------------------|----------|--------|----------------------|-------------|------------------|--|
| HTU21D Peripheral Module | Pmod PCB | HTU21D | Humidity Temperature | 1.5 to 3.6V | I <sup>2</sup> C |  |
|--------------------------|----------|--------|----------------------|-------------|------------------|--|

# Available Pmods

| Model                          | Package     | Sensor Type | Properties Measured                 | Power       | Interface        | Image                                                                                 |
|--------------------------------|-------------|-------------|-------------------------------------|-------------|------------------|---------------------------------------------------------------------------------------|
| TSYS01<br>Peripheral<br>Module | Pmod<br>PCB | TSYS01      | Temperature                         | 2.2 to 3.6V | I <sup>2</sup> C |    |
| TSYS02<br>Peripheral<br>Module | Pmod<br>PCB | TSYS02      | Temperature                         | 1.5 to 3.6V | I <sup>2</sup> C |    |
| MS5637<br>Peripheral<br>Module | Pmod<br>PCB | MS5637      | Pressure<br>Temperature             | 1.5 to 3.6V | I <sup>2</sup> C |    |
| HTU21D<br>Peripheral<br>Module | Pmod<br>PCB | HTU21D      | Humidity<br>Temperature             | 1.5 to 3.6V | I <sup>2</sup> C |   |
| KMA36<br>Peripheral<br>Module  | Pmod<br>PCB | KMA36       | Angular<br>Position                 | 3.0 to 5.5V | I <sup>2</sup> C |  |
| MS8607<br>Peripheral<br>Module | Pmod<br>PCB | MS8607      | Pressure<br>Temperature<br>Humidity | 1.5 to 3.6V | I <sup>2</sup> C |  |

# Lab 11 – TE Sensor Pmod

- Import example application code into a new project
- Connect TE Connectivity sensor module to MiniZed expansion port labeled Pmod 2
- Capture HTU21D humidity and temperature sensor data to the serial console



# Questions

---

- What peripheral does the iic\_v3\_4 driver support? (Hint : Refer to the MDD file)
  - Looking in the MDD file located at  
C:\Xilinx\SDK\2017.4\data\embeddedsw\XilinxProcessorIPLib\drivers\iic\_v3\_4\data it states **OPTION supported\_peripherals = (axi\_iic);** indicating it supports the AXI IIC IP Block

# Agenda

| Lecture    | Description                       | Labs   |
|------------|-----------------------------------|--------|
| Chapter 1  | Zynq System Architecture Basics   | Lab 1  |
| Chapter 2  | Xilinx SDK Overview               | Lab 2  |
| Chapter 3  | Standalone Board Support Package  | Lab 3  |
| Chapter 4  | Developing Applications           | Lab 4  |
| Chapter 5  | Connecting Hardware and Debugging | Lab 5  |
| Chapter 6  | First Stage Boot Loader           | Lab 6  |
| Chapter 7  | Flash Programming and Boot-up     | Lab 7  |
| Chapter 8  | SDK Project Management            | Lab 8  |
| Chapter 9  | Interrupts                        | Lab 9  |
| Chapter 10 | Xilinx Libraries                  | Lab 10 |
| Chapter 11 | TE Sensor Pmod                    | Lab 11 |
| Chapter 12 | Next Steps                        |        |

# Comprehensive Software Ecosystem Support



WIND RIVER

ENEA

arm

expresslogic

Micriµm



LAUTERBACH  
DEVELOPMENT TOOLS

Mentor  
Graphics®

And Lots More...

<https://www.xilinx.com/products/design-tools/software-zone/embedded-computing.html#os>

# Largest Portfolio of IP, Design Kits and Ref. Designs



- Widest Selection of Development Platforms and SOMs
  - Over 90 boards and SOM from Xilinx and partners
  - Embedded, intelligent control, video signal processing
  - 200+ FMC daughter cards
- Ready to Use Segment Solutions
  - Boards, IPs, reference designs, app notes, OS and drivers
  - Automotive, A&D, broadcast & pro A/V, consumer electronics, data center, emulation & prototyping, high performance computing, industrial, medical, test & measurement, wired and wireless communications
- Large Selection of AXI-based IPs
  - Xilinx IPs standardized on AXI
  - Large availability of Xilinx and Partner IPs
  - Enhanced portability between FPGAs and SoCs

# Getting Help and Support

- Visit MiniZed.org Support Forums:

[www.minized.org/forums/zed-english-forum](http://www.minized.org/forums/zed-english-forum)



- For Xilinx technical support, you may contact your local Avnet FAE or Xilinx Support site at <https://www.xilinx.com/support.html>
- On Xilinx site you will also find the following resources for assistance:
  - Documentation for Devices, Development Tools, Intellectual Property, Boards, Kits and Modules
  - Searchable Answer Database with Over 4,000 Solutions
  - User Forums
- Contact Avnet Support for any questions regarding MiniZed reference designs, kit hardware, or if you are interested in designing any of the kit devices into your next design

# Built-In Documentation - Xilinx DocNav

<https://www.xilinx.com/support/documentation-navigation/overview.html>



# Additional Training

- MiniZed.org Training and Videos Page  
[minized.org/support/trainings-and-videos](http://minized.org/support/trainings-and-videos)

Home → Support → Training and Videos

## Training and Videos

Learn how to create your own ZedBoard designs or see what others have done with ZedBoard by viewing our library of on-line trainings and videos. If you have a video that you would like to share, complete the on-line [video request form](#) for further instructions.

---

### MiniZed Speedway Design Workshops

[Developing Zynq Hardware \(Vivado 2017.1\)](#)

In the Developing Zynq Hardware Speedway, you will be introduced to the single ARM Cortex –A9 Processor core as you explore its robust AXI peripheral set. Doing so you will utilize the Xilinx embedded systems tool set to design a Zynq AP SoC system, add Xilinx IP as well as custom IP, run software applications to test the IP, and finally Debug your embedded system.

[Developing Zynq Software \(Vivado 2017.1\)](#)

In the Developing Zynq Software Speedway, you will be introduced to Xilinx SDK and shown how it offers everything necessary to make Zynq software design easy.

[Integrating Sensors on MiniZed with PetaLinux](#)

From within an Ubuntu OS running within a virtual machine, learn how to install PetaLinux 2017.1 and build embedded Linux targeting MiniZed. In the hands-on labs learn about Yocto and PetaLinux tools to import your own FPGA hardware design, integrate user space applications, and configure/customize PetaLinux.

[A Practical Guide to Getting Started with Xilinx SDSoC](#)

Using proven flows for SDSoC, the student will learn how to navigate SDSoC. Through hands-on labs, we will create a design for a provided platform and then also create a platform for the Avnet MiniZed. You will see how to accelerate an algorithm in the course lab.

- Xilinx Training – ATP offered courses, self-paced tutorials, and online training videos  
<https://www.xilinx.com/training.html>

# Objectives

---

- Introduce developers to Xilinx SDK
- Explore how SDK makes your job easier
- Connect SDK to hardware for execution and debug
- Utilize a peripheral interrupt to show real-time software response
- Show a basic example of how to use an external sensor module

