

# TOE1G-IP two-port (HW) Instruction

| 1 | E   | Environment Setup         |
|---|-----|---------------------------|
| 2 | F   | PC Setup2                 |
|   | 2.1 | IP Setting2               |
|   | 2.2 | Speed and Frame Setting4  |
|   | 2.3 | Power Option Setting6     |
| 3 | F   | PGA board setup7          |
| 4 | Ν   | Aain Menu10               |
|   | 4.1 | Display current parameter |
|   | 4.2 | Reset TOE1G-IP            |
|   | 4.3 | Send Data Test            |
|   | 4.4 | Receive Data Test         |
|   | 4.5 | Full duplex Test          |
|   | 4.6 | Slow Port Test by Ping    |
| 5 | F   | Revision History          |



# TOE1G-IP two-port (HW) Instruction

Rev1.0 4-Jul-23

This document describes the instruction to run two-port demo by using TOE1G-IP and CPU. The data is transferred by using TCP/IP protocol on high speed session or low speed session via 1 Gb Ethernet. User sets test mode and test parameters for TOE1G-IP through NiosII command shell. Similar to TOE1G-IP demo, high speed session is run with the test applications on PC, named "tcpdatatest.exe" and "tcp\_client\_txrx\_40G.exe". Low speed session is run with "Ping" command. More details of high-speed session are described in TOE1G-IP demo document.

https://dgway.com/products/IP/TOE1G-IP/dg\_toe1gip\_cpu\_refdesign\_intel\_en.pdf https://dgway.com/products/IP/TOE1G-IP/dg\_toe1gip\_cpu\_instruction\_intel\_en.pdf

## 1 Environment Setup

As shown in Figure 1-1, please prepare following test environment for running two-port demo.

- 1) FPGA Development board (Cyclone10GX board)
- 2) PC with 1 Gigabit Ethernet support
- 3) Ethernet cable (Cat5e or Cat6) for network connection between FPGA Development board and PC
- 4) Micro USB cable for programming FPGA between FPGA Development board and PC
- 5) QuartusII Programmer for programming FPGA and NiosII command shell, installed on PC
- 6) "tcpdatatest.exe" and "tcp\_client\_txrx\_40G.exe" which are test application provided by Design Gateway, installed on PC



Figure 1-1 Demo Environment Setup on Cyclone10 Gx board



## 2 PC Setup

Before running demo, network setting on PC is required. The example to set the network is described as follows.

## 2.1 IP Setting

| Network and Sharing Center          |                                                       |                                         |        |
|-------------------------------------|-------------------------------------------------------|-----------------------------------------|--------|
| 🗧 🔶 👻 🛧 👱 > Control Pa              | nel > Network and Internet > Netw                     | vork and Sharing Center 🗸 🗸 Sea         | arch C |
| Control Panel Home                  | View your basic network in                            | information and set up connections      |        |
| Change adapter settings             | View your active networks                             |                                         |        |
| Change advanced sharing<br>settings | <b>Network</b><br>Public network                      | Access type: Internet<br>Connections: U | 2      |
|                                     | Change your networking settings<br>Figure 2-1 IPv4 se | etting                                  |        |

- 1) Open Ethernet setting option from Control Panel -> Network and Internet -> Network and Sharing Center.
- 2) Click Gigabit Ethernet icon which is used to connect with FPGA board.

| Ethernet Status    | >                  | Ethernet Properties                                          |
|--------------------|--------------------|--------------------------------------------------------------|
| eneral             |                    | Networking                                                   |
| Connection         |                    | Connect using: 1-Gb LAN connection                           |
| IPv4 Connectivity: | No Internet access | Intel(R) Ethemet Connection (7) I219-V                       |
| IPv6 Connectivity: | No network access  |                                                              |
| Media State:       | Enabled            | Configure                                                    |
| Duration:          | 01:56:55           | This connection uses the following items:                    |
| Speed:             | 1.0 Gbps           | Client for Microsoft Networks                                |
|                    |                    | File and Printer Sharing for Microsoft Networks              |
| Details            | 1                  | QoS Packet Scheduler 4                                       |
|                    |                    | Internet Protocol Version 4 (TCP/IPv4)                       |
|                    |                    | Microsoft Network Adapter Multiplexor Protocol               |
| ctivity            |                    | Microsoft LLDP Protocol Univer                               |
|                    |                    |                                                              |
| Sent —             | - Received         | (5)                                                          |
|                    |                    | Install Uninstall Properties                                 |
| Bytes: 39,299,55   | 503,073,087        | Description                                                  |
| 3                  |                    | Transmission Control Protocol/Internet Protocol. The default |
|                    | Diagnose           | wide area network protocol that provides communication       |
| Disable            | Diagnose           | across diverse interconnected networks.                      |
|                    |                    |                                                              |
|                    | Close              |                                                              |
|                    |                    | OK Canc                                                      |

#### Figure 2-2 Select IP address setting menu

- 3) Click Properties button in Ethernet Status window.
- 4) Select "TCP/IPv4".
- 5) Click Properties button in Ethernet Properties.



| Internet Protocol Version 4 (TCP/IPv4) Properties                                                                                                                               | ×   |  |  |  |  |
|---------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|-----|--|--|--|--|
| General                                                                                                                                                                         |     |  |  |  |  |
| You can get IP settings assigned automatically if your network supports this capability. Otherwise, you need to ask your network administrator for the appropriate IP settings. |     |  |  |  |  |
| Obtain an IP address automatically                                                                                                                                              |     |  |  |  |  |
| Use the following IP address:     (6a)                                                                                                                                          | - 1 |  |  |  |  |
| IP address: 192 . 168 . 11 . 25                                                                                                                                                 |     |  |  |  |  |
| Subnet mask: 255 . 255 . 255 . 0                                                                                                                                                |     |  |  |  |  |
| Default gateway:                                                                                                                                                                |     |  |  |  |  |
| Obtain DNS server address automatically                                                                                                                                         |     |  |  |  |  |
| • Use the following DNS server addresses:                                                                                                                                       | - 1 |  |  |  |  |
| Preferred DNS server:                                                                                                                                                           |     |  |  |  |  |
| Alternate DNS server:                                                                                                                                                           |     |  |  |  |  |
| Validate settings upon exit                                                                                                                                                     |     |  |  |  |  |
| OK Cancel                                                                                                                                                                       |     |  |  |  |  |
| Figure 2-3 Set IP address                                                                                                                                                       |     |  |  |  |  |

6) Set IP address = 192.168.11.25 and Subnet mask = 255.255.255.0. After that, click OK button to confirm IP address setting.



## 2.2 Speed and Frame Setting



Figure 2-4 Jumbo frame setting

- 1) Click Configure button in Ethernet Properties window.
- 2) On Advanced Tab, select "Jumbo Packet" and then set Value to "9014 Bytes" for Jumbo Frame support.



3) On Link Speed, select "1 Gbps Full Duplex" and click OK button, as shown in Figure 2-5.

| reaming                                                                  | VLANs                                                | Driver                                 | Details                        | Events     |
|--------------------------------------------------------------------------|------------------------------------------------------|----------------------------------------|--------------------------------|------------|
| General                                                                  | Link Speed                                           | Advanced                               | Power N                        | lanagement |
| (intol)                                                                  | Link Speed and                                       | d Duplex Settings                      |                                |            |
| litter                                                                   | Intel(R) PROSe                                       | t Version: 23.2.0                      | 1006                           |            |
| Link Status                                                              |                                                      |                                        |                                |            |
| Speed:                                                                   | 1.00 Gbp                                             | s Full Duplex (EE                      | E: Active)                     |            |
|                                                                          |                                                      |                                        |                                |            |
| Speed and Du                                                             | plex:                                                |                                        |                                |            |
| 1.0 Gbps Full                                                            | Duplex                                               | ~                                      | Diagnostic                     | s          |
| Auto Negotiati                                                           | on                                                   | _                                      | -                              |            |
| 10 Mbps Half                                                             | Duplex                                               |                                        | Idontify Ada                   | tor        |
| 10 Mbps Full L<br>100 Mbps Hall                                          | Juplex<br>Duplex                                     |                                        | identity Adap                  | ACI        |
| 100 Mbps Full                                                            | Duplex                                               |                                        |                                |            |
| 1.0 Gbps Full                                                            | Duplex                                               | default, Inte                          | l® adapters a                  | re set     |
| to automatic                                                             | any detect and ne                                    | t you can set the                      | e speed and d                  | luplex     |
| If the adapte                                                            | natch those of the                                   | e link partner.                        |                                |            |
| If the adapte<br>settings to n                                           |                                                      |                                        |                                |            |
| If the adapte<br>settings to n                                           |                                                      |                                        |                                |            |
| If the adapte<br>settings to n                                           | nation icon                                          |                                        |                                |            |
| If the adapte<br>settings to n                                           | nation icon                                          |                                        |                                |            |
| If the adapte<br>settings to n                                           | mation icon                                          | the device is not                      | linked at its                  |            |
| If the adapte<br>settings to n<br>Inform<br>This icon is a<br>maximum ca | mation icon<br>displayed when t<br>pable speed. In t | the device is not<br>hat case, if your | linked at its<br>device is set | to         |

Figure 2-5 Set link speed = 1 Gbps



## 2.3 Power Option Setting



- 1) Open Control Panel and select Power Options.
- 2) Select High performance plan.



## 3 FPGA board setup

- 1) Power off system and connect power supply to FPGA development board
- 2) Connect micro USB cable from FPGA board to PC.
- 3) Connect CAT5e or CAT6 cable between RJ45 on FPGA board to PC.
- 4) Power on system.





- 5) Open QuartusII Programmer to program FPGA through USB-1 by following step.
  - a) Click "Hardware Setup..." to select USB-BlasterII [USB-1].
  - b) Click "Auto Detect" and select FPGA device.
  - c) Select FPGA device icon.
  - d) Click "Change File" button, select SOF file in pop-up window, and click "open" button
  - e) Check "program"
  - f) Click "Start" button to program FPGA
  - g) Wait until Progress status is equal to 100%

| 😃 Quartus Prime Pr         | ogrammer Pro Edition - [Ch                       | ain1.cdf]*         |          |             |              |             |                 | - 0          | ×               |
|----------------------------|--------------------------------------------------|--------------------|----------|-------------|--------------|-------------|-----------------|--------------|-----------------|
| Eile Edit View I           | Processing Tools Windo<br>ardware Setup -> USB-1 | w <u>H</u> elp     |          |             |              | g) W        | ait until F     | Progress =   | 100% 🕨          |
| Hardware Setup.            | USB-Blasterii [USB-1]                            | Мо                 | de: JTAG |             | ▼ Pro        | g<br>gress: | 100             | % (Successfu | l)              |
| Enable real-time           | ISP to allow background pro                      | ogramming when ava | ailable  |             |              | _           |                 |              |                 |
|                            | f) Click "Start" button                          |                    | 1        | 1           | 1            |             |                 |              |                 |
| ► <sup>™</sup> Start       | File                                             | Device             | Checksum | Usercode    | Program/     | Verify      | Blank-<br>Check | Examine      | Security<br>Bit |
| Stop                       | b) Select FPGA Device                            |                    | 00000000 | 00000000    |              |             |                 |              |                 |
| <b>b</b>                   | <none></none>                                    | 2*CFI_1Gb          |          |             |              |             |                 |              |                 |
| Auto Detect                | D:/Demo/TOE1GIP_Tw                               | 10CX220YF780       | 0970F68E | 0970F68E    | <b>√</b> (e) |             |                 |              |                 |
| XDelete                    |                                                  |                    |          |             | e            | ) Check     | "Progra         | n"           |                 |
|                            | d) Click "Change File"                           | button -> Select   |          |             |              |             |                 |              | Þ               |
| Add File                   | TOE1GIP_TwoPortHW.                               | SOF                |          |             |              |             |                 |              | <b>A</b>        |
| Change File                |                                                  |                    |          |             |              |             |                 |              |                 |
|                            | 2*CFI 1Gb                                        |                    |          |             |              |             |                 |              |                 |
| Save File                  | -                                                |                    |          |             |              |             |                 |              |                 |
|                            | <b>★</b>                                         |                    |          |             | ovice        |             |                 |              |                 |
|                            |                                                  |                    | c) 3     | electificad | evice        |             |                 |              |                 |
| 1 <sup>™</sup> Up          | (intal)                                          |                    |          |             |              |             |                 |              |                 |
|                            | TDI                                              |                    |          |             |              |             |                 |              |                 |
| <b>↓</b> <sup>™</sup> Down |                                                  |                    |          |             |              |             |                 |              |                 |
|                            | :                                                |                    |          |             |              |             |                 |              |                 |
|                            | 10M085A                                          | 10CX220            | YE /80   |             |              |             |                 |              |                 |
|                            | TDO                                              |                    |          |             |              |             |                 |              |                 |
|                            | 4                                                |                    |          |             |              |             |                 |              | -               |
|                            |                                                  |                    |          |             |              |             |                 |              |                 |
|                            |                                                  |                    |          |             |              |             |                 |              |                 |

Figure 3-2 FPGA Programmer



- 6) Open NiosII command shell.
  - a) Type "nios2-terminal".
  - b) Enter '0' to initialize TOE1G-IP in client mode (ask PC MAC address by sending ARP request).
  - c) Default parameter in client mode is displayed on NiosII command shell.

| Select /cygdrive/e/Altera/18.0                                                                                                                                                                                                                                                           |                                                                                                                                           | _     | × |
|------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|-------------------------------------------------------------------------------------------------------------------------------------------|-------|---|
| Altera Nios2 Command Shell<br>Version 18.0, Build 219                                                                                                                                                                                                                                    | Green : User Input<br>Blue: Output to cor                                                                                                 | nsole | ^ |
| Gun@GunPC /cugdrive/e/Altera/18.0<br>5 nios2-terminal -> Command to run terr<br>nios2-terminal: connected to hardware<br>nios2-terminal: "USB-BlasterII [USB-1]<br>nios2-terminal: (Use the IDE stop butt<br>TOE1GIP Two Ports Demo [IPVer = 2.<br>Input mode : [0] Client [1] Server => | ninal<br>target using JTAG UART on<br>", device 2, instance Ø<br>on or Ctrl-C to terminate<br>27]<br>Ø -> Input 'O' to initialize in clie | cable |   |
| +++ Current Network Parameter +++<br>Vindow Update Gap = 0<br>Mode = CLIENT<br>FPGA MAC address = 0x000102030405<br>FPGA IP = 192.168.11.42<br>FPGA port number = 60000<br>Target IP = 192.168.11.25<br>Target port number = 60001<br>Press 'x' to skip parameter setting:_              | -> Default client parameter<br>display on boot-up screen                                                                                  |       | Ŷ |

Figure 3-3 Message after system boot-up

7) User enters 'x' to skip parameter setting and use default parameters for system initialization, as shown in Figure 3-4. When user enters other keys, the menu to change parameter is displayed. The example to change parameter is shown in topic 4.2

| /cygdrive/e/Altera/18.0 Press 'x' to skip parameter setting x -> R IP initialization complete defa                                                                                                                                                 | eset by using<br>ult parameter |
|----------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|--------------------------------|
| TOE1GIP menu<br>[0] : Display TCPIP parameters<br>[1] : Reset TCPIP parameters<br>[2] : Send Data Test (TOEIP -> Target)<br>[3] : Receive Data Test (Target -> TOEIP)<br>[4] : Full duplex Test (TOEIP <-> Target)<br>[5] : Slow Port Test by Ping | -> Main Menu                   |
|                                                                                                                                                                                                                                                    | -                              |

Figure 3-4 System initialization

Note: Transfer performance depends on Test PC resource in Test platform



## 4 Main Menu

### 4.1 Display current parameter

Select '0' to check current parameter in the demo. There are seven parameters displayed on NiosII command shell

| /cygdrive/e/Altera/18.0                                                                                                                               | )                                                                                                                  |                         |
|-------------------------------------------------------------------------------------------------------------------------------------------------------|--------------------------------------------------------------------------------------------------------------------|-------------------------|
| +++ Current Network<br>Window Update Gap<br>Mode<br>FPGA MAC address<br>FPGA IP<br>FPGA port number<br>Iarget IP<br>Iarget port number                | : Parameter +++<br>= 0<br>= CLIENT<br>= 0×000102030405<br>= 192.168.11.42<br>= 60000<br>= 192.168.11.25<br>= 60001 | -> Current<br>Parameter |
| TOE1GIP menu<br>[0] : Display TCPIP<br>[1] : Reset TCPIP p<br>[2] : Send Data Tes<br>[3] : Receive Data<br>[4] : Full duplex T<br>[5] : Slow Port Tes | -<br>' parameters<br>arameters<br>t (TOEIP -> Targe<br>Test (Target -> T<br>est (TOEIP <-> Ta<br>t by Ping         | t)<br>OEIP)<br>rget)    |

Figure 4-1 Display current parameter

- Window Update Gap : Threshold value to transmit window update packet. Valid value is 0x00 - 0x3F (0-63). The unit size of threshold value is 1 Kbyte. Default value is 0 (disable window update feature).
- 2) Mode : Mode of TOE1G-IP to act as server or client. To run with PC, please input '0' to initialization the IP in client mode.
- 3) FPGA MAC address : 48-bit hex value to be MAC address of FPGA. Default value is 0x000102030405.
- 4) Target IP : IP address of destination device (1 Gb Ethernet on PC) to transfer 1 Gb Ethernet data. Default value is 192.168.11.25.
- 5) FPGA IP : IP address of FPGA. Default value is 192.168.11.42. Note: This value is used to be server IP address parameter for test application on PC.
- 6) Target port number i Port number of destination device to transfer 1 Gb Ethernet data.
   Default value is 60001.
- 7) FPGA port number : Port number of FPGA. Default value is 60000. <u>Note</u>: This value is used to be server port for test application on PC.

To change some parameters, user can set by using menu [1].



### 4.2 Reset TOE1G-IP

Select '1' to reset the IP and change IP parameters. This menu is used to change IP parameters. After user selects this menu, the current parameters are displayed. User enters 'x' to use same parameters or other keys to change some parameters. There are seven parameters which can be modified by user. When user enters invalid value such as 'n', the parameter does not change. After setting parameters completely, IP is reset. More details of each parameter are described as follows.

- Window Update Gap : Threshold value to transmit window update packet. Valid value is 0x00 - 0x3F (0-63). The unit size of threshold value is 1 Kbyte. Default value is 0 (disable window update feature).
- 2) Mode : '0' to initialization the IP as client mode.
  3) FPGA MAC address : 12-digit of hex value. Add "0x" as a prefix to input as hex value.
  4) FPGA IP address : A set of four decimal digits is separated by ".". The valid range of a set of a set of four decimal digits is separated by ".". The valid range of a set of four decimal digits is separated by ".". The valid range of a set of four decimal digits is separated by ".".
- each decimal digit is 0-255.
- 5) FPGA port number : Valid range is 0-65535.
- 6) Target IP address : A set of four decimals like FPGA IP address. This value is IP address of Test PC.
- 7) Target port number : Valid range is 0-65535.

After finishing all parameter assignment, new parameters are displayed on NiosII command shell. Next, reset signal is sent to the IP to load new parameters. Finally, "IP initialization complete" is shown after IP completes initialization process, as shown in Figure 4-2.



```
/cygdrive/e/Altera/18.0
+++ Reset TOEIP +++
                                                             Current parameter
+++ Current Network <u>Parameter +++</u>
Window Update Gap
                                     Ø
Mode
FPGA MAC address
                                     CLIENT
                                     0×000102030405
FPGA IP
                                     192.168.11.42
                                                                    Input other keys (not 'x') to
FPGA port number
                                     60000
Target IP
                                     192.168.11.25
                                                                    set parameter
                                    60001
Target port number = 60001
Press 'X' to skip parameter setting[y
Input mode : [0]_Client [1] Server =>
                                                                  п
Invalid input : Parameter not change
Window Update Threshold <0-63> : n
Invalid input : Parameter not change
Input FPGA MAC address : n
                                                                        Invalid input to
                                                                        use same value
Input FIGA fine address : In-
Invalid input : Parameter not change
Input FPGA IP address : 192.168.11.43
Input FPGA port number : 50000
Input Target IP address : n
Invalid input : Parameter not change
                                                                                Input valid value to
Input Target port number : n
Invalid input : Parameter not change
                                                                                change parameter
+++ Current Network Parameter +++
Window Update Gap  = 0
Mode
                                  = CLIENT
                                 = \frac{0 \times 000102030405}{192.168.11.43}
= 50000
FPGA MAC address
                                                                    New parameter
FPGA IP
FPGA port number
                                 = 192.168.11.25
Target IP
Target port number = 60001
MARNING: Please also change IP setting and port number on Test ap
IP initialization complete
--- TOEIGIP menu ---
[0] : Display TCPIP parameters
[1] : Reset TCPIP parameters

    [2] : Send Data Test (TOEIP -> Target)
    [3] : Receive Data Test (Target -> TOEIP)
    [4] : Full duplex Test (TOEIP <-> Target)

[5] : Slow Port Test by Ping
```

Figure 4-2 Change IP parameter result



### 4.3 Send Data Test

To transfer data from FPGA to PC, select '2' to run send data test on FPGA and prepare "tcpdatatest.exe" on PC to receive data. User sets test parameters on FPGA for sending data through NiosII command shell. On PC, user sets test parameters of "tcpdatatest" through command prompt. The step to run the test is described as follows.

- 1) On NiosII command shell, input three parameters in send data test.
  - a) Input transfer size: Unit of transfer size is byte. Valid value is 1 0xFFF\_FFF. The input is decimal unit when the input is only digit number. User can add "0x" as a prefix for hexadecimal input.
  - b) Input packet size: Unit of packet size is byte. Valid value is 1 8960. The input is decimal unit when the input is only digit number. User can add "0x" as a prefix for hexadecimal input.
  - c) Input Mode: Mode of FPGA to transfer data. Set '1' to run as server mode.
- 2) When all inputs are valid, the recommended parameters to run test application on PC and "Wait Open connection ..." are displayed.
- 3) On Command prompt, user runs application by using the recommended parameters. There are six parameters for "tcpdatatest".
  - >> tcpdatatest [Mode] [Dir] [ServerIP] [ServerPort] [Bytelen] [Pattern]
  - a) Mode : Set 'c' to run Test PC as a client
  - b) Dir : Set 'r' to receive test data from FPGA
  - c) Server IP : Set the same value as IP address of FPGA
  - d) Server por t: Set the same value as port number of FPGA
  - e) Bytelen : Set the same value as "Input transfer size" of step 1a)
  - f) Pattern : '1'-enable data verification, '0'-disable data verification
- 4) After running test application, the port is created. Current transfer size is displayed on NiosII command shell and Command prompt every second. "Send data complete" is displayed on NiosII command shell after all data are sent.
- 5) FPGA closes the connection. Finally, total transfer size and performance are displayed on NiosII command shell and Command prompt.

Figure 4-3 shows the example of send data test when using non-jumbo frame size. The left window is NiosII command shell on FPGA operating as server and the right window is Command prompt on PC operating as client.

Figure 4-4 shows the example of send data test when using jumbo frame size.







When the input is invalid, "Out-of-range input"/"Invalid input" is displayed and the operation is cancelled, as shown in Figure 4-5 - Figure 4-7.

/cygdrive/e/Altera/18.0 +++ TOEIP Send Mode +++ Enter transfer size : 1 - 0xFFFFFFFF => 0x10000000 Out-of-range input Error transfer size --- TOE1GIP menu ---[0] : Display TCPIP parameters [1] : Reset TCPIP parameters [2] : Send Data Test (TOEIP -> Target) [3] : Receive Data Test (Target -> TOEIP) [4] : Full duplex Test (TOEIP <-> Target) [5] : Slow Port Test by Ping Figure 4-5 Error from invalid transfer size /cygdrive/e/Altera/18.0 +++ TOEIP Send Mode +++ Enter transfer size : 1 - ØxFFFFFFF => ØxFFFFFFFF Enter packet size : 1 - 8960 => 9000 Enter packet size Out-of-range input => 9000 Error packet size --- TOE1GIP menu ---[0] : Display TCPIP parameters [1] : Reset TCPIP parameters [2] : Send Data Test (TOEIP -> Target) [3] : Receive Data Test (Target -> TOEIP) [4] : Full duplex Test (TOEIP <-> Target) [5] : Slow Port Test by Ping Figure 4-6 Error from invalid packet size /cygdrive/e/Altera/18.0 +++ TOEIP Send Mode +++ Enter transfer size : 1 - ØxFFFFFFF => ØxFFFFFFF Enter packet size : 1 - 8960 => <u>8</u>960 Enter packet size : 1 - 8960 Input mode : [0] Client [1] Server => 2 Invalid input Error mode --- TOE1GIP menu ---[0] : Display TCPIP parameters [1] : Reset TCPIP parameters [2] : Send Data Test (TOEIP -> Target) [3] : Receive Data Test (Target -> TOEIP) [4] : Full duplex Test (TOEIP <-> Target) [5] : Slow Port Test by Ping

Figure 4-7 Error from invalid mode



## 4.4 Receive Data Test

To transfer data from PC to FPGA, select '3' to run receive data test on FPGA and prepare "tcpdatatest.exe" on PC to send data. User sets test parameters on FPGA for receiving data through NiosII command shell. On PC, user sets test parameters of "tcpdatatest" to send data through Command prompt. The step to run the test is described as follows.

- 1) On NiosII command shell, set three parameters under receive data test menu.
  - a) Input transfer size: Unit of transfer size is byte. Valid value is 1 0xFFF\_FFF. The input is decimal unit when the input is only digit number. User can add "0x" as a prefix for hexadecimal input.
  - b) Input data verification mode: '0'-disable data verification, '1'-enable data verification sent from PC.
  - c) Input Mode: Mode of FPGA to transfer data. Set '1' to run server mode.
- 2) When all inputs are valid, the recommended parameters to run test application on PC are displayed. After that, "Wait Open connection ..." is displayed.
- 3) On Command prompt, user runs application by using the recommended parameters. There are six parameters for "tcpdatatest".
  - >> tcpdatatest [Mode] [Dir] [ServerIP] [ServerPort] [Bytelen] [Pattern]
  - a) Mode : Set 'c' to run Test PC as a client
  - b) Dir : Set 't' to send test data to FPGA
  - c) Server IP : Set the same value as IP address of FPGA
  - d) Server port : Set the same value as port number of FPGA
  - e) Bytelen : Set the same value as "Input transfer size" of step 1a)
  - f) Pattern : Set the same value as "Input data verification mode" of step 1b).

Select '0' to send dummy data or '1' to send incremental data.

- 4) After running test application, the port is created. Current transfer size is displayed on NiosII command shell and Command prompt every second.
- 5) "Connection closed" and "Receive data completed" are displayed on NiosII command shell after PC completes to send all data and closes the connection. Finally, total transfer size and performance are displayed on NiosII command shell and Command prompt.



Figure 4-8 shows the example of receive data test when disable data verification mode on FPGA and send dummy data by PC. The left window is test result on NiosII command shell while the right window is test result on Command prompt.

Figure 4-9 shows the example of receive data test when enable data verification mode on FPGA and send incremental data by PC.



<sup>---</sup> TOE1GIP menu ---

Figure 4-8 Receive data test without data verification

| /cvqdrive/e/Altera/18.0                                        | Comman(                         |                                 |
|----------------------------------------------------------------|---------------------------------|---------------------------------|
| Input parameter to enable data verification                    | Call TCPdata                    | test to generate increment data |
| +++ TOEIP Receive Mode +++                                     | D:\SW>tcpdatatest c t 192       | 2.168.11.42 60000 4294967295 1  |
| Enter transfer size : 1 - 0xFFFFFFFF => 0xFFFFFFFF             |                                 |                                 |
| Enable data verification : [0] Disable [1] Enable => 1         | Start Sending with Data j       | pattern in Client mode          |
| Run test application on PC by following command                | Waiting for connection          |                                 |
| tcpdatatest c t 192.168.11.42 60000 4294967295 1               | System connected                |                                 |
| (2)                                                            | Oradian Data Olar               |                                 |
| Walt Upen connection                                           | Sending Data Size<br>113 246 MR |                                 |
| Send Ø Byte Recv 112 MByte                                     | 213.910 MB                      |                                 |
| Send Ø Byte Recv 211 MByte                                     | 319.816 MB                      |                                 |
| Send Ø Byte Recv 315 MByte                                     |                                 |                                 |
|                                                                | 4.000 GB                        | Display performance after       |
| Send Ø Byte Recv 3974 MByte                                    | 4.109 GB                        | finishing transferring all data |
| Send Ø Byte Recv 4081 MByte                                    | 4.217 GB                        | and connection is closed        |
| Send & Byte Recv 4183 Libyte                                   | Spend 39,98 Second(s) for       | e Sending 4,295 GBute(s)        |
| Connection closed                                              | Sending Data Rate: 107.43       | 3 MByte(s)/Sec                  |
| Receive data completed                                         |                                 |                                 |
| Total tx transfer size = 0 Bute                                |                                 |                                 |
| Total = O[B] , Time = 39980[ms] , Transfer speed = O[MB/s]     |                                 |                                 |
| Total rx transfer size = 4294967295 Bute                       |                                 |                                 |
| Total = 4294[MB] , Time = 39980[ms] , Transfer speed = 107[MB/ | 's]                             |                                 |
| TOEICIB (5)                                                    | -                               |                                 |
|                                                                |                                 |                                 |
| Figure 4-9 Receive data te                                     | est when enable da              | ata verification                |



Figure 4-10 shows the example of error when data verification is failed. In the example, the error is caused from mismatch verification mode value. FPGA enables data verification while "tcpdatatest" sends dummy data. The error message is displayed on NiosII command shell.



#### Figure 4-10 Receive data test when data verification is failed



## 4.5 Full duplex Test

Select '4' to run full duplex test to transfer data between FPGA and PC in both directions at the same time. User sets test parameters on FPGA through NiosII command shell and test parameters on PC through Command prompt. The step to run the test is described as follows.

- 1) On Niosll command shell, set four parameters under full duplex test menu.
  - a) Input transfer size: Unit of transfer size is byte. Valid value is 1-0xFFFF\_FFF. The input is decimal unit when the input is only digit number. User can add "0x" as a prefix for hexadecimal input. This value must be equal to total transfer size setting on test application.
  - b) Input packet size: Unit of packet size is byte. Valid value is 1 8960. The input is decimal unit when the input is only digit number. User can add "0x" as a prefix for hexadecimal input.
  - c) Input data verification mode: '0'-disable data verification, '1'-enable data verification.
  - d) Input Mode: Mode of FPGA to transfer data. Sett '1' to run as server mode.
- 2) When all inputs are valid, the recommended parameters to run test application on PC are displayed. After that, "Wait Open connection ..." is displayed.
- 3) On Command prompt, user runs application by using the recommended parameters. There are four parameters for "tcp\_client\_txrx\_40G".

>> tcp\_client\_txrx\_40G [ServerIP] [ServerPort] [ByteLen] [Verification]

- a) Server IP : Set the same value as IP address of FPGA
- b) Server port : Set the same value as port number of FPGA
- c) ByteLen : Total transfer size in byte unit.

Set the same value as "Input transfer size" of step 1a).

d) Verification : Set the same value as "Input data verification mode" of step 1b). '0'-send dummy data and disable data verification,

'1'-send incremental data and enable data verification.

- 4) After running test application, the port is created. During transferring data, current transfer size is displayed on NiosII command shell and Command prompt every second.
- 5) "Send data complete" is displayed on NiosII command shell after it finishes sending and receiving all data. After that, the connection is closed. Finally, total transfer size and performance are displayed on NiosII command shell and Command prompt.

Step 4) - 5) is repeated as forever loop until user cancels the operation by pressing "Ctrl+C" on Command prompt and pressing any key(s) on NiosII command shell.

As shown in Figure 4-11 and Figure 4-12, transfer performance when running full duplex without data verification is better than running with data verification. The left window is the test result on NiosII command shell while the right window is the test result on Command prompt.





Figure 4-12 Full duplex test with data verification



## 4.6 Slow Port Test by Ping

Select '5' to run Ping request command with PC. After selecting this menu, "Please start run Ping command on PC" message is displayed on the console. After that, user can type "ping <FPGA board IP address>" command on Command prompt to star "Ping" command test, as shown in Figure 4-14.



Figure 4-13 Result from Slow Port Test by Ping

| Command Prompt                                                                                             |                      |
|------------------------------------------------------------------------------------------------------------|----------------------|
| D:\SW>ping 192.168.11.42 -t                                                                                |                      |
| Pinging 192.168.11.42 with 32 bytes of data:<br>Reply from 192.168.11.42: bytes=32 time<1ms TTL=128        | Ping reply from FPGA |
| Reply from 192.168.11.42: bytes=32 time<1ms TTL=128<br>Reply from 192.168.11.42: bytes=32 time<1ms TTL=128 |                      |
| Reply from 192.168.11.42: bytes=32 time<1ms TTL=128<br>Reply from 192.168.11.42: bytes=32 time<1ms TTL=128 |                      |
| Reply from 192.168.11.42: bytes=32 time<1ms TTL=128<br>Reply from 192.168.11.42: bytes=32 time<1ms TTL=128 |                      |

Figure 4-14 Ping command result on PC

User can exit this menu by pressing any key(s) to the console. After that, main menu is displayed as shown in Figure 4-15.

| /cygdrive/e/Altera/18.0                                                                                                                                                                                       |                              |  |  |
|---------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|------------------------------|--|--|
| +++ Ping Command Test +++<br>Please start run Ping command on                                                                                                                                                 | PC                           |  |  |
| rress any key to exit ring test                                                                                                                                                                               | Main menu after              |  |  |
| TOE1GIP menu exit the submen                                                                                                                                                                                  |                              |  |  |
| 10] : Display ICPIP parameters<br>[1] : Reset TCPIP parameters<br>[2] : Send Data Test (TOEIP -> Ta<br>[3] : Receive Data Test (Target -<br>[4] : Full duplex Test (TOEIP <-><br>[5] : Slow Port Test by Ping | rget)<br>> TOEIP)<br>Target> |  |  |

Figure 4-15 Main menu is displayed after exit the submenu



# 5 Revision History

| Revision | Date     | Description             |
|----------|----------|-------------------------|
| 1.0      | 3-Dec-19 | Initial version release |