

# **Integrating Arm Cortex-M Processors into Xilinx FPGAs**

## **Course Workbook**

# Table of Contents

|                                             |                         |
|---------------------------------------------|-------------------------|
| About this Workbook                         | <a href="#">Page 3</a>  |
| Pre-Lab: Workshop Pre-requisites            | <a href="#">Page 4</a>  |
| Lab 1: Exploring the Architecture in Vivado | <a href="#">Page 7</a>  |
| Lab 2: Saying Hello World                   | <a href="#">Page 25</a> |
| Lab 3: Completing a Simple Application      | <a href="#">Page 47</a> |

# About this Workbook

This workbook is designed to be used in conjunction with the Integrating Arm Cortex-M processors in Xilinx FPGAs course.

The contents of this workbook are created by Adiuvo Engineering & Training, Ltd.

If you have any questions about the contents, or need assistance, please contact Adam Taylor at [adam@adiuvoengineering.com](mailto:adam@adiuvoengineering.com).

# **Pre-Lab**

## Workshop Pre-requisites

# Required Hardware

The hands-on labs in this course use the following hardware:

- Digilent Arty S7-50 development board
- Digilent PmodNAV
- Digilent PmodHYGRO
- USB-A to Micro-B cable

# Downloads and Installations

**Step 1** – Download and install the following at least 1 day prior to the workshop. This may take a significant amount of time and drive space.

|                                                                                   |                          |
|-----------------------------------------------------------------------------------|--------------------------|
| Vivado 2018.2<br>**Please check that it is this version and not a newer version** | <a href="#">Download</a> |
| Digilent Board Files                                                              | <a href="#">Download</a> |
| Arm Design Start FPGA IP<br>**Download Cortex-M1 for Xilinx**                     | <a href="#">Download</a> |
| Arm Keil MDK Tools                                                                | <a href="#">Download</a> |
| Arm Keil Licensing Tool                                                           | <a href="#">Download</a> |
| Digilent Vivado IP – Master Branch                                                | <a href="#">Download</a> |

# **Lab 1**

## Exploring the Architecture in Vivado

# Lab 1: Exploring the Architecture in Vivado

**Step 1** - Ensure you have the following environment path variables set:

**C:\Keil\_v5\ARM\ARMCC\bin**

**C:\Xilinx\Vivado\2018.2\bin**



# Lab 1: Exploring the Architecture in Vivado

**Step 2** – Navigate to the directory containing the downloaded Arm M1 Core. This will be called **AT472-BU-98000-r0p1-00rel0.tgz**.

**Step 3** – Using a compression program (e.g., seven zip) unzip everything, including the inner directory.



# Lab 1: Exploring the Architecture in Vivado

**Step 4** – When extracted you should see the directory structure below.



The screenshot shows a Windows File Explorer window displaying the contents of a folder named "AT472-BU-98000-r0p1-00rel0". The path in the address bar is: ARM\_ESC > AT472-BU-98000-r0p1-00rel0 > AT472-BU-98000-r0p1-00rel0 > AT472-BU-98000-r0p1-00rel0. The folder structure includes subfolders for "docs", "hardware", "software", and "vivado", along with a PDF file ("Arm\_Cortex-M1\_DesignStart\_FPGA\_Xilinx...") and a text file ("THIRD-PARTY\_SW.txt").

| Name                                     | Date modified    | Type               | Size   |
|------------------------------------------|------------------|--------------------|--------|
| docs                                     | 18/01/2019 11:41 | File folder        |        |
| hardware                                 | 18/01/2019 11:41 | File folder        |        |
| software                                 | 18/01/2019 11:41 | File folder        |        |
| vivado                                   | 18/01/2019 11:41 | File folder        |        |
| Arm_Cortex-M1_DesignStart_FPGA_Xilinx... | 17/01/2019 15:30 | Adobe Acrobat D... | 494 KB |
| THIRD-PARTY_SW.txt                       | 10/12/2018 12:23 | TXT File           | 3 KB   |

# Lab 1: Exploring the Architecture in Vivado

**Step 5** – If you have not installed the Digilent Board files already, copy the Digilent boards contained in the directory below into <Vivado Install path>\Vivado\2018.2\data\boards\board\_files

| XilinxBoardStore-2018.2.zip > XilinxBoardStore-2018.2 > boards > Digilent |             |                 |               |      |       |                  |
|---------------------------------------------------------------------------|-------------|-----------------|---------------|------|-------|------------------|
| Name                                                                      | Type        | Compressed size | Password p... | Size | Ratio | Date modified    |
| arty                                                                      | File folder |                 |               |      |       | 13/12/2018 20:55 |
| arty-a7-35                                                                | File folder |                 |               |      |       | 13/12/2018 20:55 |
| arty-a7-100                                                               | File folder |                 |               |      |       | 13/12/2018 20:55 |
| arty-s7-25                                                                | File folder |                 |               |      |       | 13/12/2018 20:55 |
| arty-s7-50                                                                | File folder |                 |               |      |       | 13/12/2018 20:55 |
| arty-z7-10                                                                | File folder |                 |               |      |       | 13/12/2018 20:55 |
| arty-z7-20                                                                | File folder |                 |               |      |       | 13/12/2018 20:55 |
| basy3                                                                     | File folder |                 |               |      |       | 13/12/2018 20:55 |
| cmod_a7-15t                                                               | File folder |                 |               |      |       | 13/12/2018 20:55 |
| cmod_a7-35t                                                               | File folder |                 |               |      |       | 13/12/2018 20:55 |
| cmod-s7-25                                                                | File folder |                 |               |      |       | 13/12/2018 20:55 |
| cora-z7-07s                                                               | File folder |                 |               |      |       | 13/12/2018 20:55 |
| cora-z7-10                                                                | File folder |                 |               |      |       | 13/12/2018 20:55 |

# Lab 1: Exploring the Architecture in Vivado

**Step 6** – Open Vivado 2018.2. If you are familiar with Vivado do not do this by opening the project file.

**Step 7** – Change the directory using the TCL console to:

```
cd C:\<YOUR  
DIRECTORY>\AT472-  
BU-98000-r0p1-00rel0
```



# Lab 1: Exploring the Architecture in Vivado

**Step 8** – In the TCL Console enter the following command `exec subst V: .`

Make sure there is a space between “`:`” and “`.`”

This gets around the character limit on file paths in Windows by mapping the PWD to the V directory. Using a file browser to explore the V directory should show this file structure:



The screenshot shows a Windows File Explorer window titled "OS (V:)". The window displays a list of files and folders in a grid format. The columns are labeled "Name", "Date modified", "Type", and "Size". The "Name" column includes icons for each item: a folder for "docs", "hardware", "software", and "vivado"; an Acrobat PDF icon for "Arm\_Cortex-M1\_DesignStart\_FPGA\_Xilinx..."; and a text file icon for "THIRD-PARTY\_SW.txt". The "Date modified" column shows dates ranging from 10/12/2018 to 18/01/2019. The "Type" column indicates the nature of each item, and the "Size" column provides the file size for the non-directory items.

| Name                                     | Date modified    | Type               | Size   |
|------------------------------------------|------------------|--------------------|--------|
| docs                                     | 18/01/2019 11:41 | File folder        |        |
| hardware                                 | 18/01/2019 11:41 | File folder        |        |
| software                                 | 18/01/2019 11:41 | File folder        |        |
| vivado                                   | 18/01/2019 11:41 | File folder        |        |
| Arm_Cortex-M1_DesignStart_FPGA_Xilinx... | 17/01/2019 15:30 | Adobe Acrobat D... | 494 KB |
| THIRD-PARTY_SW.txt                       | 10/12/2018 12:23 | TXT File           | 3 KB   |

# Lab 1: Exploring the Architecture in Vivado

**Step 9** – The next thing we need to do is map in the IP repository. In Vivado click on **Tools → Settings**



# Lab 1: Exploring the Architecture in Vivado

**Step 10 – In the dialog box select IP Defaults.**



# Lab 1: Exploring the Architecture in Vivado

**Step 11** – Select the Add IP repository button (shown as a +).

Navigate to  
**V:\Vivado\Arm\_IPI\_Repository**



# Lab 1: Exploring the Architecture in Vivado

**Step 12** – We are now ready to open the project. Select **File→Project→Open**.

Navigate to **V:/hardware/m1\_for\_arty\_s7/m1\_for\_arty\_s7**

Select the project file **m1\_for\_arty\_s7.xpr**



# Lab 1: Exploring the Architecture in Vivado

**Step 13** – If you see a critical message about simulation do not worry. Click on **Continue / OK**.

To open the block diagram, select on the > arrow next to the top level.



# Lab 1: Exploring the Architecture in Vivado

**Step 14** – Double click on the highlighted file. This will open the block diagram.



# Lab 1: Exploring the Architecture in Vivado

**Step 15** – If you want to pop out and explore the block diagram click on the button highlighted below.

You can examine the settings of the IP cores by double clicking on them, however, do not change anything.



# Lab 1: Exploring the Architecture in Vivado

**Step 16** – The next step is to set up the software environment launch SDK by selecting **File→Launch**.

This will open a dialog, set the dialog as below in the diagram.



# Lab 1: Exploring the Architecture in Vivado

**Step 17** – If you see a warning click **Yes**, SDK will then open



# Lab 1: Exploring the Architecture in Vivado

**Step 18** – We need to add in the SW IP so that we can build the SW application correctly.

Select Xilinx→Repositories.



# Lab 1: Exploring the Architecture in Vivado

**Step 19** – In the resultant dialog select the following directory:

**V:\Vivado\Arm\_SW\_repository**

We are now ready to start using our Arm Cortex-M1 system, this completes Lab 1!



# **Lab 2**

## Saying Hello World

# Lab 2: Saying Hello World

**Step 1 – Wait for Vivado to complete the bitstream generation.**



# Lab 2: Saying Hello World

**Step 2 – Export the hardware definition select**

**File→Export→Export Hardware**



# Lab 2: Saying Hello World

**Step 3** – This will create a pop up. Select the export location as **V:\software**

You do not need to include the bit stream

If you see the warning below click **Yes**.



# Lab 2: Saying Hello World

**Step 4** – Next, we need to open XDSK. Select

**File→Launch SDK**



# Lab 2: Saying Hello World

**Step 5** – In the pop up box, for the export location select the location we just exported the hardware definition to (**V:\Software**) and select the workspace located at:

**V:\software\m1\_for\_arty\_s7\sdk\_workspace**



# Lab 2: Saying Hello World

**Step 6** – Once SDK is opened, we will see the hardware definition imported into SDK. Note, the part should show **xc7S50**. You will also see the address spaces for all of the added peripherals.



# Lab 2: Saying Hello World

**Step 7** – The next step in SDK is to create a BSP, this will create APIs which enable us to work with the peripherals included in the design. Select **File→New→Board Support Package**.



# Lab 2: Saying Hello World

**Step 8 –** In the next dialog leave the name as the automatically generated one and click **Finish**.



# Lab 2: Saying Hello World

**Step 9 –** This will open the BSP configuration page. Explore around and ensure the **STDIN STDOUT** is set to the **AXI UART**. Once you have finished exploring click **Finish** and the BSP will be generated.

**Board Support Package Settings**

Control various settings of your Board Support Package.

**Overview**

**standalone\_bsp\_0**

OS Type: **standalone**

OS Version: **6.7**

Standalone is a simple, low-level software layer. It provides access to basic processor features such as caches, interrupts and exceptions as well as the basic features of a hosted environment, such as standard input and output, profiling, abort and exit.

Hardware Specification: V:\software\m1\_for arty\_s7\ sdk\_workspace\m1\_for arty\_s7\_wrapper\_hw\_platform\_0\system

Processor: CORTEXM1\_AXI\_0

Check the box next to the libraries you want included in your Board Support Package. You can configure the library in the navigator on the left.

| Name | Version | Description |
|------|---------|-------------|
|      |         |             |

**Configuration for OS: standalone**

| Name                          | Value          | Default | Type       | Description                                    |
|-------------------------------|----------------|---------|------------|------------------------------------------------|
| hypervisor_guest              | false          | false   | boolean    | Enable hypervisor guest support for A53 64b    |
| lockstep_mode_debug           | false          | false   | boolean    | Enable debug logic in non-JTAG boot mode       |
| sleep_timer                   | none           | none    | peripheral | This parameter is used to select specific time |
| stdio                         | axi_uartlite_0 | none    | peripheral | stdin peripheral                               |
| stdout                        | axi_uartlite_0 | none    | peripheral | stdout peripheral                              |
| ttc_select_cntr               | 2              | 2       | enum       | Selects the counter to be used in the repetit  |
| zynqmp_fsbl_bsp               | false          | false   | boolean    | Disable or Enable Optimization for FSBL's BS   |
| microblaze_exceptions         | false          | false   | boolean    | Enable MicroBlaze Exceptions                   |
| enable_sw_intrusive_profiling | false          | false   | boolean    | Enable S/W Intrusive Profiling on Hardware     |

# Lab 2: Saying Hello World

**Step 10** – Once the BSP has finished generating you will notice a new MSS file opens in SDK, along with a new project under the project explorer. This is the board support package. You can see the BSP files and the APIs included in the design.



# Lab 2: Saying Hello World

**Step 11** – Copy the files

**Xpsuedo\_asm\_rvct.c**

**Xpseudo\_asm\_rvct.h**

From **V:\vivado\Arm\_sw\_repository\CortexM\bsp\standalone\_v6\_7\src\arm\cortexm1\armcc**

Into **V:\software\m1\_for\_artys7\sdk\_workspace\standalone\_bsp\_0\CORTEXM1\_AXI\_0\include**

# Lab 2: Saying Hello World

**Step 12** – We now need to develop our SW application in Arm KEIL.

Navigate to **V:/software/m1\_for\_arty\_s7/Build\_Keil/**. Click on the file **m1\_for\_arty\_s7.uvprojx**  
This will open the Arm Keil project.



# Lab 2: Saying Hello World

**Step 13** – Make sure the target is set to **m1\_for\_arty\_s7**.

Open the **Main** directory under the project, and double click on **main.c**. This will open the file for editing.

**Step 14** – Scroll down to **line 149** and change the output string from

*print ("Example design for Digilent S7 board\r\n");*

to

*print ("Adiuvo Tutorial Example design for Digilent S7 board\r\n");*



# Lab 2: Saying Hello World

**Step 15** – Before we can click on Build, we need to check the name of the Arm Cortex processor generated by SDK. Use a file explorer and navigate to

**V:\software\m1\_for\_arty\_s7\sdk\_workspace\standalone\_bsp\_0**

Ensure the folder is named **CORTEX\_M1\_0** and not **CORTEXM1\_AXI\_0** or similar, if they are, correct the naming to **CORTEX\_M1\_0**.

# Lab 2: Saying Hello World

**Step 16–** Click on **Build** and you should see the project compile and produce necessary output files.



# Lab 2: Saying Hello World

**Step 17**– Use a file browser to navigate to **V:\hardware\m1\_for\_arty\_s7\m1\_for\_arty\_s7**. You will see a files named **bram\_s7.elf** and **bram\_s7.hex** (these should have today's time stamp as you just generated them).

| Name                         | Date modified    | Type                | Size     |
|------------------------------|------------------|---------------------|----------|
| m1_for_arty_s7.cache         | 18/04/2019 13:35 | File folder         |          |
| m1_for_arty_s7.hw            | 18/04/2019 13:35 | File folder         |          |
| m1_for_arty_s7.runs          | 18/04/2019 13:49 | File folder         |          |
| m1_for_arty_s7.sdk           | 18/04/2019 14:12 | File folder         |          |
| m1_for_arty_s7.sim           | 18/04/2019 13:35 | File folder         |          |
| bram_s7.elf                  | 18/04/2019 14:49 | ELF File            | 137 KB   |
| bram_s7.hex                  | 18/04/2019 14:49 | HEX File            | 29 KB    |
| m1.mmi                       | 13/12/2018 15:15 | MMI File            | 3 KB     |
| m1_for_arty_s7.xpr           | 18/04/2019 14:02 | Vivado Project File | 19 KB    |
| m1_for_arty_s7_reference.bit | 13/12/2018 15:15 | BIT File            | 2,141 KB |
| m1_for_arty_s7_reference.mcs | 13/12/2018 15:15 | MCS File            | 6,022 KB |
| make_mmi_file.tcl            | 17/01/2019 15:30 | TCL File            | 8 KB     |
| make_prog_files.bat          | 17/01/2019 15:30 | Windows Batch File  | 2 KB     |
| make_prog_files.tcl          | 17/01/2019 15:30 | TCL File            | 4 KB     |

# Lab 2: Saying Hello World

**Step 18** – Double click on the **make\_prog\_files.bat** this will create the bit file needed with the Cortex-M1 and application we just created to download into the Arty S7-50 board.

**Step 19** – In Vivado open **Hardware Manager**:



# Lab 2: Saying Hello World

**Step 20** – Once Hardware Manager is open select **Open Target** and auto connect. This will open the JTAG link with the target board.



# Lab 2: Saying Hello World

**Step 21** – We are now connected to the Arty S7-50 board and can program it. Before we do this we should open a terminal program, such as terra term or PuTTY, so we can see the output from the serial link. **Set it for 115200, 1 Start, 1 Stop no Parity.**

**Step 22** – To program the FPGA in Hardware Manager we need to select the correct bit file, select **Program Device**.



# Lab 2: Saying Hello World

**Step 23** – When the dialog appears select the file

**V:/hardware/m1\_for\_arty\_s7/m1\_for\_arty\_s7/m1\_for\_arty\_s7.bit**



# Lab 2: Saying Hello World

**Step 24** – Check the output in your terminal, it should look similar to below:



```
*****  
Arm Cortex-M1 Revision 0 Variant 1  
  
ESC 2019 Tutorial Example design for Digilent S7 board  
  
V2C-DAPLink board not detected  
Use DIP switches and push buttons to  
control LEDs  
Version 1.1  
*****  
Bram readback correct  
Base SPI readback correct
```

As we build on top of the existing reference design we can also press **BTN1** and **BTN0** on the Arty S7-50 to see LD0 and LD1 cycle through colors with each press.

This concludes Lab 2!

# **Lab 3**

## Completing a Simple Application

# Lab 3: Completing a Simple Application

**Step 1** – In Vivado we need to add in IP cores from the Digilent IP library. This requires that we first add in the IP repository. To do this click on the **Project Settings**.



# Lab 3: Completing a Simple Application

**Step 2** – This will open the project settings dialog box. Select **IP→Repository** and click on the **+** button to add a IP repository.



# Lab 3: Completing a Simple Application

**Step 3** – Navigate to the location of the Digilent IP library on your system (downloaded during the Pre-Lab). If you do not have them they can be downloaded from <https://github.com/Digilent/vivado-library>.

**Step 4** – When you see the dialog below click **OK**.



# Lab 3: Completing a Simple Application

**Step 5** – We are now able to begin adding in the IP from this library into our Vivado design. The first stage is to close the IP settings and open the **block diagram**. Float the block diagram so we can make it fit the screen by selecting the button highlighted below.



# Lab 3: Completing a Simple Application

**Step 6** – We are now going to add in the **Pmod Nav** and **Pmod HYGRO**. In the block diagram select the **+** button. This will bring up a dialog which we can use to add in the necessary IP.



# Lab 3: Completing a Simple Application

**Step 7** – To add **Pmod Nav**, in the search bar type “**pmodnav**” and double click on the IP to add it into the block diagram.



**Step 8** – To add in the **Pmod HYGRO**, repeat steps 6-7 by clicking the **+** button again and in the search bar type “**pmodhygro**” double click on the IP to add it into the block diagram.



# Lab 3: Completing a Simple Application

**Step 9 – Check that both the IP blocks have now been added in the block diagram.**



# Lab 3: Completing a Simple Application

**Step 10** – Click on the Run Connection Automation option. This will open a dialog to connect in the newly added IP.



# Lab 3: Completing a Simple Application

**Step 11** – In the dialog check **All Automation** and click **OK**.



# Lab 3: Completing a Simple Application

**Step 12** – You will see the updated block diagram with the **PmodNAV** and **PmodHYGRO** connected into the AXI system and with the Cortex-M1 processor.



# Lab 3: Completing a Simple Application

**Step 12 (cont'd)** – Make sure you connect the **ext\_spi\_clk** to the **s\_axi\_clk**



# Lab 3: Completing a Simple Application

**Step 13** – At this point we have not added any IO to these IP blocks connecting them to the Pmod ports on the Arty S7-50.

The next thing to do is select the **Connector JB** under the board tab and drag and drop it on the **PmodHYGRO**.



# Lab 3: Completing a Simple Application

**Step 14** – This should show the connection to the PmodNAV correctly.



# Lab 3: Completing a Simple Application

**Step 15 – Repeat the same thing for PmodNAV and Connector JA.**



# Lab 3: Completing a Simple Application

**Step 16** – Again, you will see a confirmation of the connection.



# Lab 3: Completing a Simple Application

**Step 17** – We now check assigned memory addresses. Save and close the block diagram and double check in the **Address Editor** that all of the Pmods are in the **0x4xxx\_xxxx Range**.

The screenshot shows the Vivado Block Design interface. On the left is the 'Sources' panel, which lists I2C and Pmod components. In the center is the 'Diagram' window, showing a block diagram with components like PmodHYGRO\_0, PmodHYGRO\_1\_0, and PmodNAV. A red box highlights the 'Address Editor' tab in the top navigation bar. To the right is the 'Address Editor' window, displaying a table of memory assignments. A red oval highlights the entries for PmodHYGRO\_0 and PmodNAV\_0, both of which are listed under the CORTEXM1\_AXI\_0 slave interface with base addresses in the 0x44A0\_XXXX range.

| Cell           | Slave Interface                                                                                   | Base Name                       | Offset Address | Range | High Address |     |             |
|----------------|---------------------------------------------------------------------------------------------------|---------------------------------|----------------|-------|--------------|-----|-------------|
| CORTEXM1_AXI_0 | CM1_AXI3 (32 address bits : 0x00000000 [1M], 0x40000000 [512M], 0x60000000 [1G], 0xA0000000 [1G]) | axi_bram_ctrl_0                 | S_AXI          | Mem0  | 0x6000_0000  | 8K  | 0x6000_1FFF |
|                |                                                                                                   | axi_gpio_0                      | S_AXI          | Reg   | 0x4011_0000  | 64K | 0x4011_FFFF |
|                |                                                                                                   | daplink_if_0/axi_gpio_0         | S_AXI          | Reg   | 0x4001_0000  | 64K | 0x4001_FFFF |
|                |                                                                                                   | axi_gpio_1                      | S_AXI          | Reg   | 0x4012_0000  | 64K | 0x4012_FFFF |
|                |                                                                                                   | axi_quad_spi_0                  | AXI_LITE       | Reg   | 0x4013_0000  | 64K | 0x4013_FFFF |
|                |                                                                                                   | daplink_if_0/axi_quad_spi_0     | AXI_LITE       | Reg   | 0x4002_0000  | 64K | 0x4002_FFFF |
|                |                                                                                                   | daplink_if_0/axi_single_spi_0   | AXI_LITE       | Reg   | 0x4003_0000  | 64K | 0x4003_FFFF |
|                |                                                                                                   | axi_uartlite_0                  | S_AXI          | Reg   | 0x4010_0000  | 64K | 0x4010_FFFF |
|                |                                                                                                   | daplink_if_0/axi_xip_quad_spi_0 | AXI_FULL       | MEM0  | 0x0000_0000  | 1M  | 0x000E_FFFF |
|                |                                                                                                   | daplink_if_0/axi_xip_quad_spi_0 | AXI_LITE       | Reg   | 0x4000_0000  | 64K | 0x4000_FFFF |
| PmodNAV_0      | AXI_LITE_SPI                                                                                      | Reg0                            | 0x4004_0000    | 64K   | 0x4004_FFFF  |     |             |
| PmodNAV_0      | AXI_LITE_GPIO                                                                                     | Reg0                            | 0x4005_0000    | 4K    | 0x4005_0FFF  |     |             |
| PmodHYGRO_0    | AXI_LITE_TMR                                                                                      | Reg0                            | 0x44A0_0000    | 64K   | 0x44A0_FFFF  |     |             |
| PmodHYGRO_0    | AXI_LITE_IIC                                                                                      | Reg0                            | 0x44A1_0000    | 64K   | 0x44A1_FFFF  |     |             |

# Lab 3: Completing a Simple Application

**Step 18** – We are now ready to build the design. Click on the **validate button** to prove we have no errors or critical warnings in the design.



# Lab 3: Completing a Simple Application

**Step 19** – Click on the generate bit stream button.



# Lab 3: Completing a Simple Application

**Step 20** – This may take a little while but once the bit stream is completed you will see the message **write\_bitstream\_complete** in the upper right hand corner of Vivado.



# Lab 3: Completing a Simple Application

**Step 21** – Now we need to update the MMI file. To do this we need to open the implemented design.

There is a script we need to run to generate this, available under:

**V:\hardware\m1\_for\_arty\_s7\m1\_for\_arty\_s7**

In the **TCL console**, change the working directory to the one above using:

**cd V:\\hardware\\m1\_for\_arty\_s7\\m1\_for\_arty\_s7**

Then enter the command **source make\_mmi\_file.tcl**

This will create the updated MMI file.

Note, if you see any warning when you open the implemented design, click on **OK**.

# Lab 3: Completing a Simple Application

**Step 22** – Next, export the hardware definition. Select **File→Export→Export Hardware**.



# Lab 3: Completing a Simple Application

**Step 23** – In the pop up, set the export location as V:\software



# Lab 3: Completing a Simple Application

**Step 24** – In the pop up, set the export location as **V:\software**.

If you see a warning asking if you want to overwrite the existing file, click **Yes**.



# Lab 3: Completing a Simple Application

**Step 25** – Next, we need to open XDSK. Select **File→Launch SDK**.



# Lab 3: Completing a Simple Application

**Step 26** – In the pop up box, for the export location, select the location we just exported the hardware definition to (**V:\Software**).

Select the workspace located at **V:\software\m1\_for\_arty\_s7\sdk\_workspace**.

Note: Use **File Explorer** to confirm there is only one exported hardware definition under V:\software. If there is a HDF file for the Arty A7, please delete it.



# Lab 3: Completing a Simple Application

**Step 27** – In SDK you will see the hardware definition and BSP being updated from what we used in Lab 2. Under the BSP delete the directory **cortexm1\_0**.

In the hardware definition you will see the **PmodHYGRO** and **PmodNAV**.

In the BSP MSS file you will also see the drivers have been included with the BSP.

| Design Information                       |                          |            |               |          |
|------------------------------------------|--------------------------|------------|---------------|----------|
| Target FPGA Device:                      | 7s50                     |            |               |          |
| Part:                                    | xc7s50csga324-1          |            |               |          |
| Created With:                            | Vivado 2018.2            |            |               |          |
| Created On:                              | Thu Apr 18 16:21:09 2019 |            |               |          |
| Address Map for processor CORTEXM1_AXI_0 |                          |            |               |          |
| Cell                                     | Base Addr                | High Addr  | Slave I/f     | Mem/Reg  |
| daplink_if_0_axi_single_spi_0            | 0x40030000               | 0x4003ffff | AXI_LITE      | REGISTER |
| daplink_if_0_axi_gpio_0                  | 0x40010000               | 0x4001ffff | S_AXI         | REGISTER |
| axi_gpio_0                               | 0x40110000               | 0x4011ffff | S_AXI         | REGISTER |
| axi_bram_ctrl_0                          | 0x60000000               | 0x60001fff | S_AXI         | MEMORY   |
| axi_quad_spi_0                           | 0x40130000               | 0x4013ffff | AXI_LITE      | REGISTER |
| axi_gpio_1                               | 0x40120000               | 0x4012ffff | S_AXI         | REGISTER |
| PmodHYGRO_0                              | 0x44a10000               | 0x44a1ffff | AXI_LITE_IIC  | REGISTER |
| daplink_if_0_axi_xip_quad_s...           | 0x40000000               | 0x4000ffff | AXI_LITE      | REGISTER |
| daplink_if_0_axi_xip_quad_s...           | 0x00000000               | 0x000fffff | AXI_FULL      | REGISTER |
| PmodNAV_0                                | 0x40050000               | 0x4005ffff | AXI_LITE_G... | REGISTER |
| axi_uartlite_0                           | 0x40100000               | 0x4010ffff | S_AXI         | REGISTER |
| PmodHYGRO_0                              | 0x44a00000               | 0x44a0ffff | AXI_LITE_T... | REGISTER |
| daplink_if_0_axi_quad_spi_0              | 0x40020000               | 0x4002ffff | AXI_LITE      | REGISTER |
| PmodNAV_0                                | 0x40040000               | 0x4004ffff | AXI_LITE_SPI  | REGISTER |

| Peripheral Drivers                            |                                                               |
|-----------------------------------------------|---------------------------------------------------------------|
| Drivers present in the Board Support Package. |                                                               |
| PmodHYGRO_0                                   | PmodHYGRO                                                     |
| PmodNAV_0                                     | PmodNAV                                                       |
| axi_bram_ctrl_0                               | <a href="#">Documentation</a> <a href="#">Import Examples</a> |
| axi_gpio_0                                    | <a href="#">Documentation</a> <a href="#">Import Examples</a> |
| axi_gpio_1                                    | <a href="#">Documentation</a> <a href="#">Import Examples</a> |
| axi_quad_spi_0                                | <a href="#">Documentation</a> <a href="#">Import Examples</a> |
| axi_uartlite_0                                | <a href="#">Documentation</a> <a href="#">Import Examples</a> |
| daplink_if_0_axi_gpio_0                       | <a href="#">Documentation</a> <a href="#">Import Examples</a> |
| daplink_if_0_axi_quad_spi_0                   | <a href="#">Documentation</a> <a href="#">Import Examples</a> |
| daplink_if_0_axi_single_spi_0                 | <a href="#">Documentation</a> <a href="#">Import Examples</a> |
| daplink_if_0_axi_xip_quad_spi_0               | <a href="#">Documentation</a> <a href="#">Import Examples</a> |

# Lab 3: Completing a Simple Application

**Step 28** – Next, we need to copy the files  
**Xpsuedo\_asm\_rvct.c** and **Xpseudo\_asm\_rvct.h**

From

**V:\vivado\Arm\_sw\_repository\CortexM\bsp\standalone\_v6\_7\src\arm\cortexm1\armcc**  
to

**V:\software\m1\_for arty\_s7\sdk\_workspace\standalone\_bsp\_0\CORTEXM1\_AXI\_0\include**

**Step 29** – Check the name of the Cortex-M processor generated by SDK. Use File Explorer and navigate to  
**V:\software\m1\_for arty\_s7\sdk\_workspace\standalone\_bsp\_0**.

Ensure the folder is named **CORTEX\_M1\_0** and not **CORTEXM1\_AXI\_0** or similar, if so correct the naming to **CORTEX\_M1\_0**.

# Lab 3: Completing a Simple Application

**Step 30** – Now, let's develop our SW application in Arm KEIL.

Navigate to **V:/software/m1\_for\_arty\_s7/Build\_Keil/**. Click on the file **m1\_for\_arty\_s7.uvprojx**. This will open the Arm Keil project.

Make sure the target is set to **m1\_for\_arty\_s7**.



# Lab 3: Completing a Simple Application

**Step 31** – The next thing we need to do is ensure the compiler directives are set correctly for both our application and the drivers we will be using. To open the options, click on the **highlighted button**.

Ensure Optimization is set to **Level-1 (O-1)**, **C99** and **GNU extensions** are enabled, if you want you can also select the optimization level.



# Lab 3: Completing a Simple Application

**Step 32** – To work with the **PmodHYGRO** and the **PmodNAV** we need to add in the source code.

To do this we right click on the project and select **Manage Project Items**.



# Lab 3: Completing a Simple Application

**Step 33 – Under Groups** we can add in the **PModHYGRO** and the **PModNAV** as new groups.

Then add in the source code which can be found under the **PmodXXXX drivers directory**.

Find the drivers under:

**V:\software\m1\_for\_arty\_s7\ sdk\_workspace\ standalone\_bsp\_0\CORTEX\_M1\_0\libsra**

For the PmodNAV do not include the SPI source files. These are already included under the Xilinx\_SPI group



# Lab 3: Completing a Simple Application

**Step 34 – Open the PmodNAV.c and comment out usleep() calls.**

Open **xtmrctr\_sinit.c** under the Xilinx PmodHYGRO and edit the line to be **XTmrCtr\_Config XTmrCtr\_ConfigTable[1];**

```
main.c xiic_1.c uart.c print.c xil_printf.c xtmcrt_sinit.c
58 #define XPAR_XTMRCTR_NUM_INSTANCES 0
59 #endif
60
61 /* **** Variable Declarations ****/
62
63 /* A table of configuration structures containing the configuration information
64 * for each timer core in the system. */
65 XTmrCtr_Config XTmrCtr_ConfigTable[1];
66
67 /* **** Function Definitions ****/
68
69 /* ****/
```

# Lab 3: Completing a Simple Application

**Step 35** – We can then use the Pmods and create applications. In this example, let's create a simple application which reads the Pmods and Temperature, Humidity, X,Y & Z information over the terminal by adding the following into our code in main.c:

```
#include "PmodHYGRO.h"
#include "PmodNAV.h"
#define TIMER_FREQ_HZ 100000000
PmodHYGRO myDevice;
PmodNAV nav;
bool sample;
float temp_degc, hum_perrh, temp_degf;
```

The above should be declared as global variables

# Lab 3: Completing a Simple Application

**Step 36** – To provide a timing reference you might want to use the system tick. This can be accessed by

```
#define STCTRL    (*( ( volatile unsigned long * ) 0xE000E010 ) )
#define STRELOAD   (*( ( volatile unsigned long * ) 0xE000E014 ) )
#define STCURREN   (*( ( volatile unsigned long * ) 0xE000E018 ) )
#define SBIT_ENABLE 0
#define SBIT_TICKINT 1
#define SBIT_CLKSOURCE 2
#define RELOAD_VALUE 98999999
```

The ISR can be accessed using

```
void SysTick_Handler(void)
{
    sample=TRUE;
}
```

This is already mapped into the vector. Check out **startup\_arty\_cm1.s**.

# Lab 3: Completing a Simple Application

**Step 37** – In the main loop add in the following code

```
HYGRO_begin(&myDevice, XPAR_PMODHYGRO_0_AXI_LITE_IIC_BASEADDR,0x40,XPAR_PMODHYGRO_0_AXI  
_LITE_TMR_BASEADDR,1,TIMER_FREQ_HZ);  
  
NAV_begin  
(&nav,XPAR_PMODNAV_0_AXI_LITE_GPIO_BASEADDR,XPAR_PMODNAV_0_AXI_LITE_SPI_BASEADDR);  
NAV_Init(&nav);  
STRELOAD = RELOAD_VALUE;  
STCTRL = (1<<SBIT_ENABLE) | (1<<SBIT_TICKINT) | (1<<SBIT_CLKSOURCE);  
  
while ( 1 )  
{  
    if (sample == TRUE){  
        temp_degc = HYGRO_getTemperature(&myDevice);  
        hum_perrh = HYGRO_getHumidity(&myDevice);  
        sprintf (debugStr, "Temp is %f Humidity is %f\r\n\r\n", temp_degc, hum_perrh );  
        print ( debugStr );  
        NAV_GetData(&nav);  
        sprintf (debugStr, "X is %f Y is %f Z is %f\r\n\r\n", nav.acclData.X, nav.acclData.Y, nav.acclData.Z );  
        print ( debugStr );  
        sample = FALSE;  
    }  
}
```

# Lab 3: Completing a Simple Application

**Step 38** – The expected output should produce something like below



The screenshot shows a terminal window titled "COM26 - PuTTY". The window contains the following text output:

```
Temp is 24.003906 Humidity is 34.295654
X is 0.148779 Y is -0.164944 Z is
Temp is 23.984375 Humidity is 34.295654
X is 0.148535 Y is -0.164212 Z is
Temp is 23.984375 Humidity is 34.295654
X is 0.148901 Y is -0.164090 Z is
Temp is 24.013672 Humidity is 34.295654
X is 0.148047 Y is -0.163541 Z is
Temp is 23.984375 Humidity is 34.295654
X is 0.148657 Y is -0.164151 Z is
Temp is 24.003906 Humidity is 34.197998
```

# Lab 3: Completing a Simple Application

**Step 39 –** Now, let's test our application on the hardware.

Use a file browser navigate to **V:\hardware\m1\_for\_arty\_s7\m1\_for\_arty\_s7**.

You will see a file named **bram\_s7.elf** and **bram\_s7.hex**. These should have today's time stamp as you just generated them.



# Lab 3: Completing a Simple Application

## Step 40 – Double click on make\_prog\_files.bat

This will create the bit file needed with the Cortex-M1 and application we just created to download into the Arty S7-50 board.

## Step 41 – Power off the Arty S7 board and connect the PmodNAV to PmodA and PmodHYGRO to PmodB.



# Lab 3: Completing a Simple Application

**Step 42 – Power on the Arty Board and In Vivado open the Hardware Manager.**



# Lab 3: Completing a Simple Application

**Step 43 –** Once Hardware Manager is open, select **Open Target** and auto connect. This will open the JTAG link with the target board.



# Lab 3: Completing a Simple Application

**Step 44 –** This will connect to the Arty S7-50 so that we can program it. Before we do this we should open a terminal program (such as terra term or PuTTY) so that we can see the output from the serial link.

Set it for **115200, 1 Start, 1 Stop no Parity**.

# Lab 3: Completing a Simple Application

**Step 45 –** To program the FPGA in Hardware Manager we need to select the correct bit file. Select Program Device.



# Lab 3: Completing a Simple Application

**Step 46** – When the dialog appears, select the file  
**V:/hardware/m1\_for\_arty\_s7/m1\_for\_arty\_s7/m1\_for\_arty\_s7.bit**



**Step 47** – Check the output in your terminal.

Congratulations! You have finished Lab 3 and completed your simple application.