

# QM\_ARTIX7\_XC7A35T DB

## USER MANUAL



### Preface

The QMTECH® XC7A35T DDR3 Development Kit uses Xilinx Artix®-7 devices to demonstrate the highest performance-per-watt fabric, transceiver line rates, DSP processing, and AMS integration in a cost-optimized FPGA. Featuring the MicroBlaze™ soft processor and 1,066Mb/s DDR3 support, the family is the best value for a variety of cost and power-sensitive applications including software-defined radio, machine vision cameras, and low-end wireless backhaul.

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

<http://www.chinaqmtech.com>



QMTECH

QMTECH\_Artix7\_XC7A35T\_Daughter\_Board(User Manual)

## Table of Contents

---

|                                                   |           |
|---------------------------------------------------|-----------|
| <b>1. QM_ARTIX7_XC7A35T DB INTRODUCTION.....</b>  | <b>3</b>  |
| 1.1 DB OVERVIEW.....                              | 3         |
| 1.2 DAUGHTER BOARD TOP VIEW.....                  | 3         |
| <b>2. EXPERIMENT (1): USB TO SERIAL PORT.....</b> | <b>4</b>  |
| <b>3. EXPERIMENT (2): VGA DISPLAYS.....</b>       | <b>7</b>  |
| <b>4. EXPERIMENT (3): GMII ETHERNET TEST.....</b> | <b>10</b> |
| <b>5. EXPERIMENT (4): MICROSD CARD TEST.....</b>  | <b>15</b> |
| <b>6. REFERENCE.....</b>                          | <b>18</b> |
| <b>7. REVISION.....</b>                           | <b>19</b> |



# 1. QM\_Artix7\_XC7A35T DB Introduction

## 1.1 DB Overview

QM\_Artix7\_XC7A35T provides several user interfaces to meet different customer needs. Below section lists the detailed info of these user interfaces:

- USB to UART Serial Port, by using Silicon Labs' CP2102N-A01-GQFN28R chip.
- 16bit(RGB565) VGA display interface, by using resistor dividers;
- GMII ethernet interface, by using Realtek's RTL8211EG chip;
- CMOS/CCD camera interface, by using 18pin female header;
- Two Digilent PMOD standard compatible female headers;
- MicroSD card slot;

## 1.2 Daughter Board Top View

Below figure shows the daughter board of QM\_Artix7\_XC7A35T development kit. The daughter board's dimension is 108.71mm x 134.62mm. All the functional chips' power supply is injected from the 64P female connector, detailed connection refer to the hardware schematic.



Figure 1-1. QM\_Artix7\_XC7A35T Daughter Board

## 2. Experiment (1): USB to Serial Port

The CP2102N-A01-GQFN28R is a USB 2.0 to serial port bridge chip designed by Silicon Labs. The CP2102N-A01-GQFN28R includes a USB 2.0 full-speed function controller, USB transceiver, oscillator, UART and eliminates the need for other external USB components required for development. Below figure shows the hardware design of CP2102N on the QM\_Artix7\_XC7A35T daughter board.



Figure 2-1. CP2102N Hardware Design

Before start to test the CP2102N's USB to UART serial communication function, make sure all the hardware connections of the development kit are correctly connected. Xilinx USB platform cable's VREF, GND, TDI, TMS, TCK, TDO pins shall be connected to QM\_XC7A35T\_DDR3 core board's JTAG interface. Then power on the development kit with 5V DC power source. Xilinx USB platform cable's indicator LED's color will turn from brown into green. At the same time, the Mini-USB cable shall also be plugged in the board, below figure shows an example hardware setup:



All the test examples are developed in the Vivado2018.2 environment. Open the CP2102N test project located in this release folder: /Software/Test05\_usb\_uart\_cp2102n. Below figure shows the project of [uart\\_top](#):



**Figure 2-2. CP2102N UART Communication Test Example**

In this example project, the default communication parameters are: 9600bps, 8 data bit, No Parity Check, 1 stop bit. If users want to test other communication parameters, change the source code accordingly.

```
uart_rx_path.v:1: timescale 1ns / 1ps
uart_rx_path.v:3: module uart_rx_path(
uart_rx_path.v:4:     input clk_i,
uart_rx_path.v:5:     input uart_rx_i,
uart_rx_path.v:7:     output [7:0] uart_rx_data_o,
uart_rx_path.v:8:     output uart_rx_done,
uart_rx_path.v:9:     output baud_bps_tb           //for simulation
uart_rx_path.v:10: );
uart_rx_path.v:12: parameter [12:0] BAUD_DIV      = 13'd5208;    //波特率时钟, 9600bps, 50Mhz/9600=5208
uart_rx_path.v:13: parameter [12:0] BAUD_DIV_CAP = 13'd2604;    //波特率时钟中间采样点, 50Mhz/9600/2=2604
uart_rx_path.v:15: reg [12:0] baud_div=0;          //波特率设置计数器
uart_rx_path.v:16: reg baud_bps=0;            //数据采样点信号
uart_rx_path.v:17: reg bps_start=0;           //波特率启动标志
uart_rx_path.v:18: always@ (posedge clk_i)
uart_rx_path.v:19: begin
uart_rx_path.v:20:     if(baud_div==BAUD_DIV_CAP)           //当波特率计数器计数到采样点时, 产生采样信号baud_bps
uart_tx_path.v:1: timescale 1ns / 1ps
uart_tx_path.v:3: module uart_tx_path(
uart_tx_path.v:4:     input clk_i,
uart_tx_path.v:6:     input [7:0] uart_tx_data_i,        //待发送数据
uart_tx_path.v:7:     input uart_tx_en_i,         //发送发送使能信号
uart_tx_path.v:9:     output uart_tx_o
uart_tx_path.v:12: parameter BAUD_DIV      = 13'd5208;    //波特率时钟, 9600bps, 50Mhz/9600=5208, 波特率可调
uart_tx_path.v:13: parameter BAUD_DIV_CAP = 13'd2604;    //波特率时钟中间采样点, 50Mhz/9600/2=2604, 波特率可调
uart_tx_path.v:15: reg [12:0] baud_div=0;          //波口号设置计数器
uart_tx_path.v:16: reg baud_bps=0;            //数据发送点信号, 高有效
uart_tx_path.v:17: (* MARKDEBUG = "TRUE" *) reg [9:0] send_data=10'b1111111111; //待发送数据寄存器, 1bit起始信号+8bit有效信号+1bit结束信号
uart_tx_path.v:18: (* MARKDEBUG = "TRUE" *) reg [3:0] bit_num=0;           //发送数据个数计数器
uart_tx_path.v:19: reg uart_send_flag=0;          //数据发送标志位
uart_tx_path.v:20: reg uart_tx_o_r=1;
```



After the CP2102N communication test project correctly synthesized, implemented and generated \*.bit file, users could use Vivado 2018.2 program tool to program the generated \*.bit file into FPGA. Below image shows the FPGA program status with program tool.



**Figure 2-3. Program \*.bit File**

The CP2102N example test project's main functionality is performing an UART loopback communication. The FPGA program will send the received UART data back to the PC. Below figure shows user employees some PC based UART test tool to send data to FPGA: <http://www.cmssoft.cn> QQ:10865600. After a short while the PC UART test tool will receive the same data stream from FPGA, which means the CP2102N loopback test program is running correctly.



**Figure 2-4. UART Loopback Test**



### 3. Experiment (2): VGA Displays

The RGB signal accepted by the color monitor is an analog signal, one for each color, in the range 0V to 0.7V according to the VGA spec. So the digital color signal generated by the video controller should be converted to an analog signal. The daughter board uses resistor to form a voltage divider circuit in combination with the 75 ohm load resistance of VGA monitor. Below image shows the hardware design.



**Figure 3-1. VGA Display Hardware Designs**

Before start to test the VGA display function, make sure all the hardware connections of the development kit are correctly connected. Xilinx USB platform cable's VREF, GND, TDI, TMS, TCK, TDO pins shall be connected to QM\_XC7A35T\_DDR3 core board's JTAG interface. Then power on the development kit with 5V DC power source. Xilinx USB platform cable's indicator LED's color will turn from brown into green. At the same time, the VGA cable shall also be plugged in the board, below figure shows an example hardware setup:



Open the VGA test project located in this release folder: /Software/Test09\_VGA\_Test. Below figure shows the example project of **VGA\_test**:



**Figure 3-2. VGA Display Function Test**

In this example project, the default VGA output resolution parameter is 1024x768@60Hz. If users want to test other display parameters, change the source code accordingly.

```

13:     output [4:0] vga_b;
14:     input keyl           //键盘key1
15: );
16: //-----// 
17: // 基本钩线●基带驱动●输出?1024*768 60Hz VGA
18: //-----//
19: parameter LinePeriod=1344;      //显示帧周期
20: parameter H_SyncPulse=136;    //显示同步脉冲Sync a钟?
21: parameter H_BackPorch=160;    //显示后场驱动脉冲back porch b钟?
22: parameter H_ActivePix=1024;   //显示有效像素Display interval c钟?
23: parameter H_FrontPorch=24;    //显示前场驱动脉冲front porch d钟?
24: parameter Hde_start=296;
25: parameter Hde_end=320;
26: //-----//
27: // 基本钩线●基带驱动●输出?1024*768 60Hz VGA
28: //-----//
29: parameter FramePeriod=006;    //显示帧周期
30: parameter V_SyncPulse=6;      //显示同步脉冲Sync e钟?
31: parameter V_BackPorch=29;    //显示后场驱动脉冲back porch p钟?
32: parameter V_ActivePix=768;   //显示有效像素Display interval q钟?
33: parameter V_FrontPorch=3;    //显示前场驱动脉冲front porch r钟?
34: parameter Vde_start=35;
35: parameter Vde_end=100;
36: //-----//
37: //-----//
38: 
```

**Figure 3-3. VGA Display Parameters**

After the VGA display test project correctly synthesized, implemented and generated \*.bit file, users could use Xilinx Vivado 2018.2 program tool to program the generated \*.bit file into FPGA. Below image shows the FPGA program status with program tool.





**Figure 3-4. Program FPGA**

After the FPGA correctly loaded the vga\_test.bit file and users pressed the SW2 button on core board, the VGA monitor will display different color patterns. Below image shows the example color bar pattern.



**Figure 3-5. VGA Display Test**



## 4. Experiment (3): GMII Ethernet Test

The daughter board uses RTL8211EG to implement the 10M/100M/1000M triple speed ethernet interface. It provides all the necessary physical layer functions to transmit and receive ethernet packets over the CAT.5 UTP cable. The data transfer between PHY and FPGA is via the Gigabit Media Independent Interface(GMII) for 1000Base-T. The RTL8211EG-VB chip supports 3.3V signaling for GMII interface. Below image shows the hardware design of RTL8211EG:



**Figure 4-1. RTL8211 Hardware Design**

Before start to test the GMII ethernet communication function, make sure all the hardware connections of the development kit are correctly connected. Xilinx USB Platform cable shall be connected to QM\_Artix7\_XC7A35T core board's JTAG interface. The ethernet cable shall be plugged in the board and the test computer simultaneously. Then power on the development kit with 5V DC power source. Below figure shows an example hardware setup:





**Figure 4-2. Test Setup**

Use Vivado2018.2 to open the GMII ethernet test project located in this release folder: /Software/Test08\_GMII\_Ethernet. Below figure shows the example project of [ethernet\\_test](#):



After the ethernet test project correctly synthesized, implemented and generated \*.bit file, users could use Vivado 2018.2 program tool to program the generated \*.bit file into FPGA. Below image shows the FPGA program status with program tool.



Figure 4-3. FPGA Program

Users could check the ethernet connection status in the Windows OS. Below images shows the ethernet communication speed between the FPGA development board and the test computer is 1Gbps based.



In order to finish this ethernet test, users need to set the Windows's Static IP into 192.168.0.3:



Figure 4-4. Configure Test PC's IP

Run Windows Command Console as administrator. In that DOS type command window bind the development board's IP address(192.168.0.2) and MAC address (00-0a-35-01-fe-c0) by typing command: ARP -s 192.168.0.2 00-0a-35-01-fe-c0:

The screenshot shows a Windows Command Prompt window titled '管理员: 命令提示符'. The command 'ARP -s 192.168.0.2 00-0a-35-01-fe-c0' is typed and executed. The output shows the command was successful.

```
Administrator: 命令提示符
Microsoft Windows [版本 10.0.17134.471]
(c) 2018 Microsoft Corporation. 保留所有权利。
C:\WINDOWS\system32>ARP -s 192.168.0.2 00-0a-35-01-fe-c0
```

Figure 4-5. Binding IP and MAC



Open the NetAssist ethernet debug tool and set the communication parameters as shown in below figure. The NetAssist tool will receive the test data “HELLO QMTECH BOARD” sent from development board. Then press the 【Send】 button to send the test data <http://www.cmsoft.cn> QQ:10865600 to the FPGA development board. In response, the FPGA will send back test data to the test PC.



Figure 4-6. GMII Ethernet Test Result



## 5. Experiment (4): MicroSD Card Test

The daughter board provides a MicroSD slot to extend MicroSD or TF card. In this experiment, we uses 8GB Micro SDHC card provided by Kingston. The Micro SDHC card meets the specification of SD V2.0. Below image shows the hardware design of MicroSD slot:



Figure 5-1. MicroSD Hardware Design

Before start to test the MicroSD read/write function, make sure all the hardware connections of the development kit are correctly connected. Xilinx Platform USB cable shall be connected to QM\_Artix7\_XC7A35T core board's JTAG interface. The Kinston 8 GB micro SD card shall be plugged in the board. Then power on the development kit with 5V DC power source. below figure shows an example hardware setup:



Figure 5-2. Test Environment Setup

In this test example, the MicroSD card is working under SPI mode which could be easily handled by FPGA. SPI interface only has four wires: CS, MOSI, MISO, CLK. The clock frequency for the SPI interface is 10MHz which is divided by the on board 50MHz crystal directly. After Power-On, the MicroSD card enters SD mode and users need to send command to make the MicroSD switch to SPI mode. Then users need to follow the sequence shown in below figure to initialize the MicroSD card. Users may refer to the SD v2.0 spec for more details regarding to the Read and Write protocol.





**Figure 5-3. Initialize Sequence**

After correctly initialized the MicroSD, the test program will write a batch of test data into the MicroSD card and then read back all these written value for further comparison. Here we use ILA to monitor these data transfer between the FPGA and the MicroSD card. Users may follow the ILA settings shown in below figure to observe the transactions. The sampling clock frequency is using on board 50MHz crystal and the trigger signal for sampling is myvalid\_o. When myvalid\_o goes high, there will be data comes from MicroSD card.



After the MicroSD test project correctly synthesized, implemented and generated \*.bit file, users could use Xilinx program tool to program the generated \*.bit file into FPGA. And then press the button SW1 on FPGA daughter board to trigger the test. After a short while, the ILA will stop capturing the data immediately after the myvalid\_o signal goes high. Then we can see the init\_o is already in high status which means the MicroSD has already been correctly initialized. And the data signal mydata\_o displays the data read out from MicroSD card.



Figure 5-4. Data Write and Read Waveform



## 6. Reference

- [1] ug470\_7Series\_Config.pdf
- [2] ds181\_Artix\_7\_Data\_Sheet.pdf
- [3] ug475\_7Series\_Pkg\_Pinout.pdf
- [4] n25q\_64a\_3v\_65nm.pdf
- [5] MT41J128M16JT-125K.pdf
- [6] MP2359.pdf
- [7] NCP1529-D.PDF

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



## 7. Revision

| Doc. Rev. | Date       | Comments             |
|-----------|------------|----------------------|
| 0.1       | 1/1/2018   | Initial Version.     |
| 1.0       | 12/1/2018  | V1.0 Formal Release. |
| 3.0       | 12/01/2019 | V2.0 Formal Release. |
|           |            |                      |

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

