

# QMTECH ZYNQ7000 BAJIE BOARD

## USER MANUAL



### Preface

The QMTECH® ZYNQ7000 Bajie Board uses Xilinx Zynq®-7000 device which integrates the software programmability of an ARM®-based processor with the hardware programmability of an FPGA, enabling key analytics and hardware acceleration while integrating CPU, DSP, ASSP, and mixed signal functionality on a single device. Consisting of single-core Zynq-7000S and dual-core Zynq-7000 devices, the Zynq-7000 family is the best price to performance-per-watt, fully scalable SoC platform for your unique application requirements.

For more information, updates and useful links, please visit QMTECH Official Website:

<http://www.chinaqmtech.com>



QMTECH

QMTECH ZYNQ7000 Bajie Board

User Manual V01

## Table of Contents

|                                                        |           |
|--------------------------------------------------------|-----------|
| <b>1. INTRODUCTION.....</b>                            | <b>3</b>  |
| 1.1 DOCUMENT SCOPE.....                                | 3         |
| 1.2 TEST EXAMPLES.....                                 | 3         |
| 1.3 BAJIE BOARD SETUP.....                             | 4         |
| <b>2. GETTING STARTED.....</b>                         | <b>5</b>  |
| 2.1 STEPS TO CUSTOMIZE THE ZYNQ PROCESSING SYSTEM..... | 5         |
| 2.1.1 Step 1: Create New Project.....                  | 5         |
| 2.1.2 Step 2: Add Zynq Processing System.....          | 8         |
| 2.1.3 Step 3: Customize Zynq Processing System.....    | 10        |
| 2.1.4 Step 4: Generate Output Products.....            | 14        |
| <b>3. EXPERIMENT 1: EMIO USER LED.....</b>             | <b>15</b> |
| <b>4. EXPERIMENT 2: MIO USER LED.....</b>              | <b>19</b> |
| <b>5. EXPERIMENT 3: DDR3 TEST.....</b>                 | <b>20</b> |
| <b>6. EXPERIMENT 5: LWIP TEST.....</b>                 | <b>23</b> |
| <b>7. REFERENCE.....</b>                               | <b>26</b> |
| <b>8. REVISION.....</b>                                | <b>27</b> |

# 1. Introduction

## 1.1 Document Scope

This demo user manual introduces the non-Linux part test examples that running on the QMTECH ZYNQ7000 Bajie Board. Those examples are all running with Xilinx Vivado 2018.3 environment. So the prerequisites before working with the examples are shown as below:

1. Users have already installed the Vivado 2018.3 in the Windows OS.
2. Users have the basic knowledge about the usage of the Vivado environment. At least know how to synthesis, implement and generate bitstream, etc.

## 1.2 Test Examples

Below diagram shows the main parts that these test examples cover:

- PS side MIO(Multipurpose Input Output);
- PL side HDMI Display;
- PL side EMIO(Extendable Multipurpose Input Output);
- PS side UART;
- PS side RGMII ethernet Interface;
- PS side DDR3 Memory Controller;



Figure 1-1. Tested Peripherals

### 1.3 Bajie Board Setup

Before start to test the Zynq7000 Bajie Board, users need to prepare the hardware setup shown as in below image. In default, the factory binary test images are already stored in the micro SD card and the D3 LED will be periodically blinking.



Figure 1-2. Hardware Setup

## 2. Getting Started

This chapter describes the detailed steps to create a customized ZYNQ Processing System. Comparing to the existing ZYNQ development board e.g. Xilinx ZC702, there are many differentiations in the QMTECH ZYNQ7000 Bajie Board. For example, there's only one 16bit width DDR3 memory chip connected to PS ARM core.

### 2.1 Steps to Customize the ZYNQ Processing System

#### 2.1.1 Step 1: Create New Project

Open Vivado 2018.3, then click 【Create Project】 shown in below figure.



Figure 2-1. Vivado 2018.3

Below image will be shown and click 【NEXT】 button:



Figure 2-2. Create New Project

Set the Project name and the project location:



**Figure 2-3. Set Project Name and Location**

Click 【Next】button in below image:



**Figure 2-4. Click Next**

Click 【Next】button in below image if there's no source file existing:



Click 【Next】 button in below image if there's no constraint file existing:



Figure 2-5. Click Next

Select the device consistent to the chip mounted on QMTECH ZYNQ xc7z010clg400-1:



Figure 2-6. Select Device

Click 【Finish】if there's nothing needs to be changed.



## 2.1.2 Step 2: Add Zynq Processing System

After the project successfully created, users can start to add the Zynq PS to the design by click 【Create Block Design】 in the IP INTEGRATOR. Type example name 'system' in the edit box shown in below image.



Figure 2-7. Create Block Design

Click the 【+】 button shown in below image and Search the keyword ZYNQ in the edit box. If the ZYNQ7 Processing system can be found, users could double click it and add it in the design.



Figure 2-8. Add ZYNQ7 PS

The below image will be displayed once the ZYNQ7 is correctly added.



**Figure 2-9. Added ZYNQ7 PS**

Users could click the 【Run Block Automation】. And then connect PS clock 【FCLK\_CLK0】 to 【M\_AXI\_GP0\_ACLK】.



**Figure 2-10. Block Automation**



### 2.1.3 Step 3: Customize Zynq Processing System

Double click the ZYNQ IP shown in the above image to implement the detailed customizations. The architecture block diagram will be shown as below. All the configurable parts are all listed in the Page Navigator.



**Figure 2-11. ZYNQ Architecture**

Click the **PS-PL Configuration** page, nothing needs to be changed here.



**Figure 2-12. ZYNQ Architecture**

Click the **Peripheral I/O Pins** page. Configure the Ethernet 0 shown as below. Assign the Ethernet 0 I/Os on the MIO[16:27] and MDIO I/Os on MIO[52:53].



**Figure 2-13. Configure Ethernet 0**

Configure the SD 0 shown as in below image. The SD card slot is connected to MIO[40:45] and the SD detect signal is connected to MIO47.



**Figure 2-14. Configure SD 0**

Below image shows the UART 1 port is connected to MIO12 and MIO13.



Click **MIO Configuration** page. Make sure all the MIO/EMIO assignment are same to the configurations shown in below image.



**Figure 2-15. MIO/EMIO Assignment**

Click **Clock Configuration** page. Configure the ENET0 clock with 1000Mbps because the RTL8211 supports RGMII 1000Mbps ethernet work mode.



Click **DDR Configuration** page. Change the Effective DRAM Bus Width into 16 Bit and select MT41K256M16 RE-125 as the memory part, though the actual part mounted on the ZYNQ Bajie Board is MT41K256M16TW-107:P. This is still workable because the clock frequency is only 400MHz and all the DDR3 memory chips are down speed compatible. If users still worry about the stability thing, then DDR3 memory customization also could be done in this page. And detailed parameters like the CAS latency, RAS to CAS Delay, etc. could be retrieved from Micron DDR3 data sheet and filled in this DDR Configuration page.

The screenshot shows two windows of the ZYNQ7 Processing System (5.5) software:

- Clock Configuration:** Shows the basic clocking setup with an input frequency of 33.333333 MHz and a CPU clock ratio of 6:2:1. A red box highlights the DDR row in the clock table, which shows a DDR PLL at 400 MHz.
- DDR Configuration:** Shows the DDR controller configuration. The "Enable DDR" checkbox is checked. A red box highlights the "Memory Part" dropdown set to "MT41K256M16 RE-125" and the "Effective DRAM Bus Width" dropdown set to "16 Bit". Other settings include ECC (Disabled), Burst Length (8), DDR clock (400 MHz), Internal Vref (unchecked), Junction Temperature (C) (Normal (0-85)), Additive Latency (cycles) (0), and Enable Advanced options (unchecked). The "OK" button is highlighted with a red box.

Figure 2-16. DDR3 Memory Configuration

For the **SMC Timing Calculation** and **Interrupts** pages, nothing needs to be changed here. And then click the OK button to finish the whole ZYNQ Processing System customization.

#### 2.1.4 Step 4: Generate Output Products

After the ZYNQ PS customization finished, users still need to make the PINs external.



**Figure 2-17. Make External**

Then **Validate Design**, **Generate Output Products** and **Create HDL Wrapper** to finish the whole procedure.



### 3. Experiment 1: EMIO User LED

Before start to test the user LED connected to EMIO, users need to make sure the designer\_1\_wrapper is correctly generated in the previous step. And then execute the whole compilation procedure: **Run Synthesis**, **Run Implementation** and **Generate Bitstream**. Make sure there's no error generated in any of these three steps.



**Figure 3-1, Generate Bitstream**

Below image shows the constraint file of this project. Users may modify this constraint file if needed.



Then export hardware to the SDK by clicking 【File】 → 【Export Hardware】 , select the checkbox **Include bitstream** and click the OK button. The detailed procedure is shown as below:



**Figure 3-2. Export Hardware to SDK**

Start the SDK by clicking 【File】 → 【Launch SDK】 and then clicking the OK button:



**Figure 3-3. Start SDK**

Setup a new project for testing the EMIO by clicking 【New】 → 【Application Project】 , and type EMIO\_Test in the project name.



**Figure 3-4. Create New Project**

Choose Empty Application and click the OK button.



Add source file main.c in the EMIO\_Test/src folder and the project will be automatically built by the Xilinx SDK environment. The below test routine configures the EMIO pin H17 as the output pin and enable it. After that it will periodically toggle the pin.



```

project_1.sdk - C/C++ - EMIO_Test/src/main.c - Xilinx SDK
File Edit Navigate Search Project Run Xilinx Window Help
Project Explorer main.c
  design_1_wrapper_hw_platform
  EMIO_Test
    Binaries
    Includes
    Debug
    src
      main.c
        lsconfig.td
        README.txt
        Xilinx.spec
        EMIO_Test_bsp
Outline xpziops.h
sleep.h
main : int

main()
{
    static XGpioPs_psGpioInstancePtr;
    XGpioPs_Config* GpioConfigPtr;
    int xStatus;

    GpioConfigPtr = XGpioPs_LookupConfig(XPAR_PS7_GPIO_0_DEVICE_ID);
    if(GpioConfigPtr == NULL)
        return XST_FAILURE;

    xStatus = XGpioPs_CfgInitialize(&psGpioInstancePtr, GpioConfigPtr, GpioConfigPtr->BaseAddr);
    if(XST_SUCCESS != xStatus)
        return XST_FAILURE;

    XGpioPs_SetDirectionPin(&psGpioInstancePtr, 54,1);
    XGpioPs_SetOutputEnablePin(&psGpioInstancePtr, 54,1);

    {
        XGpioPs_WritePin(&psGpioInstancePtr, 54, 1);
        usleep(200000);
        XGpioPs_WritePin(&psGpioInstancePtr, 54, 0);
        usleep(200000);
    }

    return 0;
}

```

**Figure 3-5. Toggle EMIO Pin H17**

Right click the project folder EMIO\_Test and then select **Run As→1 Launch on Hardware (System Debugger)**. And then users could see the D4 LED will be periodically blinking.



**Figure 3-6. Start to Run**



## 4. Experiment 2: MIO User LED

Before start to test the user LED connected to MIO10, users need to make sure the designer\_1\_wrapper is correctly generated in the previous step. And then execute the whole compilation procedure: **Run Synthesis**, **Run Implementation** and **Generate Bitstream**. Make sure there's no error generated in any of these three steps.

And then export hardware to the SDK and Lunch SDK.

In the SDK environment, create a new empty project named as MIO\_Test.

Add the main.c file in MIO\_Test/src folder and wait until the SDK project build finished. In the tet routine, it firstly configures the MIO9 as the output pin and enables it. In the main loop, it periodically toggles the MIO.



```

project_1.sdk - C/C++ - MIO_Test/src/main.c - Xilinx SDK
File Edit Navigate Search Project Run Xilinx Window Help
Project ... main.c
main.c
#include "xgpiops.h"
#include "sleep.h"
int main()
{
    static XGpioPs psGpioInstancePtr;
    XGpioPs_Config* GpioConfigPtr;
    int iPinNumber= 9;
    u32 uPinDirection = 0x1;
    int xStatus;

    GpioConfigPtr = XGpioPs_LookupConfig(XPAR_PS7_GPIO_0_DEVICE_ID);
    if(GpioConfigPtr == NULL)
        return(XST_FAILURE);

    xStatus = XGpioPs_CfgInitialize(&psGpioInstancePtr,GpioConfigPtr, GpioConfigPtr->BaseAddr);
    if(XST_SUCCESS != xStatus)
        printf(" PS GPIO INIT FAILED \n\n");

    XGpioPs_SetDirectionPin(&psGpioInstancePtr, iPinNumber,uPinDirection);
    XGpioPs_SetOutputEnablePin(&psGpioInstancePtr, iPinNumber,1);

    while(1)
    {
        XGpioPs_WriteReg(0xE000A000, 0x00000000, 0xFFFFFFF&0xFFFF0200);
        usleep(500000);
        XGpioPs_WriteReg(0xE000A000, 0x00000000, 0xFFFFFFF&0xFFFF0000);
        usleep(500000);
    }
    return 0;
}

```

Figure 4-1. Toggle MIO9

Right click the project folder MIO\_Test and then select **Run As** → **1 Launch on Hardware (System Debugger)**. And then users could see the D3 LED will be periodically blinking.



Figure 4-2. Start to Run



## 5. Experiment 3: DDR3 Test

Before start to test the DDR3 memory connected to PS side, users need to make sure the designer\_1\_wrapper is correctly generated in the previous step. And then execute the whole compilation procedure: **Run Synthesis**, **Run Implementation** and **Generate Bitstream**. Make sure there's no error generated in any of these three steps.

And then export hardware to the SDK and Lunch SDK.

In the SDK environment, create a new project named as DDR3\_Test and click Next button.

Select Available Templates: Zynq DRAM tests and click Finish button.



Figure 5-1. Create DDR3 Test Project

Below image shows the main function of the DDR3 test project.



```

project_1.sdk - C/C++ - E:\Xilinx\zynq\Workspace_Starter_Kit\Project04_Uboot\project_1.sdk\DDR3_Test\src\test01.c - Xilinx SDK
File Edit Navigate Search Project Run Xilinx Window Help
Project Explorer test01.c
DDR3_Test
src
platform_config.h
test01.c
translation_table.s
translation_table.h
Xilinx.spec
ZYNO_DRAM_DIAGNOSTICS_TE
DDR3_Test.bsp
design_1_wrapper_hw_platform_0
src
main.c
main()
{
    /* Function: main
     * Description:
     * +-----+
     * =int main(void)
     {
        int abyte = 1024*1024;
        int i,j, k, lp, a, go, rc, imaski, sel, last;
        int test_start, test_size, loop_cnt;
        int min, max, istep, testsize_scl, fast, fix_center, printer;
        int tdm_idv, remote_mode, mem_test, cmd;
        char c[10];
        imemtest_readyonly();
        imemtest_enable();
        imemtest_cache_enable();
        rc = 0;
        // unlock slcr
        REG_WRITE(SLCR_BASE+SLCR_UNLOCK, SLCR_UNLOCK_VALUE);
        REG_WRITE(SLCR_MODE, IIRF_DIS_MODE);
        // disable TDM0.DIS_MODE, IIRF_DIS_MODE
        clear_tdm_idm();
        // init data, go to 0
        REG_WRITE(MALBOX_GO, 0);
        REG_WRITE(MALBOX_DONE, 0);
        REG_WRITE(MALBOX_START, 1);
        REG_WRITE(MALBOX_TDM_IDV, 1);
        REG_WRITE(MALBOX_MODE, 0x0FFF); // enable all 15 tests
        REG_WRITE(MALBOX_LAST, 0x000000);
        go = 0;
        // check wrap mode
        k = REG_READ(MALBOX_XREGV);
        remote_mode = 0;
        if (k == 0x55)
            remote_mode = 1;
        // Create the 128-word patterns
        for (i=0; i<128; i++)
            imaski = (i >> 4) & 0x07; // invert mask index
    }
}

```

**Figure 5-2. Main() Function**

Right click the project folder DDR3\_Test and then select **Run As → 1 Launch on Hardware (System Debugger)**:



**Figure 5-3. Launch Debugger**



QMTECH

ZYNQ7000 Bajie Board

User Manual V01

Use mini USB cable to connect the PC and the ZYNQ Bajie Board J4 connector. Below image shows the output log sent by the DDR3\_Test example. And users could type '1', '2', etc. to select different test pattern. And the test results will also be displayed once the test finished.



serial-com5 - SecureCRT

File Edit View Options Transfer Script Tools Window Help

Enter host <Alt+R>

Session Manager

Sessions

- 192.168.1.10
- serial-com206
- serial-com207
- serial-com209
- serial-com214
- serial-com4
- serial-com5

serial-com5 x

```
----- ZYNQ DRAM DIAGNOSTICS TEST -----  
Select one of the options below:  
## Memory Test #  
Bus width = 32, XADC Temperature = 42,3573  
.s - Test 1MB length from address 0x100000  
.1 - Test 32MB length from address 0x100000  
.2 - Test 64MB length from address 0x100000  
.3 - Test 128MB length from address 0x100000  
.4 - Test 255MB length from address 0x100000  
.5 - Test 511MB length from address 0x100000  
.6 - Test 1023MB length from address 0x100000  
## Read Data Eye Measurement Test  
.r - Measure Read Data Eye  
## Write Data Eye Measurement Test  
.i - Measure Write Data Eye  
other options for write Eye Data Test:  
.f - Fast Mode: Toggles Fast mode - ON/OFF  
.c - Centre Mode: Toggles Centre mode - ON/OFF  
.e - Vary the size of memory test for Read/Write Eye Measurement tests  
## Data Cache Enable / Disable option:  
.z - D-Cache Enable / Disable  
## other options  
.v - Verbose Mode ON/OFF  
option Selected : 3  
  
Starting Memory Test '3' - Testing 128MB length from address 0x100000...  
-----  
TEST WORD ERROR PER-BYTE-LANE ERROR COUNT TIME  
COUNT [ LANE-0 ] [ LANE-1 ] [ LANE-2 ] [ LANE-3 ] (sec)  
-----  
.....■
```

Ready

Serial: COM5, 115200 39, 7 52 Rows, 118 Cols VT100 CAP NUM

Figure 5-4. Test Pattern



## 6. Experiment 5: LwIP Test

Before start to test the LwIP running with the MII ethernet interface, users need to make sure the designer\_1\_wrapper is correctly generated in the previous step. And then execute the whole compilation procedure: **Run Synthesis**, **Run Implementation** and **Generate Bitstream**. Make sure there's no error generated in any of these three steps.

And then export hardware to the SDK and Lunch SDK.

In the SDK environment, create a new project named as LwIP\_Test and click Next button.

Select Available Templates: LwIP Echo Server and click Finish button.



Figure 6-1. Create LwIP Test Project

Below image shows the main function of the LwIP test project. If DHCP server is not applicable, then set this static IP in the test routine directly.

The screenshot shows the Xilinx IDE interface with the following details:

- Project Explorer:** Shows the project structure for "LwIP\_Test". The "main.c" file is open in the editor.
- Editor:** The code for "main.c" is displayed. A red box highlights the DHCP configuration section:

```
    /* now enable interrupts */
    platform_enable_interrupts();

    /* specify that the network if is up */
    netif_set_up_echo_netif();

#if (LWIP_DNS == 0)
#endif /* LWIP_DNS */

    /* Create a new DHCP client for this interface.
     * Note: you must call dhcp_find_tmr() and dhcp_coarse_tmr() at
     * the predefined regular intervals after starting the client.

    dhcp_start((echo_netif));
    dhcp_timeoutcntr = 24;

    while((!(echo_netif->ip_addr.addr) == 0) && (dhcp_timeoutcntr > 0))
        xemacif_input((echo_netif));

    if(dhcp_timeoutcntr < 0) {
        if(echo_netif->ip_addr.addr == 0) {
            xil_printf("TCP Timeout\n");
            xil_printf("Configuring default IP of 192.168.1.10\r\n");
            IP4_ADDR(&(echo_netif->ip_addr), 192, 168, 1, 10);
            IP4_NETMASK(&(echo_netif->netmask), 255, 255, 255, 0);
            IP4_BROADCAST(&(echo_netif->gw), 192, 168, 2, 1);
        }
    }

    ipaddr.addr = echo_netif->ip_addr.addr;
    gw.addr = echo_netif->gw.addr;
    netmask.addr = echo_netif->netmask.addr;
#endif

    print_ip_settings(&ipaddr, &netmask, &gw);

#endif
    /* start the application (web server, rxtxtest, txtxtest, etc..) */
    start_application();

    /* receive and process packets */
    while(1) {
        if(TcpFastTmrFlag) {
```
- Outline View:** Shows the list of header files included in the project, such as stdio.h, xparameters.h, netifadapter.h, platform.h, platform\_config.h, xl\_printf.h, lwip/tcp.h, xl\_cache.h, lwip/ip.h, lwip/dhcp.h, print\_app\_header(), start\_application(), transfer\_data(), tcp\_faststart(), tcp\_slowtmr(), lwip\_init(), dhcp\_timeoutcntr, dhcp\_start(), dhcp\_stop(), err\_t, TcpFastTmrFlag, TcpSlowTmrFlag, server\_neef, echo\_neef, print\_ipchar\*, print\_ip\_settings(), ProgramSIS32(), ProgramStPhy(), lrcPhyReset(), and main().
- Target Connections:** Shows connections to "Hardware Server", "Linux TCF Agent", and "QEMU TdGdbClient".
- Bottom Status Bar:** Displays "Writable", "Smart Insert", "220 : 45", and a message in Chinese: "激活 Windows 转到“设置”以激活 Windows,".

## ~~Figure 6-2. Main() Function~~

Right click the project folder DDR3\_Test and then select **Run As → 1 Launch on Hardware (System Debugger)**:



**Figure 6-3. Launch Debugger**



Use mini USB cable to connect the PC and the ZYNQ Bajie Board J4 connector. Below image shows the output log sent by the LwIP\_Test example.



The screenshot shows the SecureCRT application window titled "serial-com5 - SecureCRT". The main pane displays the following log output:

```
----lWIP TCP echo server ----
TCP packets sent to port 6001 will be echoed back
Start PHY autonegotiation
waiting for PHY to complete autonegotiation.
autonegotiation complete
Board Speed : 100M
Board IP: 192.168.2.3
Netmask : 255.255.255.0
Gateway : 192.168.2.1
TCP echo server started @ port 7
```

The log output is highlighted with a red box. Red arrows point from the text "Figure 6-4. Log Info" to the red box and the title bar of the window.

Figure 6-4. Log Info

Open ethernet test assistant and set the configurations as shown in below image. TCP Client@192.168.2.3:7 and connect to server. "<http://www.cmssoft.cn>" is the message will be echo back from the server side.



Figure 6-5. Echo Message

## 7. Reference

- [1] ug585-Zynq-7000-TRM.pdf
- [2] ds187-XC7Z010-XC7Z020-Data-Sheet.pdf
- [3] ug865-Zynq-7000-Pkg-Pinout.pdf
- [4] MT41K256M16TW-107:P.pdf
- [5] tps563201.pdf
- [6] RTL8211E-VL.PDF

上海勤謀電子科技有限公司



## 8. Revision

| Doc. Rev. | Date       | Comments             |
|-----------|------------|----------------------|
| 0.1       | 28/03/2020 | Initial Version.     |
| 1.0       | 13/04/2020 | V1.0 Formal Release. |

上海勤謀電子科技有限公司

