

# ADI Summer School



AHEAD OF WHAT'S POSSIBLE™

# Summer School outline

- ▶ Company overview
- ▶ Perspective
- ▶ Setup
- ▶ Hardware
  - Setup – LTSPice, Kicad
  - Get through basic and advanced electronics
  - Design an accelerometer
- ▶ HDL
  - Introduction
  - Pre-requisites – HDL specific setup
  - Resources, knowledge
  - Build an example project
- ▶ Software&Applications
  - Setup
  - No-OS
    - Introduction/overview no-OS
    - IIO framework
    - Drivers' development steps
    - Driver design – TBD
  - Linux
    - Introduction/overview Linux
    - IIO framework
    - Drivers' development steps
    - Driver design – TBD
  - Bindings setup
  - Simple app for displaying the processed data

# ADI Romania Design Center

- ▶ Founded in 2011
- ▶ Office 1 - UBC Riviera
  - 1,000 square meters, 100 people capacity
- ▶ Office 2 - UBC Tower
  - 1,000 square meters, 120 people capacity
- ▶ Multidisciplinary team
  - Hardware design
  - FPGA development (VHDL, Verilog)
  - Embedded software (C/C++, Linux)
  - Applications software (Python, MATLAB, C++)
  - Devops (Jenkins, Microsoft Azure, CI/CD)
  - System architecture
  - UX design
  - Program/Project management
- ▶ Project fields
  - RF Communications
  - Precision & High-Speed Instrumentation
  - Depth, Perception and Ranging (ToF, LIDAR)
  - Industrial Automation



# Office Plan



# Process Flow Diagram



## Specifications:

- Use Zybo Z7 as system board
- AD Conversion side: AD5592R
- Use free version for HDL tools
- Low to medium complexity for a graduate student, so it can be completed within the course duration

### 1. Accelerometer application using ADXL327

# Setup - Prerequisites

## Tools

- ▶ [TeraTerm](#) (Windows only) or [Putty](#) – to create UART connections with the devices and communicate with them
- ▶ [Cygwin](#) – Linux terminal for Windows
  - Make sure to have the latest versions for the following packages: attr, automake, bash, cmake, git, grep, gvim, make, ssh, perl, python, run, sed, vim, wget, which, xlsclients.
- ▶ Text editors: Visual Studio Code or Notepad++ on Windows, Visual Studio Code or VIM on Linux
- ▶ [WinScp](#) – connect to the SD card from device to process files using a GUI
- ▶ [Kuiper Imager](#) to write SD cards with a Kuiper image
- ▶ [IIO Oscilloscope](#)

## Prerequisites – Learning Materials

1. Git:
  - a. [Learn Git Branching](#) interactively, with animations
  - b. [How to write a good commit message](#)
  - c. For more details, check the [Git Book](#)
2. VIM basics:
  - a. [Shortcuts](#)
  - b. [Cheat sheet](#) and [another cheat sheet](#)
3. Linux basics:
  - a. [Frequent terminal commands](#)
  - b. [VIM text editor cheat sheet](#)
  - c. [edX CS course: Introduction to Linux](#)\* OS, files, etc. (takes about 1 month to complete). Check the syllabus for more details.
4. Linux\*: a few useful resources for a better understanding of the Linux Kernel drivers and devicetrees:
  - a. [\[ADI\] building the ADI Linux kernel](#)
5. Coding guidelines:
  - a. [HDL](#) – on GitHub, used for the Guideline Checker GitHub action

## Environment preparation - GitHub setup

- To use Git on your laptop, firstly you must do a [First-time Git setup](#)
- Follow the [Creating a personal access token \(classic\)](#) tutorial
- Copy the [Personal access token](#)
- Get the HTTPS links for both HDL and Linux repository from the [ADISummerSchool organization](#)



- Edit the paths:
  - `https://[copied_personal_access_token]@github.com/adisummerschool/hdl.git`
  - `https://[copied_personal_access_token]@github.com/adisummerschool/linux.git`
- Run the following commands in the workspace folder:
  - `git clone https://[copied_personal_access_token]@github.com/adisummerschool/hdl.git`
  - `git clone https://[copied_personal_access_token]@github.com/adisummerschool/linux.git`

## Prerequisites: hardware specific tools and learning materials

- Basic presentation of ADALM2000
- Install and get running the LTSpice? <https://www.analog.com/media/en/analog-dialogue/volume-53/number-4/get-up-and-running-with-ltspice.pdf>
- Install Kicad - <https://www.kicad.org/download/>
- M2K hardware training – for basic information –  
<https://wiki.analog.com/university/courses/tutorials/index>
- [https://wiki.analog.com/university/tools/m2k/users/reference\\_manual?s\[ \]=adalm2000](https://wiki.analog.com/university/tools/m2k/users/reference_manual?s[ ]=adalm2000)
- [https://wiki.analog.com/university/courses/electronics/labs?s\[ \]=m2k&s\[ \]=electronics](https://wiki.analog.com/university/courses/electronics/labs?s[ ]=m2k&s[ ]=electronics)
- [ADALM2000 Videos – YouTube](#)
- [Scopy](#) – for using ADALM2000 board to visualize signals on the Oscilloscope or generate various waveforms, powering other devices, etc.
- Advanced:
  - <https://www.analog.com/en/education/education-library/data-conversion-handbook.html>
- Project proposal: Accelerometer application using ADXL327 and AD5592R converter

## Accelerometer application – breadboard testing setup

### Specifications

- Use a USB 5V supply
- Design an on-board power supply to provide 3V to ADXL327
- Design the comparator to use for driving 3 LEDs corresponding to each axis of the accelerometer to test its movements
- *Hint – use the ADALP2000 components for the above designs*
- Use the ADALM2000 Scope channels to visualize the ADXL327 X, Y and Z analog signals
- [https://wiki.analog.com/university/labs/2\\_axis\\_tilt\\_sensor\\_adalm2000](https://wiki.analog.com/university/labs/2_axis_tilt_sensor_adalm2000)
- Block diagram:



## Accelerometer application – design stages



## Accelerometer application – Stage 1

### Objectives:

- Change the light intensity of the LEDs in proportion to the inclination of the accelerometer on X ,Y and Z axis.
- Use 2 LEDs for each axis, one for positive and one for negative side

### Stage 1: Breadboard design using leds as output



**Step 1:** Choose a USB-C socket and a linear regulator from part kit + corresponding passives to power on the accelerometer.

**Step 2:** Measure with M2K the output voltage of the accelerometer on each axis when the chip is in horizontal position and when you tilt it 90dgrs in each side of X , Y and Z axis (save the data). Choose capacitors for Xout , Yout and Zout.

**Step 3:** Design four differential amplifiers to scale the output for the next stage (ADC input) and choose the correct series resistors for (more details on the next slide).

## Accelerometer application – Stage 1

**Step 3:** Design six differential amplifiers to scale the output for the next stage (ADC input) and choose the correct series resistors for (more details on the next slide).



## Accelerometer application – breadboard testing setup

Scope channels visualizing accelerometer signals:



LED on if movement on X axis event registered



LED off - for the reverse movement on X axis: -x

## Accelerometer application – Final PCB setup

### Materials:

- ADALM2000 Active Learning Module
- ADALP2000 Parts kit
- Zybo Z7 board
- Solder-less breadboard
- Jumper wires
- 1 - ADXL327
- 1 - AD5592R
- 6 - LEDs
- Decoupling capacitors - TBD
- 3V3 Power supply - TBD
- Amplifiers for driving the LEDs - TBD
- 3 Potentiometers



## Accelerometer Application

Next steps:

- Implement the circuit in Kicad software
- Create footprints for the components if the case
- Create the layout for the circuit
- Test it
- Analyse the results

1. HDL introduction
2. GitHub
3. Project description
4. SPI communication
5. Project files
6. Extra resources
7. References



# Setup - Prerequisites

## HDL software installation Xilinx Vivado and Vitis 2022.2

- Choose the appropriate Self Extracting Web Installer



The screenshot shows the Xilinx Unified Installer download page. It displays two main sections: one for Windows OS and one for Linux OS. Each section includes a download link, an MD5 sum value, a 'Download Verification' button with three sub-options (Digests, Signature, Public Key), and a large green text overlay indicating the operating system.

| Operating System | Download Link                                                                                            | MD5 Sum Value                                    | Download Verification Options  |
|------------------|----------------------------------------------------------------------------------------------------------|--------------------------------------------------|--------------------------------|
| Windows OS       | <a href="#">Xilinx Unified Installer 2022.2: Windows Self Extracting Web Installer (EXE - 209.61 MB)</a> | MD5 SUM Value : 985168f6920c5ee2111c5d16573330e1 | Digests, Signature, Public Key |
| Linux OS         | <a href="#">Xilinx Unified Installer 2022.2: Linux Self Extracting Web Installer (BIN - 271.02 MB)</a>   | MD5 SUM Value : 9bf473b6be0b8531e70fd3d5c0fe4817 | Digests, Signature, Public Key |

# Setup - Prerequisites

## HDL software installation [Xilinx Vivado and Vitis 2022.2](#)

- Make sure you select the **Vitis** option:



# Setup - Prerequisites

## HDL software installation [Xilinx Vivado and Vitis 2022.2](#)

- Select **ONLY** the following plug-ins and make sure that you have the required free space:



## Environment preparation - Setup Cygwin/Linux terminal

- Exporting the paths to the installed tools and HDL repository:
  - **echo \$PATH** to see how your \$PATH looks like before exporting anything
  - In Cygwin/Linux terminal, type **vim ~/.bashrc** (VIM must be installed as a package for Cygwin prior to this) and write the following paths, modifying them accordingly to your system and preference (if you don't use Cygwin, then **do not** put /cygdrive/!)
  - **export PATH=\$PATH:/cygdrive/partition/path/to/Xilinx/Vivado/2022.2/bin**
  - **export PATH=\$PATH:/cygdrive/partition/path/to/Xilinx/Vitis/2022.2/bin**
  - **export PATH=\$PATH:/cygdrive/partition/path/to/hdl/bin**
  - now you can do again *echo \$PATH* to see how the \$PATH changed



|                   |       |       |        |       |       |        |     |        |          |                   |              |        |        |        |        |
|-------------------|-------|-------|--------|-------|-------|--------|-----|--------|----------|-------------------|--------------|--------|--------|--------|--------|
| <b>AMD/Xilinx</b> | AC701 | KC705 | VCT707 | ZC702 | ZC706 | ZCU102 | Zed | CoraZ7 | Microzed | ADRV9009-EG11-SOM | ADRV936x-SOM | VCK190 | KCU105 | VCU118 | VCU128 |
|-------------------|-------|-------|--------|-------|-------|--------|-----|--------|----------|-------------------|--------------|--------|--------|--------|--------|

|                     |        |       |           |       |      |       |
|---------------------|--------|-------|-----------|-------|------|-------|
| <b>Intel/Altera</b> | A10SOC | C5SOC | DE10 Nano | A10GX | A5GT | A5SOC |
|---------------------|--------|-------|-----------|-------|------|-------|

\* supported in previous releases

## ► Field-Programmable Gate Array

- meaning the firmware can be modified without disassembling it or returning it to the manufacturer

## ► Semiconductor devices

- matrix of CLBs and programmable interconnects; reconfigurable
- Distinguished from ASICs which are custom manufactured for specific design tasks
- The most detailed and enthusiastic presentation about FPGA can be found [here\\*](#)



| FPGA                                                                                                                               | PROCESSOR                                                                                                                                                 |
|------------------------------------------------------------------------------------------------------------------------------------|-----------------------------------------------------------------------------------------------------------------------------------------------------------|
| <ul style="list-style-type: none"><li>• Programmable Hardware</li><li>• High Speed</li><li>• Reusable</li><li>• Flexible</li></ul> | <ul style="list-style-type: none"><li>• Accessibility</li><li>• Operating System</li><li>• Common memory and peripherals</li><li>• Ready to use</li></ul> |
| Examples: Artix 7, Kintex 7 etc.                                                                                                   | Examples: Raspberry Pi, Arduino                                                                                                                           |

## ■ Open-source reference designs

- Precision Converters (AD40xx, AD4630-24...)
- High Speed Converters (AD9081, AD9144, AD9680...)
- Transceivers (AD9361, ADRV9371, ADRV9009...)

## ■ Prototyping boards

- AD-FMCOMMS2/3/4/5-EBZ
- AD-FMC-DAQ2/3-EBZ
- AD-FMCOMMS11-EBZ
- AD-FMCOMMS8-EBZ
- AD-FMCLIDAR1-EBZ

## ■ Standalone SOMs

- ADRV9361-Z7035/ADRV9364-Z7020
- ADRV9009-ZU11EG

## ■ Educational Systems

- ADALM1000/ADALM2000
- ADALM-Pluto



- ▶ Map of the HDL repository:

- **`.github`**: contains the resources needed for a GitHub action to be run: the scripts that are run in the workflows and the workflow code itself
- **`/docs`**: contains the coding guideline by which the guideline checker script is correcting the files and raising warnings
- **`/library/scripts`** and **`/projects/scripts`**: are the scripts that can be run on them
- **`/library/Makefile`**: contains all the IPs that exist there (what is written here will be built when running *make lib-all*)
- **`/library/IP_name/Makefile`**: contains all the file dependencies which are needed for this IP to be built
- **`/projects/project_name/carrier/Makefile`**: contains all the IP dependencies which are needed for this project to be built
- More details about the structure of the repository can be found on the [Git repository wiki page](#) and about the projects' structure can be found [here](#)

## Part of the HDL IP Library

**ADC/DAC/Transceiver specific**  
**Parallel LVDS/CMOS**

AD7668

ADRV9001

AD9265

AD9361

AD9265

**ADC/DAC specific**  
**SPI Engine**

AD7616-1

AD40xx

AD463x

AD738X

AD4134

**JESD204**  
**All ADI JESD204 devices**

AD9081 / MxFE

ADRV9009

AD9144

AD9680

**Video**

AXI\_HDMI\_RX –  
ADV7611

AXI\_HDMI\_TX –  
ADV7511

**System utilities**

AXI\_FAN\_CONTROL

AXI\_CLKGEN

AXI\_DMAC

OFFLOAD FIFO

UTIL\_PACK/UPACK

Github repository: [HDL](#)

## Zybo Z7-10 FPGA

PS

PL



► **PS – Processing System** (the blue component)

► **PL – Programmable Logic** – all the other components that are added by the user (it can be seen better in the Block Diagram in Vivado)

- For **Zynq** architecture, the boot files are **ulmage + devicetree.dtb** and **BOOT.BIN**
- For **ZynqMP** architecture, the boot files are **Image + system.dtb** and **BOOT.BIN**

## ► **Booting with a custom design**

- To understand better the structure of ADI's project framework, check [Project files for Xilinx boards](#). There you will find out the purpose of each file.
- Useful information for generating the boot files:
  - Boot image: BOOT.BIN is the HDL part. It requires the files specified in [Project files for Xilinx boards](#); using these, the project must be built (see [How to build an HDL project](#)), to have the **.xsa**; afterwards, a **u-boot.elf** file should be taken from the SD card for the BOOT.BIN to be generated (see How to build the boot image BOOT.BIN)
  - Linux Kernel image: depending on the configuration, the commands differ (see [How to build the Linux Kernel image and Devicetree Blob from source](#)); it will result an *image* file
  - Devicetree Blob: it is generated from a Devicetree Structure file (**.dts**) (see [How to build the Linux Kernel image and Devicetree Blob from source](#)); it will result a **.dtb** file

## ► **Booting with the reference design**

- The alternative to building these from scratch, is to take them from the SD card, where the reference designs are (after step [How to prepare an SD card](#)):
  - BOOT.BIN and the Devicetree Blob (**.dtb**) can be taken from the folders that have your desired configuration as a name
  - The Linux Kernel image can be taken from the common folder for the supported architectures (**zynq-common / zynqmp-common**)

# HDL - Project diagram



# HDL - PMOD connector

*Positioning of SPI pins on the EVAL-AD5592R-PMDZ board*



*SPI pins on the PMOD connector from the Zybo Z7-10 board*



## A. Start-up

[ADI HDL User Guide](#) is a starting point to get more information about our projects and structure.

[HDL coding guideline](#) – to maintain things in an ordered manner, when submitting a Pull Request (PR) a script is run in a GitHub action, and it will raise warnings regarding one's code if some rules from this document are not respected.

## B. Resources

The following links are meant as a support for the Knowledge chapter, and they are written in the proper order of execution as steps (the ones with \* will be of good use for the next teams)

1. [How to prepare an SD card](#) with a Kuiper image
2. [How to build an HDL project](#)
3. [How to build the boot image BOOT.BIN](#) (two ways):
  - Using Vivado Tcl console, by running **adi\_make::boot\_bin** (for this option, *u-boot.elf* should be taken from the appropriate folder from the SD card that now has a Kuiper image) – check the steps from [here](#)
  - For [Zynq architecture](#) or for [ZynqMP architecture](#)
4. [How to build the Linux Kernel image and Devicetree Blob from source](#) for [Zynq architecture](#)\* or for [ZynqMP architecture](#)\*
5. [How to build the No-OS with GNU make](#)\*

# HDL – Specific prerequisites

1. **Xilinx Vivado and Vitis** – free 2022.2 version
2. **Verilog/VHDL training:** for the passionate and curious ones about this side, the following training will give you a glimpse of the basics – towards intermediate difficulty projects
  - [Verilog beginner's tutorial](#) which contains theory, hands-on examples, etc.
  - [An intermediate tutorial\\*](#) (it's still work in progress, but it will touch great topics)
  - [HDL labs from Xilinx\\*](#) (requires a few days to complete): takes you through several digital design concepts and helps you get accustomed to VHDL/Verilog if your background is with Verilog/VHDL
  - [An introduction to formal methods\\*](#) from [zipcpu.com](#)
3. **Tcl scripts:** *Tcl or Tool Command Language*, is an open-source multi-purpose C library which includes a powerful dynamic scripting language; in the HDL team, we use **.tcl** scripts to describe our project such that Xilinx Vivado understands it and can build it
  - More about Tcl can be found on [Tcler's Wiki](#) and on [Tcl Introduction and Tutorial\\*](#)
4. **Makefile:** contains all the dependencies needed for an IP/project to be built. The projects need several IPs to be previously built, and sometimes some IPs include other IPs or source files which they depend on
  - More about [Makefiles\\*](#)
5. **BOOT.BIN:** it's the result (boot image) after building the HDL project with a few extra files; this will be programmed into the FPGA, either through SD card or via JTAG
  - [Xilinx Confluence Documentation\\*](#) about it
6. **u-boot.elf:** Universal Boot Loader that is frequently used in the Linux community, and it is needed for the BOOT.BIN generation
  - More about it on the [Xilinx Confluence Documentation about U-Boot\\*](#)

# HDL - Knowledge - SPI communication

## SPI COMMAND FOR CONFIGURING THE CHIP AS AN ADC

| MSB |     |                  |     |     |          |    |      |      |      |      |      |      |      |      | LSB |
|-----|-----|------------------|-----|-----|----------|----|------|------|------|------|------|------|------|------|-----|
| D15 | D14 | D13              | D12 | D11 | D10      | D9 | D8   | D7   | D6   | D5   | D4   | D3   | D2   | D1   | D0  |
| 0   |     | Register address |     |     | Reserved |    | ADC7 | ADC6 | ADC5 | ADC4 | ADC3 | ADC2 | ADC1 | ADC0 |     |

Table 26. Bit Descriptions for the ADC Pin Configuration Register

| Bit(s)     | Bit Name             | Description                                                                                                                                 |
|------------|----------------------|---------------------------------------------------------------------------------------------------------------------------------------------|
| D15        | MSB                  | Set this bit to 0.                                                                                                                          |
| D14 to D11 | Register address     | Set these bits to 0b0100.                                                                                                                   |
| D10 to D8  | Reserved             | Reserved. Set these bits to 0.                                                                                                              |
| D7 to D0   | ADC7 to ADC0<br>Text | Select I/Ox pins as ADC inputs.<br>1: I/Ox is an ADC input.<br>0: I/Ox function is determined by the pin configuration registers (default). |



[Introduction to SPI interface](#)

# HDL - Knowledge - SPI communication



[Introduction to SPI interface](#)

# HDL – Project Structure

- We will create the described project for the Zybo Z7-10 FPGA board using the EVAL-AD5592R-PMDZ ADC.
- For the following files, there are already templates, and they can be found at [hdl/projects/ad5592r\\_pmdz](#)

**system\_constr.xdc :**

- FPGA pins are connected to INPUT/OUTPUT ports

**system\_top.v:**

- INPUT/OUTPUT ports are connected to block design ports

**system\_bd.tcl :**

modules(IPs) and ports are added in:

- projects/common/zyboz7/**zyboz7\_system\_bd.tcl**
- projects/ad5592r\_pmdz/common/**ad5592r\_pmdz\_bd.tcl**





| Rotation Axis | Zybo-Z7 | ADXL327 |
|---------------|---------|---------|
| X1            | LD0     | D1      |
| X2            | LD1     | D2      |
| Y1            | LD2     | D3      |
| Y2            | LD3     | D4      |



$$(1) f_{\text{ref\_clk}} = 100\text{MHz}$$

$$(2) T_{\text{PWM}} = 2^{12} * T_{\text{ref\_clk}}$$

1. Starting from the block design of the IP the **axi\_pwm\_custom.v** file should be completed with the modules instantiation
2. The interface module should generate a PWM signal with **variable duty cycle** based on the **input data magnitude**
3. The data wires should be connected to the **up\_adc\_channel** modules **conversion\_data** port



1. Starting from the schematic of the board, the [constraints file](#) is written
  - a) For this, the pinout of the board is needed as well as the template for the constraints
2. After identifying the I/Os, the [board design](#) of the project will be written
3. The [top file](#) will be written with regards to the SPI interface
4. The custom PWM generator should be created in the **library/axi\_pwm\_led** folder and added in the **projects/ad5592r\_pmdz/common/ ad5592r\_pmdz\_bd.tcl**
5. The [Makefile](#) can be written, with the dependencies and the needed sources
6. In order to generate the [BOOT.BIN](#) and to program the FPGA, we need all the files previously created, and an **u-boot.elf** and **zynq\_fsbl.elf** (which will be provided to you)

# HDL – 1. Constraints(1)

- ▶ It's the connection between the physical pins of the FPGA that you want to use and the HDL code that describes the behavior of the FPGA
- ▶ Here you define the board specific pins, clocks, etc.
- ▶ Contents [\[1\]](#) in order suggested by Xilinx:
  - Timing assertions section:
    - Primary clocks, virtual clocks, generated clocks, clock groups
    - Bus skew constraints
    - Input and output delay constraints
  - Timing exceptions section:
    - False paths, max/min delay, multicycle paths
    - Case analysis, disable timing
  - Physical constraints section:
    - Setting-up variables for easy configuration
    - Pin specifications
  - Learn more here [\[2\]](#)

# HDL – 1. Constraints(2)

1. Start by searching for the [schematic](#) of the FPGA and [additional devices](#)
2. Take the [default constraints file](#) and leave uncommented the pins that you will be using
  - 1) We will need the Pmod Headers **JC** and **JD** for the SPI connections and the **LEDs pins** for the PWM generator. Uncomment those lines and remove the others
  - 2) These pins have default names, so change the names to be suggestive (the names are the ones specified with get\_ports, in curly braces) and close to the ones from the schematic
3. This file will be put at **hdl/projects/ad5592r\_pmdz/zyboz7/system\_constr.xdc**

Example of pin constraint:

```
set_property -dict {PACKAGE_PIN Y17 IOSTANDARD LVCMOS33 DIFF_TERM TRUE} [get_ports pin_name]
```

- PACKAGE\_PIN: the pin number found in the FPGA's schematic
- IOSTANDARD: defines what Voltage Level your interface operates on and what kind of signaling is;
  - Low-Voltage CMOS transistor is used on this pin with a voltage of 3.3V
  - There are many others in [3]
- DIFF\_TERM: internal differential termination that can be activated; used for the signal not to reflect, when having LVDS pairs of signals

- ▶ **Base design** file of the **carrier**: projects/common/zyboz7/**zyboz7\_system\_bd.tcl**
- ▶ **Board design** file: projects/ad5592r\_pmdz/common/**ad5592r\_pmdz\_bd.tcl**
- ▶ **Design** file of the **project**: projects/ad5592r\_pmdz/ zyboz7/**system\_bd.tcl**
  
- ▶ In all design files (of a project), firstly the base design must be sourced, and then the board design.

Example:

```
source $ad_hdl_dir/projects/common/ zyboz7/ zyboz7_system_bd.tcl  
source ../common/ ad5592r_pmdz_bd.tcl
```

## 3. Top file

- Top wrapper file, in which the `system_wrapper.v` module is instantiated
- `system_wrapper.v` is a tool generated file and can be found at  
`<project_name>.srcs/sources_1/bd/system/hdl/system_wrapper.v`
- The I/O ports of this Verilog module will be connected to actual I/O pads of the FPGA

## 4. Project design

- This Tcl script is creating the actual Vivado project and runs the synthesis and implementation of the design
- It needs all files used in the project to be specified

## 5. Makefile

- Contains all the dependencies needed for the project to be built

## 6. BOOT.BIN

- It's the result (boot image) after building the HDL project with the previously described files
- This will be programmed into the FPGA (through SD card or via JTAG)
- To learn more about the structure, check [this](#)\*

- [AD Circuits from the Lab](#) videos
- [Digital Design and Computer Architecture course – ETH Zürich, with Onur Mutlu](#) (and all his courses from his YouTube page)
- [Vivado QuickTake Tutorials](#)
- [FPGA design](#) presentations from Intel

## HDL – References

- [\[1\]UG903\(v2022.1\): Ordering Your Constraints – Recommended Constraints Sequence](#)
- [\[2\]UG949\(v2022.1\): Defining Timing Constraints – Defining Timing Constraints in Four Steps](#)
- [\[3\]UG471\(v1.10, 2018\): Supported I/O Standards and Terminations](#)

No-OS

Linux

## Pre-requisites

- Knowledge of C/C++
- Basic understanding of Github and git commands
- Virtualbox installed
- VM with Debian (provided)

## Project Architecture



## Embedded Software Architecture



## Kernel-space vs User-space



## Zynq boot stages

What are:

- ZSBL (Zero Stage Boot Loader)
- FSBL (First Stage Boot Loader)
- SSBL (Second Stage Boot Loader) or U-Boot
- Kernel space
- User space

What does each of them do?

Why make it soooo complicated?

## Linux Kernel

*Download a Linux image (rootfs.ext2) – and run it in the versatile qemu emulation*

Build steps:

1. Choose or create a working directory
2. Install git with the following command: `sudo apt-get install git -y`
3. Make a local clone of the Linux kernel repository:  
`git clone https://github.com/adisummerschool/linux.git`
4. Move to linux directory: `cd linux`
5. Check out the prepared branch : `git checkout versatile_adi_defconfig`
6. Create your own branch: `git checkout -b my_branch`
7. Organize your work and download the cross compiler in a different folder of your choice: `wget https://developer.arm.com/-/media/Files/downloads/gnu-a/10.3-2021.07/binrel/gcc-arm-10.3-2021.07-x86\_64-arm-none-linux-gnueabihf.tar.xz`
8. Unzip the archive using: `tar xvf gcc-arm-10.3-2021.07-x86_64-arm-none-linux-gnueabihf.tar.xz`

## Linux Kernel

Build steps:

9. Come back into the folder where the cloned repo is and set some environment variables:

- `export ARCH=arm`
- `export CROSS_COMPILE=<path-to-the-folder-where-compiler-is>/`  
`gcc-arm-10.3-2021.07-x86_64-arm-none-linux-gnueabihf/bin/arm-none-linux-gnueabihf-`

10. Install additional packages for compiling the kernel: `sudo apt-get install flex bison -y`

11. Create the .config file which contains the list of the features to be included in the kernel: `make versatile_adi_defconfig`

12. `sudo apt-get install libncurses-dev -y`

13. Create the kernel image zimage: `make zImage -j4`

## Linux Kernel

### Rootfs

- The root filesystem is the top-level directory of the filesystem. It must include all the executables and libraries required to boot the remaining filesystems. After the system is booted, all other filesystems are mounted on standard, well-defined mount points as subdirectories of the root filesystem.
- Rootfs is a file system which describes how to store and access data. The kernel is the actual code which executes.

Download and extract a Linux image (rootfs.ext2):

[https://swdownloads.analog.com/cse/kuiper/iio\\_rootfs.zip](https://swdownloads.analog.com/cse/kuiper/iio_rootfs.zip)

## Linux

- Optional additional information: Embedded Linux course: <https://bootlin.com/doc/training/embedded-linux/embedded-linux-slides.pdf>, Linux kernel course: <https://bootlin.com/doc/training/linux-kernel/linux-kernel-slides.pdf>
- Consult examples of drivers' implementation – gradual complexity increase - <https://bitbucket.analog.com/projects/SDG/repos/sw-tools/browse/iio>
- IIO framework:
  - IIO: <https://wiki.analog.com/software/linux/docs/iio/iio>
  - LibIIO: <https://wiki.analog.com/resources/tools-software/linux-software/libiio>
  - IIO Scope: [https://wiki.analog.com/resources/tools-software/linux-software/iio\\_oscilloscope](https://wiki.analog.com/resources/tools-software/linux-software/iio_oscilloscope)
  - Scopy: <https://wiki.analog.com/university/tools/m2k/scopy>

## No-OS intro:

- Introduction: <https://wiki.analog.com/resources/no-os/overview>
- Additional information: <https://www.analog.com/en/analog-dialogue/articles/understanding-and-using-the-no-os-and-platform-drivers.html>
- Running a no-OS application on a selected device, after hdl build – steps to be added
- Build a software app with TinyIIOD and test the connection to the server – ex: ADRV9002/9009

## Bindings

- Setup for bindings support
- Choose a platform to develop an app based on the previously developed drivers
- Ex: Build libiio in Linux with Python  
bindings: [https://github.com/analogdevicesinc/libiio/blob/master/README\\_BUILD.md](https://github.com/analogdevicesinc/libiio/blob/master/README_BUILD.md)

# Thank You! Feedback?

