

## FPGA Setup for TOE/UDP1G IP with CPU Demo

Rev3.0 10-Nov-20

This document describes how to setup FPGA board and prepare the test environment for running TOE1G-IP or UDP1G-IP demo. The user can setup two test environments for transferring TCP data or UDP data via 1Gb Ethernet connection by using TOE1G-IP or UDP1G-IP, as shown in Figure 1-1.



Figure 1-1 Two test environments for running the demo

First uses one FPGA board and Test PC with 1Gb Ethernet card for transferring the data. Test PC runs test application, i.e., tcpdatatest (half-duplex test for TOE1G-IP), tcp\_client\_txrx\_40G for (full-duplex test for TOE1G-IP) or udp1gdatatest (test application for UDP1G-IP). Also, Serial console is run on Test PC to be user interface console.

Second uses two FPGA boards which may be different board or the same board. Both boards run TOE1G-IP or UDP1G-IP demo with assigning the different initialization mode (Client for Server) for transferring data.



## 1 Test environment setup when using FPGA and PC

Before running the test, please prepare following test environment.

- FPGA development boards: ZC706/KC705/AC701 board
- PC with 1 Gigabit Ethernet or connecting with 1 Gigabit Ethernet card
- 1Gb Ethernet connection: Cat5e or Cat6 cable for between FPGA and PC/FPGA <u>Note</u>: When using ZC706, SFP+ to RJ45 adapter for connecting to SFP+ connector on ZC706 board must be used.
- micro USB cable for programming FPGA, connecting between FPGA board and PC
- mini USB cable for Serial console, connecting between FPGA board and PC
- Test application provided by Design Gateway for running on Test PC: TOE1G-IP: "tcpdatatest.exe" and "tcp\_client\_txrx\_40G.exe" UDP1G-IP: "udp1gdatatest.exe"
- Serial console software such as TeraTerm installed on PC. The setting on the console is Baud rate=115,200, Data=8-bit, Non-parity and Stop=1.
- Vivado tool for programming FPGA, installed on PC





Figure 1-1 TOE1G-IP/UDP1G-IP with CPU demo (FPGA <-> PC) on ZC706



dg\_toeudp1gip\_fpgasetup\_xilinx.doc Ele Edit Setup Control Window Help Serial Console 'tcpdatatest.exe'/ 'tcp\_client\_txrx\_40G.exe'
 or 'udp1gdatatest.exe' C € XILINX. mini USB cable 🙆 #FMC KINTEX (UART) C C 00:0A 35:02:78.64 micro USB cable (JTAG) KC705 0 CAT5e/CAT6 cable for 1Gb Ethernet S/N 1230-2352 Figure 1-2 TOE1G-IP/ UDP1G-IP with CPU demo (FPGA <-> PC) on KC705







The step to setup test environment by using FPGA and PC is described in more details as follows.

- 1) Power off system.
- 2) Connect micro USB cable and mini USB cable from FPGA board to PC for JTAG programming and USB UART (Serial Console).
- 3) Connect power supply to FPGA development board.
- 4) For ZC706, connect SFP to RJ45 adapter into SFP+ connector on ZC706 board.



Figure 1-4 Connect SFP to RJ45 adapter to ZC706

5) Connect CAT5e or CAT6 cable between RJ45 on FPGA board to PC



- 6) Power on FPGA board.
- 7) Open Serial console to connect to FPGA board. Serial setting is Baud rate = 115,200, Data=8-bit, Non-parity, and Stop = 1.



- 8) Download and program configuration file and firmware to FPGA board.
  - a) For ZC706 board, open Vivado TCL shell and change current directory to download folder which includes demo configuration file. Type "xxx1gcputest\_zc706.bat", as shown in Figure 1-6.

| Vivado 2017.4 Tcl Shell - E:\Program\Xilinx\Vivado\2017.4\bin\vivado.bat -mode tcl — | >  | < |
|--------------------------------------------------------------------------------------|----|---|
|                                                                                      |    | ^ |
| Vivado% cd D:/Temp/download                                                          |    |   |
| Vivado% udp1gcputest_zc706.bat_                                                      |    |   |
|                                                                                      |    | ¥ |
| Figure 1-6 Example command script for download to ZC706 by Vivado to                 | ol |   |

b) For AC701/KC705 board, configure FPGA by using Vivado, as shown in Figure 1-7.

| Vivado 2017.4                                       | HARDWARE MANAGER - unconnected                                                                                                                                                               |
|-----------------------------------------------------|----------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| Eile Flow Iools Window Help Q- Quick Access         | Open target<br>No hardware target is open. Open target                                                                                                                                       |
| HLx Editions                                        | Hardware Auto Connect                                                                                                                                                                        |
| Quick Start<br>Create Project ><br>Open Project >   | Open New Target HARDWARE M AGER - localhost/xilinx_tcf/Digile d. Click Program device There are no debug cores. Program device Refresh device                                                |
| Open Example Project >                              | Hardware ? _ □ ⊡ ×<br>Q,   ★   ♦   Ø   ▶   ≫   ■   ✿                                                                                                                                         |
| Tasks<br>Manage IP > a. Click Open Hardware Manager | Name     Status       ✓ Il localhost (1)     Con         |
| Open Hardware Manager ><br>Xilinx Tcl Store >       | xc7k325t_0 (1)     Programmed     XADC (System Monitor)                                                                                                                                      |
| 🍌 Program Device                                    | ×                                                                                                                                                                                            |
|                                                     | e and download it to your hardware device. You<br>es file that corresponds to the debug cores<br>ming file.<br>e. Click "" to select Programming file<br>(TOE1GCPUTest.bit/UDP1GCPUTest.bit) |
| Bitstream file: D:/Temp/T                           | OE1GCPUTest.bit 🛞                                                                                                                                                                            |
| Debu <u>a</u> probes file:                          |                                                                                                                                                                                              |
| Enable end of startup check                         | x                                                                                                                                                                                            |
| 3                                                   | Program Cancel                                                                                                                                                                               |
|                                                     | f. Click Program button to<br>start FPGA programming                                                                                                                                         |
| Figure 1-7 Program                                  | FPGA by Vivado for AC701/KC705                                                                                                                                                               |



- 9) On serial console, welcome message is displayed.
  - a. Input '0' to initialize TOE1G-IP/UDP1G-IP in client mode (ask PC MAC address by sending ARP request).
  - b. Default parameter in client mode is displayed on the console.

| UDP1G-IP                                                                                                                                                                                                        | TOE1G-IP                                                                                       |                                                           |
|-----------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|------------------------------------------------------------------------------------------------|-----------------------------------------------------------|
| UDP1GIP with CPU Demo [Ver = 1.6]<br>Input mode : [0] Client [1] Server => 0                                                                                                                                    | TOE1GIP with CPU Demo [IPVer = 2.<br>Input mode : [O] Client [1] Server =)                     | Input '0' to initialize<br>,25 in client mode<br>♪┃       |
| Default UDP1GIP Parameter<br>Mode = CLIENT<br>FPGA MAC address = 0x000102030405<br>FPGA IP = 192.168.11.42<br>Target IP = 192.168.11.25<br>FPGA port number = 4000<br>Target port number (Target->FPGA) = 61000 | Target IP = 192.168.11.25<br>FPGA IP = 192.168.11.42                                           | Default client parameters,<br>displayed on boot-up screen |
| Target port number (Target / Target) = 60000<br>Press 'x' to skip parameter setting:                                                                                                                            | Target port number = 60001<br>FPGA port number = 60000<br>Press 'x' to skip parameter setting: |                                                           |

Figure 1-8 Message after system boot-up

c. User enters 'x' to skip parameter setting for using default parameters to begin system initialization, as shown in Figure 1-9. If user enters other keys, the menu for changing parameter is displayed, similar to "Reset TCPIP/UDPIP parameters" menu. The example when running the main menu is described in "dg\_toe1gip\_cpu\_instruction" or "dg\_udp1gip\_cpu\_instruction document.



<u>Note</u>: Transfer performance in the demo depends on Test PC resource in Test platform.



## 2 Test environment setup when using two FPGAs

Before running the test, please prepare following test environment.

- Two FPGA development boards which are the same board or the different board, ZC706/KC705/AC701
- Cat5e or Cat6 cable for 1 Gb Ethernet connection between two FPGA boards (Ethernet connection between two FPGA boards could be connected directly or connected through other network devices such as Ethernet switch) *Note: When using ZC706, insert SFP to RJ45 adapter to SFP+ connector on FPGA board.*
- Connect micro USB cable and mini USB cable for programming FPGA and Serial console between each FPGA board and PC (two sets are used for two FPGA boards)
- Serial console software such as TeraTerm, installed on PC. The setting on the console is Baudrate=115,200, Data=8-bit, Non-parity, and Stop=1.
- Vivado tool for programming FPGA, installed on PC





The step to setup test environment by using two FPGAs is described in more details as follows.

Follow step 1) - 8) of topic 1 (Test environment setup when using FPGA and PC) to prepare FPGA board for running the demo. After two FPGA boards have been configured completely, Serial console displays the menu to select client mode or server mode. The step after FPGA configuration is described as follows.

- 1) Open Serial console for board#1 and board#2 which are initialized as Server and Client respectively.
  - a. Set '1' on Serial console of FPGA board#1 for running server mode.
  - b. Set '0' on Serial console of FPGA board#2 for running client mode.
  - c. Default parameters for server or client are displayed on the console, as shown in Figure 2-2.

| COM10 - Tera Term                                                                                                                                                                                                                                                                                                                                                                                                                                                                   | r _ UDP1G                                                                       | -IP COM26                                                                                              | - Tera Term V                                                                  | Client                                                                          | _                                                           |   |
|-------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|---------------------------------------------------------------------------------|--------------------------------------------------------------------------------------------------------|--------------------------------------------------------------------------------|---------------------------------------------------------------------------------|-------------------------------------------------------------|---|
| <u>File Edit Setup Control</u> Set<br>mod                                                                                                                                                                                                                                                                                                                                                                                                                                           | le for FPGA board#1<br>o [Ver = $1.6$ ]                                         | UDP1G                                                                                                  | Setup Control                                                                  | mode for<br>Demo [Ve                                                            | select client<br>FPGA board#                                |   |
| Input mode : [0] Client [1] Server => 1<br>Default UDP1GIP Parameter<br>Mode = SERVER<br>PPGA MAC address = 0x001122334455<br>PPGA IP = 192.168.11.25<br>FPGA IP = 192.168.11.42<br>PPGA port number = 60000<br>Carget port number (Target->FPGA) = 4000<br>Carget port number (FPGA->Target) = 60000 c<br>Press 'x' to skip parameter setting: |                                                                                 |                                                                                                        |                                                                                |                                                                                 |                                                             |   |
|                                                                                                                                                                                                                                                                                                                                                                                                                                                                                     | efault parameters for<br>er mode is displayed                                   |                                                                                                        |                                                                                | •                                                                               | t parameters f<br>de is displaye                            |   |
|                                                                                                                                                                                                                                                                                                                                                                                                                                                                                     | n. Set '1' to select server<br>mode for FPGA board#1<br>Demo [IPVer = 2.25( a)- | <u>File Edit S</u>                                                                                     | Tera Term VT<br>etup C <u>o</u> ntrol<br>P with CPU A<br>: [0] Clier           | mode for Fi                                                                     | $- \Box$ select client PGA board#2 $er = 2.25$ $bruer = 20$ | ] |
| Default TOE1GIP Parama<br>Window Update Gap = (<br>Mode = S<br>FPGA MAC address = (<br>Target IP = 3                                                                                                                                                                                                                                                                                                                                                                                | eter<br>SERUER<br>3×001122334455<br>192.168.11.42<br>192.168.11.25<br>\$0000    | -<br>Default TO<br>Window Upd<br>Mode<br>FPGA MAC a<br>Target IP<br>FPGA IP<br>Target por<br>FPGA port | EIGIP Paramo<br>ate Gap =  <br>ddress =  <br>= :<br>= :<br>= :<br>t number = ! | eter<br>0<br>CLIENT<br>0×00010203<br>192.168.13<br>192.168.13<br>60001<br>60000 | 30405<br>L.25<br>L.42 C                                     |   |
|                                                                                                                                                                                                                                                                                                                                                                                                                                                                                     | It parameters for<br>node is displayed<br>Figure 2-2                            | 2 Input mo                                                                                             | client mode                                                                    | arameters fo<br>is displayed                                                    |                                                             |   |



2) Input 'x' to use default parameters or other keys to change parameters. The parameters of server mode must be set before client mode.

When running TOE1G-IP,

- a. Set parameters on server Serial console.
- b. Set parameters on client Serial console to start IP initialization by transferring ARP packet.
- c. After finishing initialization process. "IP initialization complete" and main menu are displayed on server console and client console.



Figure 2-3 Main menu of TOE1G-IP



When running UDP1G-IP,

- a. For server mode, if user does not change default parameters, input 'x' to skip parameter setting.
- b. For client mode, user must change target port number (Target->FPGA) to use same value as target port number (FPGA->Target).
- c. After finishing initialization process. "IP initialization complete" and main menu are displayed on server console and client console.

| 💆 COM10 - Tera Term VT Server                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                               |            | P1G-IP                                                                                                                                                                                                                            | 6 - Tera Term VT                                                                                                                                                                                          | Client                                                                                                                                                       |                                                            | : User Input<br>: User Output                                      |
|-------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|------------|-----------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|-----------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|--------------------------------------------------------------------------------------------------------------------------------------------------------------|------------------------------------------------------------|--------------------------------------------------------------------|
| COM10-Tera Term VT Server - UDI<br><u>File Edit Setup Control Window H</u><br><u>File Edit Setup Control Window H</u><br><u>Default parameters</u><br><u>for server mode</u><br><u>Input mode : [0] Client [1] Server =&gt; 1</u><br><u>Default UDP1GIP Parameter</u><br><u>Mode = SERVER</u><br><u>FPGA MAC address = 0x001122334455</u><br><u>FPGA MAC address = 0x0011223344555</u><br><u>FPGA IP = 192.168.11.25</u><br><u>Target IP = 192.168.11.42</u><br><u>FPGA port number (Target-&gt;FPGA) = 4000</u><br><u>Target port number (FPGA-&gt;Target) = 4000</u><br><u>Target port number (FPGA-&gt;Target) = 4000</u><br><u>Press 'x' to skip parameter setting:</u><br><u>Use default parameter</u> |            | <u>File Edit</u><br><u>Default</u><br><u>Mode</u><br><u>PFGA MAC</u><br><u>PFGA PD</u><br><u>Target 1</u><br><u>Target 1</u><br><u>Target 1</u><br><u>Input m</u><br><u>Invalid</u><br>Input FI<br>Invalid<br>Input FI<br>Invalid | <u>Setup Control Window</u><br>LGIP with CPU Demo [1<br>ode : [0] Client [1]<br>UDP1GIP Parameter<br>= CLIENT<br>C address = 0x0001021<br>= 192.168.                                                      | <u>Help</u><br>Ver = 1.6] -<br>Server => 0<br>030405<br>11.42<br>11.25<br>>FPGA> = 610<br>arget> = 600<br>setting[y]<br>Server =>[<br>pt change<br>pt change | Defaul<br>for clie<br>190<br>190<br>Input t                | t parameters<br>ent mode<br>o set parameter<br>ue to use old value |
|                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                             | Figure 2-4 | Invalid<br>Input Fi<br>Invalid<br>Input Ta<br>Invalid<br>UDP1GIP<br>Mode<br>FPGA MAG<br>FPGA MAG<br>FPGA IP<br>Target I<br>Target I<br>Target MARNING                                                                             | input : Parameter n<br>PGA port number : n<br>input : Parameter n<br>arget port number (Ta<br>arget port number (F<br>input : Parameter n<br>Parameter<br>= CLIENT<br>C address = 0×0001021<br>= 192.168. | ot change<br>arget->FPGA)<br>PGA->Target)<br>ot change<br>030405<br>11.42<br>11.25<br>>FPGA) = 600<br>IP setting                                             | Alue for both T<br>. : 60000<br>. : n<br>New p<br>for clie | arameters<br>ent mode<br>er on Test app                            |



## 3 Revision History

| Revision | Date      | Description                       |  |  |
|----------|-----------|-----------------------------------|--|--|
| 1.0      | 2-Nov-18  | Initial version release           |  |  |
| 2.0      | 31-Jul-20 | Remove test result on the console |  |  |
| 3.0      | 10-Nov-20 | TOE1G-IP and UDP1G-IP             |  |  |