## Gigabit Ethernet Module AN8211 User Manual





Version Record

| Version | Date     | Release By  | Description   |
|---------|----------|-------------|---------------|
| Rev 1.0 | 2015-9-5 | Rachel Zhou | First Release |
|         |          |             |               |

# Part 1: Gigabit Ethernet Module General Description

ALINX Gigabit Ethernet Module AN8211, use RTL8211EG GPHY chip of Realtek, supports 10/100/1000 Mbps Network transmission rate. The module reserves a 40-pin female header that to connect FPGA development kit, a Gigabit Ethernet port is used to connect a computer's network card or other network device (such as a router).



Figure 1-1: AN8211 module product photo (Front side)





#### 1.1 AN8211 Gigabit Ethernet Module Detail Parameter

Gigabit Ethernet module detail parameter listed in below:

- > AN8211 Module Dimension: Detailed as Figure 1-3
- > 10/10 10/100/1000 Mbps adaptive
- Support GMII/RGMII/MII/RMII communication interface
- > Network port supports MDI/MDX adaptive, Master/Slave adaptive
- > Support MDIO bus for GPHY register management
- Power supply and power consumption: single power supply 5V, power consumption is about 0.5 watts;

## 1.2 AN8211 Gigabit Ethernet Module Parameter Description



Figure 1-3: AN8211 Gigabit Ethernet Module Dimensions

#### Part 2: Gigabit Ethernet Module Hardware Design

After the RTL8211EG is powered up, it detects the level status of some specific IOs to determine its working mode. On the AN8211 module, a pull-up resistor or pull-down resistor has been added to the configuration pin of the RTL8211EG chip to allow the GPHY chip to be in normal operation mode after power-on. Table 2-1 describes the default settings of the AN8211 Ethernet module GPHY chip RTL8211EG after power-on.

| Configuration Pin | Descripton                              | Default Vaule           |
|-------------------|-----------------------------------------|-------------------------|
| PHYAD[2:0]        | PHY address of<br>MDIO/MDC mode         | PHY Address is 001      |
| SELRGV            | 3.3V,2.5V,1.5/1.8V<br>voltage selection | 3.3V                    |
| AN[1:0]           | Auto-negotiation<br>configuration       | (10/100/1000M) Adaptive |
| RX Delay          | RX clock 2ns delay                      | Delay                   |
| TX Delay          | TX clock 2ns delay                      | Delay                   |
| MODE              | RGMII or GMII Selction                  | GMII                    |

Table 2-1: Default setting of PHY Chip RTL8211EG after Power-on

Transmitting through the GMII bus, the transmission clock E\_GTXC is provided by the FPGA, the frequency is 125Mhz, the data is TXD0~TXD7, the data valid signal is TXEN, the TXC signal is not used. The receive clock E\_RXC is provided by the PHY chip, the data is RXD0~RXD7, the data valid signal is RXDV, and the data is sampled on the rising edge of the clock.

In the 100M MII communication mode, when transmitting data, then transmitting clock is a 25Mhz TXT signal, the 25Mhz TXC clock is the PHY input to the FPGA, the data is TXD0~TXD3, the data valid signal is TXEN, and the GTXC signal is not used; When receiving data, the receiving clock is a 25Mhz RXC signal, the data is RXD0~RXD3, and the data valid signal is RXDV.

The following figure 2-1 shows the hardware design of the Gigabit Ethernet module AN8211:

ALINX



Figure 2-1: Hardware Design of the Gigabit Ethernet Module AN8211

| Pin | Pin Name | Description           |
|-----|----------|-----------------------|
| 1   | GND      | Ground                |
| 2   | +5V      | 5V Power Supply       |
| 3   | E_RXDV   | Receive data valid    |
|     | _        | signal                |
| 4   | E_RXD0   | Bit0 of receive data  |
| 5   | E_RXD1   | Bit1 of receive data  |
| 6   | E_RXD2   | Bit2 of receive data  |
| 7   | E_RXD3   | Bit3 of receive data  |
| 8   | E_RXC    | GMII Receive Clock    |
| 9   | E_RXD4   | Bit4 of receive data  |
| 10  | E_RXD5   | Bit5 of receive data  |
| 11  | E_RXD6   | Bit6 of receive data  |
| 12  | E_RXD7   | Bit7 of receive data  |
| 13  | E_RXER   | Receive data error    |
| 14  | E_COL    | Collision signal      |
| 15  | E_CRS    | Carrier Sense signal  |
| 16  | E_GCLK   | GMII transmit clock   |
| 17  | E_TXEN   | Transmit enalbe       |
|     |          | signal                |
| 18  | E_TXD0   | Bit0 of transmit data |
| 19  | E_RESET  | Reset signal          |
| 20  | E_TXD1   | Bit1 of transmit data |
| 21  | E_TXD2   | Bit2 of transmit data |

| 40-ı  | oin     | assignm  | ent of  | Gigabit | Ethernet | Module | AN8211 |
|-------|---------|----------|---------|---------|----------|--------|--------|
| · ~ r | · · · · | assignin | 0110 01 | ergaste | Ethernot | module |        |

| 22 | E_TXD3 | Bit3 of transmit data       |  |  |  |  |
|----|--------|-----------------------------|--|--|--|--|
| 23 | E_TXC  | MII tramsimit clock         |  |  |  |  |
| 24 | E_TXD4 | bit4 of transmit data       |  |  |  |  |
| 25 | E_TXD5 | Bit5 of transmit data       |  |  |  |  |
| 26 | E_TXD6 | Bit6 of transmit data       |  |  |  |  |
| 27 | E_TXD7 | Bit7 of transmit data       |  |  |  |  |
| 28 | E_TXER | Transmitting Erro<br>Signal |  |  |  |  |
| 29 | E_MDC  | MDIO management<br>clock    |  |  |  |  |
| 30 | E_MDIO | MDIO management<br>data     |  |  |  |  |
| 31 | -      | NC                          |  |  |  |  |
| 32 | -      | NC                          |  |  |  |  |
| 33 | -      | NC                          |  |  |  |  |
| 34 | -      | NC                          |  |  |  |  |
| 35 | -      | NC                          |  |  |  |  |
| 36 | -      | NC                          |  |  |  |  |
| 37 | -      | NC                          |  |  |  |  |
| 38 | -      | NC                          |  |  |  |  |
| 39 | -      | NC                          |  |  |  |  |
| 40 | -      | NC                          |  |  |  |  |

For detailed pin description and GMII/MII communication timing, please refer to the RTL8211 chip datasheet.

## **Part 3: Hardware Connection**

The hardware connection between the AN8211 module and FPGA development are easy. The 40-pin female headers of module plug into the expansion board of FPGA development board. Make sure to align the Pin1 of the module and FPGA board. The figure 4-1 is hardware connection of ALINX Series FPGA development kit AX301 and the AN8211 module.



Figure 3-1: Hardware connection to AX301 FPGA Board and AN8211

After the board is powered on, use the Gigabit Ethernet cable (Category 5 or Category 6 cable) to connect the network port of the Ethernet module to the network port of the computer. After the connection is completed, you can start the experiment of Ethernet.

### Part 4: Gigabit Ethernet program

We provide 2 Ethernet test program, one is a Gigabit Ethernet testing program for Gigabit data communication between the Ethernet module and the computer. The other is the 100M Ethernet test program for 100M data communication between the Ethernet module and the computer. Let me introduce you to the Gigabit Ethernet test program

The communication protocol of the test program uses the Ethernet UDP communication protocol. The FPGA communicates with the Gigabit PHY chip RTL8211EG of the Ethernet module through the GMII bus, and the Gigabit PHY chip exchanges data through the network cable and the PC.

ALINX

Figure 4-1 detailed ethernet data communication diagram.

Figure 4-1 Ethernet Data Communication Diagram

#### 4.1 AN8211 Gigabit UDP Protocol

ALINX



UDP is the abbreviation of User Datagram Protocol. UDP only provides a basic, low-latency communication called a datagram. The so-called datagram is a kind of self-addressing information, data pack from the sender to the receiver. UDP protocol is often used for image transmission, network monitoring data exchange and other data transmission speed requirements are relatively high

 Header format of the UDP protocol The UDP header consists of 4 domains, each occupying 2 bytes, as follows figure 4-2:



Figure 4-2: Header format of the UDP protocol

- 1) UPD Source Port
- 2) Destination Port
- 3) Length of Diagram
- 4) Checksum

The UDP protocol uses its port number to reserve its own data transmission channel for different applications. The data sender sends the UDP datagram through the source port, and the data receiver receives the data through the destination port.

The length of the datagram refers to the total number of bytes including the header and data parts. Because the length of the header is fixed, this field is primarily used to calculate the variable length portion of the data (also known as the data load). The maximum length of a datagram varies depending on the operating environment. In theory, the maximum length of a datagram containing a header is 65535 bytes. However, some practical applications tend to limit the size of the datagram, sometimes it will be reduced to 8192 bytes.

The UDP protocol uses the checksum in the header to ensure data security. The check value is first calculated by the data sender through a special algorithm, and after being passed to the receiver, it needs to be recalculated. If a datagram is falsified by a third party during transmission or damaged due to line noise, etc., the calculated values of the sender and the receiver will not match, and the UDP protocol can detect an error. Although UDP provides error detection, when an error is detected, the error is corrected, simply throwing away the corrupted message segment or providing a warning message to the application.

#### 2. IP Datagram Header

ALINX

Since the UDP protocol packet is one of the IP packets, let us introduce the data format of the IP packet. The following figure shows the header format of the IP packet. The first 20 bytes of the packet header are fixed and the latter is variable.



Figure 4-3: Header format of the IP Packet

#### Revision:

4 digits, which refers to the version of the IP protocol. The current IP protocol version number is 4 (ie IPv4).

#### Head length:

4 bits, the maximum value that can be represented is 15 units (one unit is 4 bytes), so the maximum length of the IP header is 60 bytes.

#### Differentiated services:

8 bits, used to get better service, is called service type in the old standard, but it has never been used. In 1998, this field was renamed to differentiate service. This field is only works when using DiffServ. This field is not used under normal circumstances.

#### Total length:

ALINX

16 bits, the length of the sum of the header and the data, in bytes, so the maximum length of the datagram is 65535 bytes. The total length must not exceed the maximum transmission unit MTU

#### Logo:

16 bits, it is a counter used to generate the identity of the datagram Flag:

It is 3 digits, and currently only the first two meaningful MFs; the lowest digit of the flag field is MF (More Fragment)

MF=1 means "there are still fragments".

MF=0 means the last slice DF, One bit in the middle of the flag field is DF (Don't Fragment), which is allowed only when DF=0

#### Slice offset:

12 bits, which refers to the relative position of a slice in the original packet after fragmentation. The slice offset is offset by 8 bytes.

#### Time to live:

8 bits, recorded as TTL (Time To Live). The maximum number of routers that the datagram can pass through the network. The TTL field is initially set by the sender with an 8 bit field. The recommended initial value is specified by the assigned number RFC. The current value is 64. The TTL is always set to a maximum of 255 when sending an ICMP echo reply. protocol:

8 bits, indicating which protocol is used for the data carried by this datagram, so that the IP layer of the destination host hands over the data part to which process, 1 is ICMP protocol, 2 is IGMP protocol, and 6 is TCP protocol. 17 is expressed as UDP protocol



Figure 4-4: Protocol

#### Header Checksum

16bits, only check the header of the datagram without checking the data portion. Here, the CRC check code is not used and a simple calculation method is used.

Source address and destination address:

Each takes 4 bytes and records the source and destination addresses respectively.

#### 4.2 Programming

Gigabit Ethernet GMII communication is a verilog code design based on the UDP communication protocol. The program function is to send UDP packets to the PC or network device through the network port by default after the board is powered on. The content of the data packet is

"Hello Alinx AX301" . When the FPGA detects the UDP packet sent by the network port, it stores the received data packet in the RAM, and then continuously sends the received data packet back to the computer or other network device through the network port.

The entire ethernet\_test project consists of a top-level module ethernet\_test.v, UDP test program udp.v and three sub-modules: UDP send module (ipsend.v), UDP receive module (iprecieve.v) and CRC check module (crc.v)

| Quartus II 64-Bit - E:/Project/AH8211/verilog/AH301/ether                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                      | net |
|--------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|-----|
| ile Edit View Project Assignments Processing Tools Window Help 💎                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                               |     |
| 🗅 😂 🖬 🎒 🎒 👗 🖻 🛍 🗠 🕫 🗍 ethernet_test                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                            |     |
| roject Navigator 🗗 🗙                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                           | 1   |
| Entity                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                         | [   |
| Cyclone IV E: EP4CE6F17C8  Cyclone IV E: EP4CE6F |     |
| ipsend:ipsend_inst                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                             |     |

Figure 4-5: ethernet\_test project

#### 1. UDP Send Module (ipsend.v) Description

The UDP sending module combines the data in the RAM into a UDP IP packet format and sends it to the PHY chip through the GMII bus. The PHY chip then sends the data to the network port of the development board.

The IP packet header shall be sent before the IP packet is sent. The IP header consists of an 8-byte preamble, a destination MAC Address, a source MAC address, and a two-byte IP packet type. The preamble consists of 7 0x55 and 1 0xD5 bytes, indicating the beginning of an IP data packet transmission; the destination MAC Address is the MAC address of the object to which the data is to be sent. If the network port of the development board is connected to your PC, The value of the destination MAC Address is the MAC address is the MAC address is the MAC address is the MAC address of your PC. The source MAC Address is the MAC address is the MAC address is the MAC address is the MAC address of your PC. The source MAC Address is the MAC address is the MAC address of your PC. The source MAC Address is the MAC address is the MAC address of your PC. The source MAC Address is the MAC address is the MAC address of your PC. The source MAC Address is the MAC address local to the development board. The IP packet type value is 0x0800.

After sending the IP header, the IP datagram header is sent. The format of the IP datagram header has been discussed earlier. Then the

data in the RAM is sent, and finally the 4-byte CRC32 value is sent.

#### 2. UDP Receive Module (iprecieve.v) Description

ALINX

The UDP data receiver is the same as the UDP data transmission. First, it is judged whether the preamble is received. If the preamble is received, it starts to receive the target MAC Address and judges whether it is consistent with the MAC address of the development board. If it is consistent, the remaining header and data are received. When receiving data, the received 8-bit data is converted into a 32-bit data width and written into the RAM.

#### 3. CRC Check Module (crc.v) Description

The CRC check of an IP packet is calculated at the destination MAC Address and is calculated until the last data of a packet. The verilog algorithm and polynomial of Ethernet's CRC32 can be generated directly at the following website in Figure4-6: <u>http://www.easics.com/webtools/crctool</u>

| http://www.easics.com/webtools/crctool |                 |                 |                 |                    |                  |                 |                    |                 |                    |                 |                 |                     |                 |                 |                 |                   |                 |  |   |
|----------------------------------------|-----------------|-----------------|-----------------|--------------------|------------------|-----------------|--------------------|-----------------|--------------------|-----------------|-----------------|---------------------|-----------------|-----------------|-----------------|-------------------|-----------------|--|---|
|                                        | CI              | RC              | Тс              | ool                |                  |                 |                    |                 |                    |                 |                 |                     |                 |                 |                 |                   |                 |  |   |
| Company                                | Hor             | <u>ne</u> »     | Webt            | ools >             | » <u>CR</u>      | C Too           | <u>)</u>           |                 |                    |                 |                 |                     |                 |                 |                 |                   |                 |  | 6 |
| Webtools                               | Pol             | ynor            | nial :          | 1 + x <sup>1</sup> | + χ <sup>2</sup> | + ×4 ·          | + x <sup>5</sup> + | ×7 +            | x <sup>8</sup> + x | 10 + )          | (11 + )         | ( <sup>12</sup> + ) | (16 + )         | (22 + )         | (23 + )         | x <sup>26</sup> + | χ <sup>32</sup> |  |   |
| CRC Tool                               | Pol             | ynor            | nial e          | ditor              | :                |                 |                    |                 |                    |                 |                 |                     |                 |                 |                 |                   |                 |  |   |
| Freesics                               | 1               | x <sup>1</sup>  | x²              | ×3                 | × <sup>4</sup>   | × <sup>5</sup>  | х <sup>6</sup>     | ×7              | x <sup>8</sup>     | x <sup>9</sup>  | x <sup>10</sup> | x <sup>11</sup>     | x <sup>12</sup> | x <sup>13</sup> | x <sup>14</sup> | × <sup>15</sup>   | x <sup>16</sup> |  |   |
| News                                   |                 |                 | ~               |                    | ~                | ~               |                    | ~               | ~                  |                 | ~               | •                   | ~               |                 |                 |                   | •               |  |   |
| Documents                              | x <sup>17</sup> | x <sup>18</sup> | x <sup>19</sup> | x <sup>20</sup>    | x <sup>21</sup>  | x <sup>22</sup> | x <sup>23</sup>    | x <sup>24</sup> | x <sup>25</sup>    | × <sup>26</sup> | x <sup>27</sup> | x <sup>28</sup>     | x <sup>29</sup> | × <sup>30</sup> | х <sup>31</sup> | x <sup>32</sup>   | x <sup>33</sup> |  |   |
| Jobs                                   |                 |                 |                 |                    |                  | •               | ~                  |                 |                    | ~               |                 |                     |                 |                 |                 | ~                 |                 |  |   |
| Contact                                | × <sup>34</sup> | x <sup>35</sup> | × <sup>36</sup> | x <sup>37</sup>    | × <sup>38</sup>  | x <sup>39</sup> | × <sup>40</sup>    | × <sup>41</sup> | x <sup>42</sup>    | x <sup>43</sup> | x <sup>44</sup> | x <sup>45</sup>     | x <sup>46</sup> | ×47             | × <sup>48</sup> | × <sup>49</sup>   | × <sup>50</sup> |  |   |
|                                        |                 |                 |                 |                    |                  |                 |                    |                 |                    |                 |                 |                     |                 |                 |                 |                   |                 |  | 5 |
|                                        | x <sup>51</sup> | x <sup>52</sup> | × <sup>53</sup> | × <sup>54</sup>    | × <sup>55</sup>  | × <sup>56</sup> | × <sup>57</sup>    | × <sup>58</sup> | × <sup>59</sup>    | х <sup>60</sup> | x <sup>61</sup> | x <sup>62</sup>     | x <sup>63</sup> | x <sup>64</sup> | x <sup>65</sup> | × <sup>66</sup>   | × <sup>67</sup> |  |   |
|                                        |                 |                 |                 |                    |                  |                 |                    |                 |                    |                 |                 |                     |                 |                 |                 |                   |                 |  |   |
|                                        | An              | nul             | Sat             | tol                |                  | 0022            | Eth                | ornot           | ( 6.61             | Б               |                 | -1                  |                 |                 |                 | Cla               | or              |  |   |
|                                        | Ah              | piyi            | 361             | 10                 | 1 Cr             | (052            | - בנו              | emer            | I AAI              | _0              | -               |                     |                 |                 |                 | CIE               | Bal             |  |   |
|                                        | Dat             | a bu            | s wic           | lth: 8             |                  |                 |                    |                 |                    |                 |                 |                     |                 |                 |                 |                   |                 |  |   |
|                                        |                 | 1024            |                 | 512                | _2               | 56              | _12                | 8               | 64                 | _32             |                 | 16                  | 8               | _4              |                 | 2                 | _1              |  |   |
|                                        |                 |                 |                 | 1                  |                  |                 |                    | L               |                    |                 |                 | [                   | ~               |                 |                 |                   |                 |  |   |
|                                        | Ap              | ply             |                 |                    |                  |                 |                    |                 | (                  | Clear           | -               |                     |                 |                 |                 |                   |                 |  |   |
|                                        | Ge              | nerat           | e VH            | DL I               | oit ve           | ctor t          | ype: [             | std_l           | ogic_              | vecto           | or 💌            |                     |                 |                 |                 |                   |                 |  |   |
|                                        | Ge              | nerat           | e Ver           | ilog               | ]                |                 |                    |                 |                    |                 |                 |                     |                 |                 |                 |                   |                 |  |   |

Figure 4-6: Website

#### 4. Udp test module (udp.v) Description

The Udp test program just instantiates the three submodules written

earlier: UDP send module, UDP receive module, CRC32 check module

#### 5. TOP module (Ethernet\_test.v) Description

ALINX

One function of the TOP program is to instantiate the udp module. In addition, a dual-port RAM is called. The data width of the read/write is 32 bits, and the address depth of the RAM is 512. The dual-port RAM is used to store the data received by the Ethernet. When the program does not receive the Ethernet packet, the program sends the character of "HELLO ALINX AX301" stored in the RAM all the way. If an Ethernet packet is received, the received Ethernet packet will overwrite the data in the RAM, and the program will continuously send the received packet to the network port.

## Part 5: 100M Ethernet Program

The design principle of the 100M Ethernet program and the Gigabit Ethernet program is the same. The main difference is that the data bus is changed from GMII to MII, and the frequency of the clock is changed from 125Mhz to 25Mhz. Both the transmit clock and receive clock are provided by the GPHY to the FPGA. The Figure 5-1is a schematic diagram of 100 Mbps Ethernet data communication:



Figure 5-1: The Design Principle of the 100M Ethernet program Since the data width of the MII bus is 4 bits, when data is transmitted and data is received, one byte needs to have 2 clocks to transmit or receive. The lower four bits of the data are first and the upper four bits are followed. The function of each module of the 100M Ethernet program is the same as that of the Gigabit Ethernet test program, which is not introduced here.

## **Part 6: Ethernet Experiment**

- 1. Prepare the Experiment
- Step 1:

ALINX

First, connect the network port of the development board and the network port of the PC with Cat5 + or Cat6 network cable, Then power on the development board. The LED of the Ethernet module network port will light up, indicating that the network is already connected to the link. You can confirm whether the direct link between the computer and Ethernet is Gigabit or 100 megabits. Click on the local connection in Figure 6-1 to view the status.



Figure 6-1: Local Connection

**Note:** If the network port is not connected to the link, it may be that the default program of the FPGA pull GPHY Reset pin low, so that GPHY is in the Reset state. As long as the FPGA downloads the Ethernet test program, the network port can be connected.

• Step 2:

If the computer's system is Window XP, you need to modify the target mac address in the UDP sending module (ipsend.v) to the mac address of the PC NIC, and recompile it after modification. If you don't know the mac address of your PC's NIC, look it up in the DOS command window with the ipconfig –all command.

| 46<br>47<br>48<br>49 | <pre>preamble[4]&lt;=8'h55;<br/>preamble[5]&lt;=8'h55;<br/>preamble[6]&lt;=8'h55;<br/>preamble[7]&lt;=8'hD5;</pre> | XP操作系统修改成您自己PC的<br>MAC Address |
|----------------------|--------------------------------------------------------------------------------------------------------------------|--------------------------------|
| 50                   | <pre>mac_addr[0]&lt;=8'h28;</pre>                                                                                  | //目的MAC地址 28-D2-44-DC-6E-FE    |
| 51                   | <pre>mac_addr[1]&lt;=8'hD2;</pre>                                                                                  | 204 - 44                       |
| 52                   | <pre>mac addr[2]&lt;=8'h44;</pre>                                                                                  |                                |
| 53                   | <pre>mac addr[3]&lt;=8'hDC;</pre>                                                                                  |                                |
| 54                   | <pre>mac addr[4]&lt;=8'h6E;</pre>                                                                                  |                                |
| 55                   | <pre>mac addr[5]&lt;=8'hFE;</pre>                                                                                  |                                |
| 56                   | <pre>mac addr[6]&lt;=8'h00;</pre>                                                                                  | //源MAC地址 00-0A-35-01-FE-C0     |
| 57                   | <pre>mac_addr[7]&lt;=8'h0A;</pre>                                                                                  |                                |

Figure 6-2: Modify the mac address in ipsend.v

If the computer is not the Window XP operating system, you do not need to modify the target mac address in the UDP sending module (ipsend.v), and the destination address is all FF broadcast packets.

• Step 3

Modify the IP address of the PC to 192.168.0.3P (detailed refer to Figure 6-3). The IP address of the PC needs to be the same as the setting in the sending module (ipsend.v), otherwise the network debugging assistant will not receive the UDP packets sent by the development board.

| 774                             |                                    |
|---------------------------------|------------------------------------|
| U果网络支持此功能,则可U<br>Sa需要从网络系统管理员处约 | 以获取自动指派的 IP 设置。否则,<br>获得适当的 IP 设置。 |
|                                 |                                    |
| ◎ 自动获得 IP 地址(Q)                 |                                    |
| ◎ 使用下面的 IP 地址 (S)               | ):                                 |
| IP 地址(L):                       | 192 .168 . 0 . 3                   |
| 子网掩码(U):                        | 255 .255 .255 . 0                  |
| 默认网关 四):                        | 192 .168 . 0 . 1                   |
| ◎ 自动获得 DNS 服务器地                 | 班 (8)                              |
| ◉ 使用下面的 DNS 服务器                 | \$地址 (E):                          |
| 首选 DNS 服务器(P):                  |                                    |
| 备用 DNS 服务器(A):                  |                                    |
| □ 退中时必证迟罢 (r)                   |                                    |

Figure 6-3: Modify the IP address of the PC

• Step 4

Open the DOS command window with administrator privileges and bind the IP address and MAC address of the development board. When the network debugging assistant sends a network packet with IP address 192.168.0.2, the target MAC address is automatically the MAC address of the development board.

Run the command: ARP -s 192.168.0.2 00-0a-35-01-fe-c0

| C:\VINDOVS\system                             | 2\cmd. exe                          |                                  | - 🗆 🗙    |
|-----------------------------------------------|-------------------------------------|----------------------------------|----------|
| Microsoft Windows XP<br><c> 版权所有 1985-200</c> | [版本 5.1.2600]<br>11 Microsoft Corp. |                                  | <b>^</b> |
| C:\Documents and Sett                         | ings Administrator ARP              | -s 192.168.0.2 00-0a-35-01-fe-c0 |          |
| C:\Documents and Sett                         | ings Administrator>arp              | -a                               |          |
| Interface: 0.0.0.0                            | - 0x3                               |                                  |          |
| Internet Address                              | Physical Address                    | Туре                             |          |
| 192.168.0.2                                   | 00-0a-35-01-fe-c0                   | static                           |          |

Figure 6-4: Run the Command

After binding, we can use the arp –a command to view the results of

the binding on the computer.

• Step 5

ALINX

This step is optional. Wireshark is installed to facilitate the debugging of the user's network communication. Wireshark, the network capture tool in the TOOL directory of the installation CD, can be used to view the detailed data sent and received by the PC network port during the experiment.

📶 wireshark-win32-1.4.9中文版

Figure 6-5: Wireshark Tool Installation Software

- 2. Ethernet Communication Test
- Step 1

According to the speed of the network port link, it is judged whether to download the Gigabit test program or the 100M test program.

• Step 2

Open the network debugging assistant we provided and set the parameters as follows, then press the connect button (the local IP address here is the computer's IP Address, the local port needs to be the same as in the FPGA program, it is 8080)

|               | 网络调试助手               | (C■精装版        | ¥3. 8)   |          | ×    |
|---------------|----------------------|---------------|----------|----------|------|
| 网络设置          | 网络数据接收               |               |          |          | ]    |
| (1) 执议类刑      |                      |               |          |          |      |
| UDP 🗾         |                      |               |          |          |      |
| (2) 本地IP地址    |                      |               |          |          |      |
| 192.168.0.3   |                      |               |          |          |      |
| (3)本地端口号      |                      |               |          |          |      |
| ,             |                      |               |          |          |      |
|               | 1                    |               |          |          |      |
| 接收区设置         |                      |               |          |          |      |
| □ 接收转回义件…     |                      |               |          |          |      |
| ▶ 日初换行还不      |                      |               |          |          |      |
| □ 十八进制亚小      |                      |               |          |          |      |
| □ 暂停接收亚小      |                      |               |          |          |      |
| 保存数据 清除显示     |                      |               |          |          |      |
| 发送区设置         |                      |               |          |          |      |
| □ 启用文件数据源     |                      |               |          |          |      |
| □ 自动发送附加位     |                      |               |          |          |      |
| □ 发送完自动清空     |                      |               |          |          |      |
| □ 按十六进制发送     |                      |               |          |          |      |
| □ 数据流循环发送     |                      |               |          |          |      |
| 发送间隔 1000 臺秒  | http://www.emsoft_en | 99:1086560053 | 67537465 | 58476    |      |
| 文件载入 清除输入     |                      |               |          |          | 发送   |
| 」<br>₫<br>就绪! |                      | 发送:           | 124      | 接收: 7344 | 复位计数 |

Figure 6-6: Network Debugging Assistant

At this time, the network data receiving window will display the Ethernet packet "Hello ALINX AX301" sent by the FPGA to the computer. We will set the IP address of the target host to be the same as the IP address in the FPGA program. The destination port number also needs to be the same as the FPGA program (8080).





Figure 6-7: Network Debugging Assistant

**Note:** The transmission of Ethernet data frames has a packet length requirement of 46 to 1500 bytes. Therefore, when sending Ethernet packets, the length of the data frame should not be too short, otherwise the computer data packet will be sent and the FPGA will not receive the data packet.

• Step 4

This step is optional for the user. If you want to view more information about the packet transmission, you can use the network capture tool Wireshark to view the network data received and sent by the computer's network card, and open the installed wireshark packet capture tool., click on the menu capture package -> network interface.





Figure 6-8: Wireshark Software

In the pop-up capture interface window, select your computer's Gigabit NIC and press the start button to start capturing packets.

| 详细信息                         | IP地址                               | 包          | 包数/秒 | 停止(I) |       |      |
|------------------------------|------------------------------------|------------|------|-------|-------|------|
| 🔊 Microsoft                  | fe80::6863:65df:f632:e07           | 3 57       | 3    | 开始(S) | 选项(0) | 详情(D |
| Microsoft                    | fe80::4c60:cc68:4e8f:9e76          | 5 0        | 0    | 开始(S) | 选项(0) | 详情(D |
| 🔊 Realtek PCIe GBE Family Co | ontroller fe80::ed74:7524:9e20:5f5 | <b>d</b> 0 | 0    | 开始(S) | 选项(0) | 详情(D |

Figure 6-9: Pop-up Capture Interface Window

In the wireshark capture window, you can see the development board (192.168.0.2) to the computer network port (192.168.0.2) sent data packets.

| Captu Captu                                                                            | uring from Intel(R) PRO/1000 PL Metwork Connecti                                       | on – Tireshark    |              |          |  |  |  |  |
|----------------------------------------------------------------------------------------|----------------------------------------------------------------------------------------|-------------------|--------------|----------|--|--|--|--|
| 文件 (2)                                                                                 | ) 编辑(EC) 视图(V) 定位(G) 抓包(C) 分析(A) 统计(S)                                                 | 电信(Y) 工具(T) 帮助    | (H)          |          |  |  |  |  |
|                                                                                        | ( <b>≥ ≥</b> ≥   = <b>3</b> × <b>2</b> =   < + +                                       | 🥹 장 🕹 🗐 🖬         | 🔍 Q 🔍 🖪      | 🏽 🗹 👧 🐝  |  |  |  |  |
| 过滤:                                                                                    | ,<br>,                                                                                 | ▼ 表达式             | 清除 应用        |          |  |  |  |  |
| No.                                                                                    | Time                                                                                   | Source            | Destination  | Protocol |  |  |  |  |
| 82                                                                                     | 2 16. 852821                                                                           | 192.168.0.2       | 192.168.0.3  | UDP      |  |  |  |  |
| 83                                                                                     | 3 16. 966601                                                                           | 2c:53:4a:01:a1:0c | Broadcast    | ARP      |  |  |  |  |
| 84                                                                                     | 4 17. 389703                                                                           | 192.168.0.2       | 192.168.0.3  | UDP      |  |  |  |  |
| 85                                                                                     | 5 17.926592                                                                            | 192.168.0.2       | 192.168.0.3  | UDP      |  |  |  |  |
| 86                                                                                     | 6 18.111461                                                                            | 2c:53:4a:01:a1:0c | Broadcast    | ARP      |  |  |  |  |
| 87                                                                                     | 7 18.162264                                                                            | 2c:53:4a:01:a1:0c | Broadcast    | ARP      |  |  |  |  |
| 41 00                                                                                  | 0.10.004007                                                                            | 100 100 0 0       | 004 100 10 1 | UDD      |  |  |  |  |
|                                                                                        |                                                                                        |                   |              |          |  |  |  |  |
| ⊞ Frame 77: 62 bytes on wire (496 bits), 62 bytes captured (496 bits)                  |                                                                                        |                   |              |          |  |  |  |  |
| Ethernet II, Src: Xilinx_01:fe:c0 (00:0a:35:01:fe:c0), Dst: Broadcast (ff:ff:ff:ff:ff) |                                                                                        |                   |              |          |  |  |  |  |
| ■ Internet Protocol, Src: 192.168.0.2 (192.168.0.2), Dst: 192.168.0.3 (192.168.0.3)    |                                                                                        |                   |              |          |  |  |  |  |
| 🗄 User Datagram Protocol, Src Port: http-alt (8080), Dst Port: http-alt (8080)         |                                                                                        |                   |              |          |  |  |  |  |
| 🗄 Data                                                                                 | i (20 bytes)                                                                           |                   |              |          |  |  |  |  |
|                                                                                        |                                                                                        |                   |              |          |  |  |  |  |
|                                                                                        |                                                                                        |                   |              |          |  |  |  |  |
| 0000 :                                                                                 | ff ff ff ff ff ff 00 0a 35 01 fe c0 08 00                                              | 45 00 5.          | E.           |          |  |  |  |  |
| 0010                                                                                   | 00 30 00 09 40 00 80 11 79 5e c0 a8 00 02                                              | c0 a8 .0@ y       |              |          |  |  |  |  |
| 0020 0                                                                                 | UU US II 90 II 90 UU IC UU UU 48 45 4C 4C<br>41 4c 49 4e 58 20 41 58 33 30 31 20 0c 0d | 4I ZU             | HELLU        |          |  |  |  |  |
| 0030 .                                                                                 | TI TO TO TO DO ZO TI DO DO DO DI ZO VA VU                                              | ALIMA AA O        |              |          |  |  |  |  |
|                                                                                        |                                                                                        |                   |              |          |  |  |  |  |

Figure 6-10: The wireshark Capture Window

After actual testing, the data speed of UDP communication can reach more than 900Mbps, which is very suitable for high-speed data transmission occasions, such as video image transmission and high-speed data acquisition.