

Name: \_\_\_\_\_ ID: \_\_\_\_\_

Start Date: Tuesday, June 11, 2019  
Due Date: Thursday, June 13, 2019

## Software and Hardware Co-Design with Zybo, Spring 2019 HUST Lab #10 VGA, Image Creation and Boot Loader on Zybo

This is an individual lab. Each student must perform it and demonstrate this lab to obtain credit for it. Late lab submission will be accepted with a grade reduction of 20% for each day that it is late.

The main objective of this project is to implement VGA display with Zybo and axi IPs. The idea of this project is from the Zybo Base System Design from Digilent Inc. Another task of this lab is to create a boot loader for QSPI.

### 1 Available Source Programs and Documents

zybo\_base\_system.zip is provided by the instructor. It is also available under Design Resources from this website: <https://reference.digilentinc.com/zybo:zybo>. It contains both hardware modules as well as example software programs for various applications.

Lab 5 Configuration and Booting, Advanced Embedded System Design on Zynq using Vivado from Xilinx University Program on how to configure a boot loader from SD card. This is a tutorial to implement Part 2 of this lab.

### 2 Objectives

- 1) Implement VGA part of Zybo Base System Design from Digilent.
- 2) Create and display one image of those from Tweetable Mathematical Art competition. (<http://codegolf.stackexchange.com/questions/35569/tweetable-mathematical-art>)
- 3) Create and display one new image of your own creation. It could be a modification of those from the Tweetable mathematical Art.
- 4) Create the boot image of the above system, store it in the QSPI flash memory, start the above system from the QSPI memory.

### 3 Demonstration and Report by Thursday, June 13, 2019

Submit a pdf copy of your image displaying code. Demonstrate your system can be booted from the QSPI flash memory and display at least two images, one of them is your own creation.

### 4 Resources

- 1) zybo\_base\_system.zip, Zybo Base System Design, <https://reference.digilentinc.com/zybo:zybo>.
- 2) Lab 5 Configuration and Booting, Advanced Embedded System Design on Zynq using Vivado, <http://www.xilinx.com/support/university/vivado/vivado-workshops/Vivado-advanced-embedded-design-zynq.html>.
- 3) AXI Video Direct Memory Access v6.2, LogiCORE IP Product Guide, Vivado Design Suite, PG020, November 18, 2015, [http://www.xilinx.com/support/documentation/ip\\_documentation/axi\\_vdma/v6\\_2/pg020\\_axi\\_vdma.pdf](http://www.xilinx.com/support/documentation/ip_documentation/axi_vdma/v6_2/pg020_axi_vdma.pdf).
- 4) Tweetable Mathematical Art, <http://codegolf.stackexchange.com/questions/35569/tweetable-mathematical-art>.

## 5 The Final Block Design Diagram for Part 1.

Following this block design diagram to create our block design for Part 1 of this lab. If the steps do not agree with this block design diagram, assume this block design is correct. A larger pdf copy of this block design diagram is available for you to see more details.

You may get a lot of warnings during the process to build a bit stream file, you can ignore most of them.



## Part 1: A Tutorial on How to Implement VGA part of the Zybo Base System Design

### 6 Create a Vivado RTL project for VGA Demonstration

Create a Vivado RTL project, entitled lab10VGAdemoJJS where JJS is your name initials, and choose Zybo board. Create a block design of the same name: lab10VGAdemoJJS.

To disconnect a pin from a net, open the IP block where the pin is from to select the pin. Right click on the pin to choose “Disconnect Pin”. Press “Esc” key to deselect a pin.

#### 6.1 Add Zynq7 Processing System

Add ZYNQ7 Processing System and “Run Block Automation” before anything else to make sure that UART connection for SDK works. Set the following configurations.

##### 6.1.1 Peripheral IO Pins

Keep Quad SPI Flash, UART 1 and I2C 0 only. Choose M14 and M15 for I2C 0.



##### 6.1.2 PS-PL Configuration

Enable M AXI GP0, general purpose master interface 0 and S AXI HP0, high performance slave interface 0. In “General” menu, enable FCLK\_RESET\_0\_N and FCLK\_RESET\_1\_N.



**PS-PL Configuration**

| Name                      | Select                              | Description                                    |
|---------------------------|-------------------------------------|------------------------------------------------|
| + General                 |                                     |                                                |
| + DMA Controller          |                                     |                                                |
| + GP Master AXI Interface |                                     |                                                |
| + M AXI GP0 interface     | <input checked="" type="checkbox"/> | Enables General purpose AXI master interface 0 |
| + M AXI GP1 interface     | <input type="checkbox"/>            | Enables General purpose AXI master interface 1 |
| + GP Slave AXI Interface  |                                     |                                                |
| + HP Slave AXI Interface  |                                     |                                                |
| + S AXI HP0 interface     | <input checked="" type="checkbox"/> | Enables AXI high performance slave interface 0 |
| + S AXI HP1 interface     | <input type="checkbox"/>            | Enables AXI high performance slave interface 1 |

**Enable Clock Resets**

|               |                                     |                                                     |
|---------------|-------------------------------------|-----------------------------------------------------|
| FCLK_RESET0_N | <input checked="" type="checkbox"/> | Enables general purpose reset signal 0 for PL logic |
| FCLK_RESET1_N | <input checked="" type="checkbox"/> | Enables general purpose reset signal 1 for PL logic |
| FCLK_RESET2_N | <input type="checkbox"/>            | Enables general purpose reset signal 2 for PL logic |
| FCLK_RESET3_N | <input type="checkbox"/>            | Enables general purpose reset signal 3 for PL logic |

### 6.1.3 Clock Configuration

Enable FCLK\_CLK0, FCLK\_CLK01 and FCLK\_CLK02 as following. Set FCLK\_CLK0 to 100MHz, FCLK\_CLK1 to 150MHz



**Clock Configuration**

| Processor/Memory Clocks | IO Peripheral Clocks | PL Fabric Clocks                                                                                              |  |
|-------------------------|----------------------|---------------------------------------------------------------------------------------------------------------|--|
|                         |                      | <input checked="" type="checkbox"/> FCLK_CLK0      IO PLL      100      100.000000      0.100000 : 250.000000 |  |
|                         |                      | <input checked="" type="checkbox"/> FCLK_CLK1      IO PLL      150      150.000000      0.100000 : 250.000000 |  |
|                         |                      | <input type="checkbox"/> FCLK_CLK2      IO PLL      50      50.000000      0.100000 : 250.000000              |  |
|                         |                      | <input type="checkbox"/> FCLK_CLK3      IO PLL      50      50.000000      0.100000 : 250.000000              |  |
|                         |                      | + System Debug Clocks                                                                                         |  |
|                         |                      | + Timers                                                                                                      |  |

Your ZYNQ system should look like the following.



## 6.2 Add an AXI Video DMA IP

Add axi video direct memory access IP as follows.  
Disable Write Channel and set Read Channel as shown.

Basic Settings.



Advanced Settings.



Run “Run Connection Automation” and choose to connect all pins. The block design should look like the following.



(This does not match the steps above it)



Make sure the memory address assignment for this module is done as shown below under Address Editor. If the address is not assigned, right click the address table and select auto assign address.

| Cell                             | Slave Interface | Base Name    | Offset Address | Range | High Address |
|----------------------------------|-----------------|--------------|----------------|-------|--------------|
| processing_system7_0             |                 |              |                |       |              |
| Data (32 address bits : 4G)      |                 |              |                |       |              |
| axi_vdma_0                       | S_AXI_LITE      | Reg          | 0x4300_0000    | 64K   | 0x4300_FFFF  |
| axi_dispctrl_0                   | S_AXI           | S_AXI_reg    | 0x43C0_0000    | 64K   | 0x43C0_FFFF  |
| axi_vdma_0                       |                 |              |                |       |              |
| Data_MM2S (32 address bits : 4G) |                 |              |                |       |              |
| processing_system7_0             | S_AXI_HPO       | HP0_DDR_L... | 0x0000_0000    | 512M  | 0x1FFF_FFFF  |
| Data_S2MM (32 address bits : 4G) |                 |              |                |       |              |
| Data SG (32 address bits : 4G)   |                 |              |                |       |              |

### 6.3 Add an axi display controller IP from Digilent Inc.

The axi display controller IP is called axi\_dispctrl\_1.0 from Digilent Inc. It is available as part of Zybo Base Design zip file that can be downloaded from Digilent. The IP is in a folder called lib folder under zybo\_base\_system\zybo\_base\_system\source\vivado\hw. This lib folder needs to be added to the IP Repository of your project. You may want to copy this lib folder in your project folder for easy access.

In Flow Navigator, select Project Setting -> IP -> IP manager. Add the “lib” folder which contain the AXI Display Controller IP. Add AXI Display Controller to the block diagram as follows.

Double click the IP and change red channel to 5 bits, green channel to 6 bits and blue channel to 5 bits.



Make the RGB pins and h sync and v sync pins external. The block should look like this.

axi\_dispctrl\_0



AXI Display Controller

Run “Run Connection Automation” to obtain the following block design.



#### 6.4 Add a 6-bit Constant Number IP

Add a constant IP, called Constant. Make it 6-bit in width and constant zero value, as the starting address of the frame buffers. Connect it to mm2s\_frame\_ptr\_in[5:0].





## 6.5 Clean Up Connections Manually

Check all clock connections to make sure the following. FCLK\_CLK0 is used for AXI GP,(general purpose) and FCLK\_CLK1 is used for AXI HP (high performance).

- 1) FCLK\_CLK0 is connected to the following:

*ACLK, S00\_ACLK, M00\_ACLK, on processing\_system7\_0\_axi\_periph,  
s\_axi\_lite\_aclk on axi\_vdma\_0,  
M\_AXI\_GP0\_ACLK on ZYNQ,  
REF\_CLK\_I and s\_axi\_aclk on axi\_dispctrl\_0.*



- 2) FCLK\_CLK1 is connected to the following:

*AXI\_HP0\_ACLK on ZYNQ,  
m\_axi\_mm2s\_aclk on axi\_vdma\_0,  
ACLK, S00\_ACLK, M00\_ACLK on axi\_mem\_intercon, as shown below.*



Check all reset connections to make sure resets are as follows:

- 3) FCLK\_RESET0 is used for AXI bus reset and is connected to s\_axi\_aresetn on axi\_dispctrl\_0, ARESETN on axi\_mem\_intercon, ARESETN on processing\_system7\_0\_axi\_periph, (These may not be correct. 1-19-2017)



- 4) *FCLK\_RESET1* is used for AXI peripheral reset and is connected to *s\_axis\_mm2s\_aresetn* on *axi\_dispctrl\_0*, *S00\_ARESETN*, *M00\_ARESETN*, on *axi\_mem\_intercon*, *S00\_ARESETN*, *M00\_ARESETN*, on *processing\_system7\_0\_axi\_periph*, *axi\_resten* on *axi\_vdma\_0*.



- 5) *M\_axis\_mm2s\_aclk* on *axi\_vdma\_0* is connected to the *PXL\_CLK\_O* on *axi\_dispctrl\_0*.
- 6) *mm2s\_fsync* on *axi\_vdma\_0* is connected to *FSYNC* on *axi\_dispctrl\_0*.
- 7) Open *M\_AXIS\_MM2* and connect *m\_axis\_mm2s\_tkeep[3:0]* of *M\_AXI\_MM2* to *s\_axis\_mm2s\_tstrb[3:0]* of *S\_AXIS\_MM2S* on *axi\_dispctrl\_0*.
- 8) *M\_AXIS\_MM2S* on *axi\_vdma\_0* is connected to *S\_AXIS\_MM2S* on *axi\_dispctrl\_0*.



## 6.6 Three Critical Warnings

These warnings are due to reset signals that are not compatible with clock signals. They can be ignored for now until we can find a better fix.



## 7 Create a wrapper and synthesize the block design.

There will be many warnings on reset.



| Messages                                                                                                                                                                                                                                                                                                                                                                              |                       |            |          |           |          |
|---------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|-----------------------|------------|----------|-----------|----------|
|                                                                                                                                                                                                                                                                                                                                                                                       | 12 critical warnings  | 4 warnings | 67 infos | 23 status | Show All |
| <b>Block Design</b> (12 critical warnings)                                                                                                                                                                                                                                                                                                                                            |                       |            |          |           |          |
| validate_bd_design                                                                                                                                                                                                                                                                                                                                                                    | (3 critical warnings) |            |          |           |          |
| make_wrapper -files [get_files C:/Users/song/jjsong/ECE530Spring2016/lectures530spring2016/lecture12VGA/lab9tmp101vgaJJS/lab9tmp101vgaJJS.srcs/sources_1/bd/lab9tmp101vgaJJS/lab9tmp101vgaJJS.launch_runs synth_1                                                                                                                                                                     | (6 critical warnings) |            |          |           |          |
| ① [BD 41-1348] Reset pin /axi_mem_intercon/S00_ARESETN (associated clock /axi_mem_intercon/S00_ACLK) is connected to asynchronous reset source /processing_system7_0/FCLK_RESET1_N. This may prevent design from meeting timing. Please add Processor System Reset module to create a reset that is synchronous to the associated clock source /processing_system7_0/FCLK_CLK1.       |                       |            |          |           |          |
| ① [BD 41-1348] Reset pin /axi_mem_intercon/M00_ARESETN (associated clock /axi_mem_intercon/M00_ACLK) is connected to asynchronous reset source /processing_system7_0/FCLK_RESET1_N. This may prevent design from meeting timing. Please add Processor System Reset module to create a reset that is synchronous to the associated clock source /processing_system7_0/FCLK_CLK1.       |                       |            |          |           |          |
| ① [BD 41-1348] Reset pin /axi_dispctrl_0/s_axis_mm2s_aresetn (associated clock /axi_dispctrl_0/s_axis_mm2s_aclk) is connected to asynchronous reset source /processing_system7_0/FCLK_RESET1_N. This may prevent design from meeting timing. Please add Processor System Reset module to create a reset that is synchronous to the associated clock source /axi_dispctrl_0/PXL_CLK_Q. |                       |            |          |           |          |
| ① [BD 41-1348] Reset pin /axi_mem_intercon/S00_ARESETN (associated clock /axi_mem_intercon/S00_ACLK) is connected to asynchronous reset source /processing_system7_0/FCLK_RESET1_N. This may prevent design from meeting timing. Please add Processor System Reset module to create a reset that is synchronous to the associated clock source /processing_system7_0/FCLK_CLK1.       |                       |            |          |           |          |
| ① [BD 41-1348] Reset pin /axi_mem_intercon/M00_ARESETN (associated clock /axi_mem_intercon/M00_ACLK) is connected to asynchronous reset source /processing_system7_0/FCLK_RESET1_N. This may prevent design from meeting timing. Please add Processor System Reset module to create a reset that is synchronous to the associated clock source /processing_system7_0/FCLK_CLK1.       |                       |            |          |           |          |
| ① [BD 41-1348] Reset pin /axi_dispctrl_0/s_axis_mm2s_aresetn (associated clock /axi_dispctrl_0/s_axis_mm2s_aclk) is connected to asynchronous reset source /processing_system7_0/FCLK_RESET1_N. This may prevent design from meeting timing. Please add Processor System Reset module to create a reset that is synchronous to the associated clock source /axi_dispctrl_0/PXL_CLK_Q. |                       |            |          |           |          |
| ① [BD 41-1348] Reset pin /axi_mem_intercon/S00_ARESETN (associated clock /axi_mem_intercon/S00_ACLK) is connected to asynchronous reset source /processing_system7_0/FCLK_RESET1_N. This may prevent design from meeting timing. Please add Processor System Reset module to create a reset that is synchronous to the associated clock source /processing_system7_0/FCLK_CLK1.       |                       |            |          |           |          |
| ① [BD 41-1348] Reset pin /axi_mem_intercon/M00_ARESETN (associated clock /axi_mem_intercon/M00_ACLK) is connected to asynchronous reset source /processing_system7_0/FCLK_RESET1_N. This may prevent design from meeting timing. Please add Processor System Reset module to create a reset that is synchronous to the associated clock source /processing_system7_0/FCLK_CLK1.       |                       |            |          |           |          |
| ① [BD 41-1348] Reset pin /axi_dispctrl_0/s_axis_mm2s_aresetn (associated clock /axi_dispctrl_0/s_axis_mm2s_aclk) is connected to asynchronous reset source /processing_system7_0/FCLK_RESET1_N. This may prevent design from meeting timing. Please add Processor System Reset module to create a reset that is synchronous to the associated clock source /axi_dispctrl_0/PXL_CLK_Q. |                       |            |          |           |          |

It takes about 8 minutes to synthesize this block design.

|                     | INOUT |     |   | (Multiple)*          |
|---------------------|-------|-----|---|----------------------|
| FIXED_IO_9964 (59)  |       |     |   | (Mult... LVC MOS33*) |
| └─ BLUE_O (5)       | OUT   | G19 | ✓ | 35 LVC MOS33*        |
| └─ BLUE_O[4]        | OUT   | J18 | ✓ | 35 LVC MOS33*        |
| └─ BLUE_O[3]        | OUT   | K19 | ✓ | 35 LVC MOS33*        |
| └─ BLUE_O[2]        | OUT   | M20 | ✓ | 35 LVC MOS33*        |
| └─ BLUE_O[1]        | OUT   | P20 | ✓ | 34 LVC MOS33*        |
| └─ BLUE_O[0]        | OUT   |     |   |                      |
| └─ GREEN_O (6)      | OUT   | F20 | ✓ | (Mult... LVC MOS33*) |
| └─ GREEN_O[5]       | OUT   | H20 | ✓ | 35 LVC MOS33*        |
| └─ GREEN_O[4]       | OUT   | J19 | ✓ | 35 LVC MOS33*        |
| └─ GREEN_O[3]       | OUT   | L19 | ✓ | 35 LVC MOS33*        |
| └─ GREEN_O[2]       | OUT   | N20 | ✓ | 34 LVC MOS33*        |
| └─ GREEN_O[1]       | OUT   | H18 | ✓ | 35 LVC MOS33*        |
| └─ GREEN_O[0]       | OUT   |     |   |                      |
| └─ RED_O (5)        | OUT   |     |   | 35 LVC MOS33*        |
| └─ RED_O[4]         | OUT   | F19 | ✓ | 35 LVC MOS33*        |
| └─ RED_O[3]         | OUT   | G20 | ✓ | 35 LVC MOS33*        |
| └─ RED_O[2]         | OUT   | J20 | ✓ | 35 LVC MOS33*        |
| └─ RED_O[1]         | OUT   | L20 | ✓ | 35 LVC MOS33*        |
| └─ RED_O[0]         | OUT   | M19 | ✓ | 35 LVC MOS33*        |
| └─ Scalar ports (2) |       |     |   |                      |
| └─ HSYNC_O          | OUT   | P19 | ✓ | 34 LVC MOS33*        |
| └─ VSYNC_O          | OUT   | R19 | ✓ | 34 LVC MOS33*        |

run implementation for about 5 minutes. Generate the bitstream file. Export hardware and launch SDK.



## 8 SDK and Demo Program from Digilent

Create an SDL empty project. Import source and header files from base\_demo folder of zybo base system demo project: zybo\_base\_system\source\vivado\SDK\base\_demo folder. Select the following files only.

|                                                                                                |                    |        |
|------------------------------------------------------------------------------------------------|--------------------|--------|
|  display_ctrl | 4/10/2016 3:02 PM  | C File |
|  display_ctrl | 4/10/2016 3:02 PM  | H File |
|  display_demo | 4/10/2016 3:02 PM  | C File |
|  display_demo | 4/10/2016 3:02 PM  | H File |
|  main         | 4/10/2016 11:18 PM | C File |
|  timer_ps     | 4/10/2016 3:02 PM  | C File |
|  timer_ps     | 4/10/2016 3:02 PM  | H File |
|  vga_modes    | 4/10/2016 3:02 PM  | H File |

The following terminal display will be present. Choose option 2: VGA output demo. Select Option 1 to change resolution first.



```

Problems Tasks Console Properties Terminal 1 ✘

Serial: (COM14, 115200, 8, 1, None, None - CONNECTED) - Encoding: (ISO-8859-1)
*****
*      ZYBO Base System User Demo      *
*****
1 - Audio Demo
2 - VGA output demo
3 - HDMI output demo
q - Quit

Select a demo to run:

```

Serial: (COM14, 115200, 8, 1, None, None - CONNECTED) - Encoding: (ISO-8859-1)  
\*\*\*\*\*  
1 - Change Resolution  
2 - Change Frame  
3 - Print Blended Test Pattern to current Frame  
4 - Print Color Bar Test Pattern to current Frame  
5 - Invert Current Frame colors  
6 - Invert Current Frame colors seamlessly\*  
q - Quit  
\*\*\*\*\*  
Note that option 6 causes the current frame index to be incremented. This is because the inverted frame is drawn to an inactive frame. After the drawing is complete, this frame is then set to be the active frame. This demonstrates how to properly update what is being displayed without image tearing. Options 3-5 all draw to the currently active frame, which is why not all pixels appear to be updated at once.  
Enter a selection:

## Part 2: Create One New Image and Boot Load Image on QSPI

Follow Lab 5 Configuration and Booting, Advanced Embedded System Design on Zynq using Vivado from Xilinx University Program to create a boot image and store it on QSPI.

### 9 Create a New Project, entitled lab10imagesJJS

Save your project as a new project called lab10imagesJJS, where JJS is your name initials. Create at least two images similar to those from Tweetable Mathematical Art Competition (<http://codegolf.stackexchange.com/questions/35569/tweetable-mathematical-art>). One of the two images could be the same as one of the example images from the website. One of them must be your own creation.

### 10 Create Boot Image and Store it ON QSPI

Follow Lab 5 Configuration and Booting from Lab 5 Configuration and Booting, Advanced Embedded System Design on Zynq using Vivado to create a boot image and store it on QSPI. Demonstrate you can start your lab9imagesJJS from the QSPI flash drive of your Zybo board.

### 11 How to add math library Compile Option

If you still cannot use math library after you add #include “math.h”, you can try to add a link option in Project Properties->C/C++ Build->Settings->Libraries and add lowercase m in the libraries as shown below.



### 12 How to Create a Bootable System from the QSPI Flash

After you have debugged and tested your project, you can create a bootable system to be stored on a SD card or flash memory so that your project can be started from the bootable system. In this tutorial, a project call lab9VGAdemo is used as an example.

## 12.1 Create and debug your project first

Before creating a bootable system, you should create and debug your project and run it under interactive mode to make sure your project works.

## 12.2 Add options to Board Support Package Settings

In SDK, after a project has been created and tested, right click on \*.bsp and click Board Support Package Settings. Choose xilffs and xilrsa and click OK. (This is required for the next step to create the FSBL.)



## 12.3 Create first stage bootloader (FSBL)

To create a first stage bootloader (FSBL) for your project, create a new application project and call it your project name \_fsbl, e.g., lab10imagesJJS\_fsbl and choose “use existing Board Support Package”. Click “Next”. In Template menu, select Zynq FSBL in the Available Templates pane and click “Finish”.



## 12.4 Create directory called image and BOOT.bin file

Create a directory under your project directory call it image with Windows Explorer to store bootable system files as shown below.

| This PC > Windows (C:) > xup > embedded > lab10imagesJJS |                      |                  |                          |
|----------------------------------------------------------|----------------------|------------------|--------------------------|
|                                                          | Name                 | Date modified    | Type                     |
|                                                          | image                | 4/4/2017 9:10 PM | File folder              |
|                                                          | lab10imagesJJS.cache | 4/4/2017 8:45 PM | File folder              |
|                                                          | lab10imagesJJS.runs  | 4/4/2017 8:45 PM | File folder              |
|                                                          | lab10imagesJJS.sdk   | 4/4/2017 9:09 PM | File folder              |
|                                                          | lab10imagesJJS.srcs  | 4/4/2017 8:45 PM | File folder              |
|                                                          | sources              | 4/4/2017 8:38 PM | File folder              |
|                                                          | lab10imagesJJS.xpr   | 4/4/2017 8:48 PM | Vivado Project File 7 KB |

In SDK, select Xilinx Tools->Create Zynq Boot Image. Click on the Browse button of Output BIF field to browse to your image directory \*/image. And click Save. Leave the default name of output.bif.



Click on Add button of the Boot image partitions, click Browse button Add partition form. Browse to \Debug of the sdk subdirectory of your project directory. Open \*\_fsbl.elf file as shown below for project lab10imagesJJS\_fsbl. Click Open from this path:  
C:\xup\embedded\lab10imagesJJS\lab10imagesJJS.sdk\lab10imagesJJS\_fsbl\Debug.



Notice the partition type is bootloader. Click OK.



Add bit stream file from project hw\_platform directory of your project under SDK folder. The bit stream file is often called project\_wrapper.bit. The file for this example is lab9VGA\_wrapper.bit as shown below. Click Open to add it and click OK.



Click Add button of the Boot image partitions and add software application lab10VGAdemo from lab10imagesJJS\Debug directory in the SDK directory of your project. Click Open and Click OK.



Notice there should be three files in your Boot image partitions folder. The file order must be first stage boot load file \_fsbl.elf, hardware bit stream file \_wrapper.bit, and the application \*.elf file. Otherwise, there could be a boot loading error.



Click “Create Image” button. The BOOT.bin and the output.bif files will be created in the \image directory.

## 12.5 Program the QSPI flash memory with the bootable system files.

Set your Zybo board to be in JTAG boot mode by setting jumper JP5 to JTAG position.

In SDK, select Xilinx Tools->Program Flash. Click Browse button and go to \image directory, select BOOT.bin file and click Open.



In the Offset field, enter 0 as the offset, click Program button.



```

Problems Tasks Console Properties Terminal 1
Program Flash

Connecting to hw_server @ TCP:127.0.0.1:3121

WARNING: Failed to connect to hw_server at TCP:127.0.0.1:3121
Attempting to launch hw_server at TCP:127.0.0.1:3121

Connected to hw_server @ TCP:127.0.0.1:3121
Available targets and devices:
Target 0 : jsn-Zybo-210279759002A
Opened Target Cable Node -1274581344 on TCP:127.0.0.1:3121 successfully
    Device 0: jsn-Zybo-210279759002A-4ba00477-0
    Device 1: jsn-Zybo-210279759002A-13722093-0

JTAG chain configuration
-----
Device ID Code IR Length Part Name
1 4ba00477 4 arm_dap
2 13722093 6 xc7z010

-----
Enabling extended memory access checks for Zynq.
Writes to reserved memory are not permitted and reads return 0.
To disable this feature, run "debugconfig -memory_access_check disable".

-----
CortexA9 Processor Configuration
-----
Version..... 0x00000003
User ID..... 0x00000000
No of PC Breakpoints..... 6
No of Addr/Data Watchpoints..... 4
Processor Reset .... DONE

-----
Flash Operation Successful

```

## 12.6 Test your QSPI bootable system

Set your Zybo board to be in QSPI mode. Power it on. Start a serial terminal if needed. Press PS\_RST (Red button) button to see if your program will start.



## 12.7 An error

The following error occurred because the order of three files was wrong. The bit stream file was placed after the application \*.elf file. In the Boot image partitions pane, the bit stream file \*.bit must be before the application file \*.elf.

You can right click on \_fsbl folder under your Project Explorer menu to open Create Boot Image. You can then edit this configuration and create another boot loader image. You may notice that \*.bit file is gone. Add it again and make sure \*.bit is before \*.elf.



## 13 Acknowledgment

I am grateful to my students David Robinson and Joe Milittelo for their research and solutions to some issues and problems with this lab.

