# Implementation of Ethernet, Aurora and their Integrated module for High Speed Serial Data Transmission using Xilinx EDK on Virtex-5 FPGA

## Chaitanya Kumar N.V.N.S<sup>1</sup>, Mir Mohammed Ali<sup>2</sup>

<sup>1, 2</sup>Mahaveer Institute of Science and Technology, Department of Electronics and Communication Engineering, Hyderabad, Telangana, India <sup>1</sup>chaitanya.nvns[at]gmail.com <sup>2</sup>mirmohammedali21[at]gmail.com

Abstract: This paper implements and establishes serial data transmission techniques like high speed Rocket IO (SERDES/MGT) and Gigabit-Ethernet, employing the architectural features of Virtex-5 FPGA. Ethernet and custom Aurora IP core are integrated to the processor in EDK (Embedded Development Kit) and the registers which are enabled in the custom Aurora IP core are accessed by Ethernet whose assigned data is sent on the Ethernet cable. By using this, the high speed serial data is transmitted at the rate of 1 Gbps for Ethernet, 3.125 Gbps for aurora respectively and 1 Gbps for integrated module of Ethernet and Aurora.

Keywords: FPGA, Integration of Ethernet and aurora, Aurora Protocol, Multi Gigabit Transceiver, EDK

#### 1. Introduction

Parallel Data transmission technology has been one of the widely used techniques for transfer of digital data, in which parallel lines are used for transmitting and receiving data which would consume more resources and time when compared to serial transmission. So, Serial transmission technology is increasingly used for the transmission of digital data due to its improved signal integrity and high speed.

Field Programmable Gate Arrays (FPGAs) are the digital ICs that are reconfigurable as desired by the designer. That is, any portion of the system can be reconfigured at any time while the rest of the design is still working. Xilinx provides a lot of tools which will help the designers to configure the FPGAs more quickly and easily. With the advancement of FPGAs a new trend of implementing the microprocessors on the FPGAs has emerged in the design community. The ML507 board is such, which supports the embedded processor PowerPC. By configuring the embedded processor it is able to achieve the same transmission and reception speeds.

This paper describes how the data is transmitted serially at higher speeds using various protocols such as Aurora, Ethernet and the integration of Ethernet and Custom Aurora IP core to the processor so that the processor can access both the modules simultaneously and interconnects both Ethernet and Aurora to access each other.

### 2. Aurora Module

When transmitting and receiving data serially at higher speeds, a protocol has to be followed. Here, Aurora protocol is being utilized which is a physical link layer protocol that uses high speed serial lanes for transmission and reception. The protocol is open and can be implemented using XILINX FPGA technology which is used in applications requiring simple, low-cost, high-rate, data channels. It is used to move data from point to point between devices using one or many transceivers. Aurora utilizes 8b/10b encoding scheme developed by IBM hence called- Aurora 8b/10b protocol where 8-bit words are translated into 10-bit symbols.



Figure 2.1 Block diagram of aurora module

The data transmission and reception in Rocket- IO uses Aurora protocol on Multi-Gigabit Transceivers (MGTs). A 32-bit data from a Virtex-5 evaluation board is transmitted to other board using Aurora protocol. Multi-Gigabit Transceivers present in the FPGA are configured using Aurora protocol and works at the clock rate of 125MHz (MGT clock). Aurora protocol converts the parallel data into serial data and vice versa (SEDERS). The data from Aurora module is transmitted serially at the rate of 3.125 Gbps through an OFC cable which is looped back as transmission medium for high speed serial data transmission. The receiver module receives data serially and converts it to parallel form.

#### 3. Ethernet Module

Ethernet is the dominant wired connectivity standard. The Xilinx Virtex-5 Ethernet media access controller (Ethernet MAC) block provides dedicated Ethernet functionality. The Ethernet MAC block is integrated into the FPGA as a hard block in Virtex-5 devices and is available in the Xilinx design environment as a library primitive, named TEMAC. The primitive contains a pair of 10/100/1000 Mbps Ethernet MACs.

Volume 5 Issue 7, July 2016 <u>www.ijsr.net</u> Licensed Under Creative Commons Attribution CC BY

#### International Journal of Science and Research (IJSR) ISSN (Online): 2319-7064 Index Copernicus Value (2013): 6.14 | Impact Factor (2015): 6.391



Figure 3.1 Virtex-5 FPGA System with the XPS LL TEMAC as the DUT

The block diagram for Ethernet applicaton requires Hard Ethernet MAC and DDR\_SDRAM along with PowerPC 440 Processor for temporary storage purpose. And other peripherals to be selected are UARTlite, Block RAM and RS232 with suitable memory storage capacity inorder to execute the Gigabit Ethernet using Xilinx EDK (Embedded Development Kit).

## 4. Integration of Ethernet and Custom Aurora IP core

The procedure of binding the Ethernet MAC and Aurora core to the Processor is known as Integration of Ethernet and Aurora. This makes the processor to control both the components simultaneously and interconnects these two peripherals with each other so that, both of them can access one another through the processor. The data present with the custom IP core can be ported onto the Ethernet MAC and is sent on the Ethernet cable to analyze the results. A simple block diagram is shown in figure 4.1 to indicate the above operation.



Figure 4.1: Block diagram of Integrated module

The process of integration is carried out in two steps. Initially Hard Ethernet MAC is configured with appropriate peripherals and then a custom IP core is created in EDK. After creating the core, it is instantiated according to the requirement and imported into EDK. After executing the task in EDK, the project is exported to the SDK (Software Development Kit) where the entire hardware portion can be operated with the help of software.



Figure 4.2 Exact block diagram of Ethernet and Aurora Integration

The precise block diagram of integration is given above which is created in the EDK. This depicts the accurate connections between all the necessary peripherals like PowerPC-Processor, DDR\_SDRAM, Hard Ethernet MAC, Custom Aurora IP core, RS232- UARTlite and Block RAM. The yellow line is the Processor Local Bus (PLB) which connects the Processor with all other peripherals.

## 5. Implementation

Initially, Aurora and Ethernet are executed individually and then both are integrated to achieve the desired output. The implementation is classified in three sections as follows:

#### 5.1 Aurora Implementation

Aurora core is generated in CORE Generator provided by Xilinx ISE. The Virtex-5 FPGA board can be configured for specific device, package and speed grade based on the requirements. The 32-bit data to be transmitted is effective if 4 lanes are used out of 16 lanes in the Aurora protocol for this configured FPGA board.

Main Parameters that are required to generate the core are Lane\_up, Channel\_up, Count signal along with Transmitting data (Tx\_D) and Receiving data (Rx\_D) signals. Once the 32-bit data is assigned for transmitting purpose, the same data flows continuously. A binary counter is designed with 32 bit width and it counts up to 32 and overflow occurs as VHDL code is written to generate the required output. Synthesis, simulation and implementation of the code are done using Xilinx ISim (ISim is an abbreviation for ISE

Volume 5 Issue 7, July 2016 <u>www.ijsr.net</u>

Licensed Under Creative Commons Attribution CC BY

#### International Journal of Science and Research (IJSR) ISSN (Online): 2319-7064 Index Copernicus Value (2013): 6.14 | Impact Factor (2015): 6.391

Simulator, an integrated HDL simulator used to simulate Xilinx FPGA and CPLD designs) and chip scope PRO analyzer. Tx\_D and Rx\_D signals are loop backed by using OFC with the help of Small Form factor Pluggable transceiver (SFP) which is a compact, hot-pluggable transceiver used for both telecommunication and data communications applications.

#### **5.2 Ethernet Implementation**

Ethernet is configured by enabling the Hard Ethernet MAC *xps\_II\_temac* as the main component to the single-processor system in the Xilinx EDK. The single-processor system contains two types of processors in which one is hardcore and the other is softcore processor. A hardcore processor type- PowerPC with clock frequency 125.0MHz should be used in synchronous with bus clock frequency of 125.0MHz for optimal communication as Processor Local Bus (PLB) is preferred over AXI bus to interconnect the embedded design efficiently. DDR\_SDRAM for temporary storage purpose along with other peripherals such as UARTlite, Block RAM and RS232 with suitable memory storage capacity are utilized in-order to execute the Gigabit Ethernet using EDK.



After succesful generation of Ethernet Hardware in EDK, the entire project is exported and launched in Software Development Kit (SDK) in order to operate the hardware with the help of programming. In SDK, the desired code is written in the main.c file of the light weight internet protocol template and the FPGA is programmed.

## **5.3 Integration of Ethernet and Custom Aurora IP core Implementation**

Initially for implementing the Integrated module, Ethernet module has to be generated as mentioned in the section 5.2. Now, as Hard Ethernet MAC is generated, custom IP core has to be created to integrate both of them to the processor. To create the custom IP core, a new peripheral is generated with XPS project. After generating the necessary files, the custom IP core named as Aurora will appear in the IP catalog under USER with an ice-cream symbol which denotes the custom core as shown in figure 5.2.

| 🗢 Xilinx Pl       | atform     | Studio -                 | E:\tes   | t\te |          |
|-------------------|------------|--------------------------|----------|------|----------|
| 🗢 File Edit       |            |                          | Hardv    |      | s        |
| 🗄 🗀 🥟 🔜           |            | 📥 🗄 🛅                    |          | F 🗄  | 26       |
| IP Catalog        |            |                          | ++ □     | s    | $\times$ |
| 12                |            |                          |          |      |          |
| Description       |            |                          |          |      |          |
| EDK Ir            |            |                          |          |      |          |
| Analog     Arithm |            |                          |          |      |          |
| 😐 🛛 Bus an        | d Bridge   |                          |          |      |          |
|                   |            | hd Interrup<br>High-Spee |          |      |          |
|                   |            | Low-Spee                 |          |      |          |
| DMA a             | nd Timer   |                          |          |      |          |
|                   |            | uration                  |          |      | _        |
| E Genera          |            |                          |          |      | 1        |
| IO Mod            |            |                          |          |      |          |
|                   |            | Communic<br>emory Con    |          |      |          |
| DE PCI            | -          | -                        | ci olioi |      | E        |
| Periph     Proces |            | roller                   |          |      | 1        |
| Utility           | sor        |                          |          |      | E        |
| Project Loc       | al PCore   | s                        |          |      | E        |
| G USER            | AURO       |                          |          |      | 1        |
|                   | > AURO     | RA                       |          |      | E        |
|                   |            |                          |          |      | E        |
|                   |            |                          |          |      | =        |
|                   |            |                          |          |      |          |
|                   |            |                          |          |      |          |
|                   |            |                          |          |      |          |
|                   |            |                          |          |      |          |
|                   |            |                          |          |      |          |
|                   |            |                          |          |      |          |
|                   |            |                          |          |      |          |
|                   |            |                          |          |      |          |
| < 100             |            |                          |          |      | >        |
| Project           |            | plications               |          | atal |          |
|                   | iauno 5 2. | VDC ID coto              | log      |      |          |
| h h               | igure 5.2: | XPS IP cata              | log      |      |          |
|                   |            |                          |          |      |          |
| 110               |            |                          |          |      |          |

And now, it is imported to the EDK after adding all the required files from the Aurora core. The imported peripheral has to be overwritten by HDL files. Once the importing part is completed, the custom aurora IP is added to the bus interface in the highlighted box of figure 5.3.



Figure 5.3: XPS wizard with integrated custom IP core

Once the custom IP has been added, connected with the PLB bus and addresses are assigned, then the entire module is arranged and interconnected as shown in the figure 4.2. Now, as the hardware is ready with both the modules integrated to the processor, the project has to be exported and launched on SDK for further execution. In SDK, the desired code is written in the main.c file of the light weight

Volume 5 Issue 7, July 2016 <u>www.ijsr.net</u> Licensed Under Creative Commons Attribution CC BY internet protocol (lwIP) template which is of standalone and POSIX\_thread of xilkernel OS to access both Ethernet and Custom Aurora IP core by the processor simultaneously and stored data in the registers of custom IP core are ported on Ethernet.

#### 6. Results

Ethernet, Aurora and Integration of Ethernet and Custom Aurora IP core are performed on the FPGA board Virtex-5 ML507 and the results are as follows:



Figure 6.1 Virtex-5 ML507 board

#### 6.1 Aurora results

The results of the Aurora module for 32 bit data of 4 lanes with Lane\_up, Channel\_up, Tx\_D, Rx\_D, count signals are analyzed in Chipscope Pro which is an analyzer software as shown below:-



| -> | Sample | /LAME_UP | /CHANNE | /count | /TX_DATA | RX_DATA | _   |
|----|--------|----------|---------|--------|----------|---------|-----|
| Т  | 0      | 1        | 1       | 644    | 642      | 623     |     |
|    | 1      | 1        | 1       | 645    | 643      | 624     |     |
|    | 2      | 1        | 1       | 646    | 644      | 625     |     |
|    | 3      | 1        | 1       | 647    | 645      | 626     |     |
|    | 4      | 1        | 1       | 648    | 646      | 627     |     |
|    | 5      | 1        | 1       | 649    | 647      | 628     | - 1 |
|    | 6      | 1        | 1       | 650    | 648      | 629     |     |
|    | 7      | 1        | 1       | 651    | 649      | 630     |     |
|    | 8      | 1        | 1       | 652    | 650      | 631     |     |
|    | 9      | 1        | 1       | 653    | 651      | 632     |     |
|    | 10     | 1        | 1       | 654    | 652      | 633     |     |
|    | 11     | 1        | 1       | 655    | 653      | 624     |     |
|    | 12     | 1        | 1       | 856    | 654      | 635     |     |
|    | 13     | 1        | 1       | 657    | 655      | 636     |     |
|    | 14     | 1        | 1       | 658    | 656      | 637     |     |
|    | 15     | 1        | 1       | 659    | 657      | 638     |     |
|    | 16     | 1        | 1       | 660    | 658      | 639     |     |
|    | 17     | 1        | 1       | 661    | 659      | 640     |     |
|    | 18     | 1        | 1       | 662    | 660      | 641     |     |
|    | 19     | 1        | 1       | 663    | 661      | 642     |     |
|    | 20     | 1        | 1       | 664    | 662      | 643     |     |
|    | 21     | 1        | 1       | 665    | 663      | 644     |     |
|    | 22     | 1        | 1       | 666    | 664      | 645     |     |
|    | 23     | 1        | 1       | 667    | 665      | 646     |     |
|    | 24     | 1        | 1       | 665    | 666      | 647     |     |
| Т  | 25     | 1        | 1       | 669    | 667      | 645     |     |
|    | 26     | 1        | 1       | 670    | 663      | 649     |     |
| _  |        |          |         |        | 112      |         | _   |

Figure 6.3 Listing Waveform

The verification of the speed which is 3.125 Gbps is done by IBERT core generator.

| Clock Settings MGT/BERT                | Bettings Sweep Test Se | tlings                       |  |
|----------------------------------------|------------------------|------------------------------|--|
| LOLING HIM IN A                        | GTX_DUAL_X0Y4_0        | GTX_DUAL_X0Y4_1              |  |
| * RX Settings                          |                        |                              |  |
| - RXOUTCLK DCM Status                  | LOCKED                 | LOCKED                       |  |
| Invert RX Polarity                     |                        |                              |  |
| RX AC Coupling                         |                        |                              |  |
| RX Termination Voltage                 | AVTTRX                 | - AVTTRX                     |  |
| - RX Equalization                      | [Large HF Boost (00)   | -   [Large HF Boost (00)   - |  |
| - DFETAP1                              | 0                      | -] [0                        |  |
| - DFETAP2                              | 0                      | - 0                          |  |
| RX Sampling Point                      |                        | UI 63 0.4171                 |  |
| · BERT Settings                        |                        |                              |  |
| TX/RX Data Pattern                     | PRBS 31-bit            | [PRBS 31-bit]                |  |
| <ul> <li>RX Bit Error Ratio</li> </ul> | 5.012E-012             | 5.012E-012                   |  |
| RX Line Rate                           | 3.125 Gbps             | 3.125 Gbps                   |  |
| RX Received Bit Count                  | 1.995E011              | 1.995E011                    |  |
| RX Bit Error Count                     | 0.000E000              | 0.000E000                    |  |
| DERT Reset                             | Reset                  | Reset                        |  |

Figure 6.4 IBERT test

#### 6.2 Ethernet results

The results of the implementation of the Gigabit Ethernet upon launching the hardware, the print results of the lwIP result of Ethernet module with the Board IP, Netmask, Gateway and link speed and the Xilkernel POSIX\_thread template can be observed in Hyper Terminal as shown in the below figures.

| D 🗳 🕸 🖁 🛍                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                       |
|-------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
|                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                 |
|                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                 |
| lwIP TCP echo server<br>TCP packets sent to port 6001 will be echoed back<br>Board IP: 192.168.1.10<br>Netmask : 255.255.255.0<br>Gateway : 192.168.1.1<br>auto-negotiated link speed: 1000<br>TCP echo server started @ port 7                                                                                                                                                                                                                                                                                                                 |
|                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                 |
| Figure 6.5: IwIP result                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                         |
| Intg_posix_thread - HyperTerminal     File Edit View Call Transfer Help                                                                                                                                                                                                                                                                                                                                                                                                                                                                         |
| 口峰 🐲 🖇 🕼                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                        |
| Xilkernel POSIX Threads Demo                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                    |
| This Kilkernel based application provides a simple example of how to create<br>multiple POSIX threads and synchronize with them when they are complete. This<br>example creates an initial master thread. The master thread creates 4 worker<br>threads that go off to compute the sum of subsets of a randomly created array<br>and return the partial sum as the result. The master thread accumulates the<br>partial sums and prints the result. This example can serve as your starting<br>point for your end application thread structure. |
| Kilkernel Demo: Master Thread Starting,<br>Kilkernel Demo: Collected result (5050) from worker: 0,<br>Kilkernel Demo: Collected result (15050) from worker: 1.<br>Kilkernel Demo: Collected result (25050) from worker: 2.<br>Kilkernel Demo: Collected result (35050) from worker: 3.<br>Kilkernel Demo: Mesult computed by worker threads = 80200.<br>Kilkernel Demo: Mesult computed by worker threads = 80200.                                                                                                                              |
| Connected 0:09:02 Auto detect 9400 8-9-1 SCROLL CAPS NLM Capture Print rote                                                                                                                                                                                                                                                                                                                                                                                                                                                                     |

The Ethernet Ping is executed in Command Prompt by entering the FPGA board IP. The number of packets sent, received and lost along with loss percentage are displayed.

| C:\WINDOWS\system32\cmd.exe                                                                                                                                                                                                                                         | - 🗆 🗙 |
|---------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|-------|
| 8eply from 192.168.1.10: bytes=32 time(ins TTL=255<br>Reply from 192.168.1.10: bytes=32 time(ins TTL=255<br>Reply from 192.168.1.10: bytes=32 time(ins TTL=255                                                                                                      |       |
| ring statistics for 192.168.1.19:<br>Packets: Sent = 100, Received = 100, Lost = 0 (0% loss),<br>Approximate round trip times in milliseconds:<br>Finimum = 0ms, Maximum = 2ms, Average = 0ms<br>Control C                                                          |       |
| C:\Documents and Settings\Administrator>ping 192.168.1.10                                                                                                                                                                                                           |       |
| Pinging 192.168.1.10 with 32 bytes of data:<br>Reply from 192.168.1.10: bytes=32 time(ins TTL=255<br>Reply from 192.168.1.10: bytes=32 time(ins TTL=255<br>Reply from 192.168.1.10: bytes=32 time(ins TTL=255<br>Reply from 192.168.1.10: bytes=32 time(ins TTL=255 |       |
| ping statistics for 192.168.1.10:<br>Pachets: Sont = 4, Received = 4, Lost = 0 (0% loss),<br>Approximate round trip times in milli-seconds:<br>Minimum = 0ms, Maximum = 0ms, Average = 0ms                                                                          | :     |
| C:\Documents and Settings\Administrator>                                                                                                                                                                                                                            | -     |
| Figure 6.7 Ethernet Ping result                                                                                                                                                                                                                                     |       |

#### 0

#### **6.3 Integrated Results**

Hard Ethernet MAC and custom Aurora IP core are integrated to the single processor on FPGA in EDK and the registers which are enabled in the custom Aurora IP core are

Volume 5 Issue 7, July 2016 www.ijsr.net Licensed Under Creative Commons Attribution CC BY

| International Journal of Science and Research (IJSR)              |
|-------------------------------------------------------------------|
| ISSN (Online): 2319-7064                                          |
| Index Copernicus Value (2013): 6.14   Impact Factor (2015): 6.391 |

accessed by Ethernet whose assigned data is sent on the Ethernet cable and the results are analyzed.

The register reg0 at an address 0xCFC00000 is assigned with data 0x12. Another register reg5 which is at an address 0xCFC00014 is configured in the code to access the data present in the reg0 with an incrimination +1 and stored as 0x13. Below are the prints of the integrated application which is executed by taking the data from IP core and porting it onto the Ethernet cable.

| lwIP TCP echo server<br>TCP packets sent to port 6001 will be echoed back<br>Board IP: 192.168.1.10<br>Netmask: 255.255.255.0<br>Gateway : 192.168.1.1<br>auto-negotiated link speed: 1000<br>TCP echo server started 0 port 7<br>Address of reg0 : CFC00000 and the data assigned : 12<br>Address of reg5 : CFC00014 and the resultant incremented data : 13<br>- |
|--------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
|                                                                                                                                                                                                                                                                                                                                                                    |

Figure 6.8: Registers output with IwIP in Hyper Terminal

The Ethernet and Aurora Integration Ping is executed in Command Prompt by entering the FPGA board IP. The number of packets sent, received and lost along with loss percentage are displayed.



Figure 6.9: Ping result of Integrated module in cmd

The combined result of both Xilkernel and Standalone OS templates which are Xilkernel\_POSIX\_thread template and lwIP templates are modified and below are the prints in Hyper Terminal.



Figure 6.10: Combined result of Xilkernel and IwIP in Hyper Terminal

The Ethernet and Aurora Integration continuous Ping is executed in Command Prompt by entering the FPGA board IP with –t.

|   | C:\WINDOWS\system32\cmd.exe - ping 192.168.1.10 -t                                                                                                                                                                   | - 🗆 🗙 |    |
|---|----------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|-------|----|
|   | Reply from 192.168.1.10: bytes=32 time<1ms ITL=255                                                                                                                                                                   | -     | Ŀ  |
|   | Ping statistics for 192.168.1.10:<br>Packets: Sent = 4, Received = 4, Lost = 0 (0% loss),<br>Approxinate round trij times in milli-seconds:<br>Minimum = 0ms, Maximum = 0ms, Average = 0ms                           |       | ł  |
|   | C:\Documents and Settings\Administrator>ping 192.168.1.10 -t                                                                                                                                                         |       | L  |
|   | Pinging 192.168.1.10 with 32 bytes of data:                                                                                                                                                                          |       | ŀ  |
|   | Reply from 192.158.1.10: bytes=32 time(ins TIL=255<br>Reply from 192.158.1.10: bytes=32 time(ins TIL=255<br>Reply from 192.158.1.10: bytes=32 time(ins TIL=255<br>Reply from 192.158.1.10: bytes=32 time(ins TIL=255 |       | 4  |
|   | Reply from 192.168.1.10: bytes=32 time<1ns TTL=255                                                                                                                                                                   |       | Þ. |
|   | Reply from 192.168.1.10: bytes=32 time<1ns ITL=255<br>Reply from 192.168.1.10: bytes=32 time<1ns ITL=255                                                                                                             |       | l  |
| ١ | Reply from 192.168.1.10: bytes=32 time<1ns ITL=255<br>Reply from 192.168.1.10: bytes=32 time=1ns ITL=255                                                                                                             |       | L  |
|   | Reply from 192.168.1.10: bytes=32 time<1ns ITL=255<br>Reply from 192.168.1.10: bytes=32 time<1ns ITL=255                                                                                                             |       | ŀ  |
| Ι | Reply from 192.168.1.10: bytes=32 time<1ns ITL=255<br>Reply from 192.168.1.10: bytes=32 time<1ns ITL=255                                                                                                             | -     |    |
|   | Reply from 192.168.1.10: bytes=32 time<1ms TTL=255                                                                                                                                                                   | · ·   | 1  |

Figure 6.11: Continuous Ping result of Integrated module in cmd

## 7. Conclusion and Future Improvements

Hard Ethernet MAC and custom Aurora IP core which are integrated to FPGA and the data given to the registers which are enabled in the custom Aurora IP core are sent on the Ethernet cable. Another module of the project involves implementation of Aurora protocol targeted to virtex-5 FX70T FPGA to achieve the above mentioned line rates. The MGT functionality is checked using IBERT tool. All the results are analyzed, Aurora on Chipscope-pro whereas, Ethernet and Integrated results on Hyper terminal. The hardware utilization of FPGA for Ethernet and Aurora Integration are analyzed with design summary in the EDK as in figure 7.1.



Figure 7.1: Device utilization

With the help of BSD programming, threads can be created to access the packets at TCP/IP level for both server and client where the sent and received packets output could be seen on wireshark. Audio and Video files can be played.

This project used independent aurora link on one GTX DUAL TILE for serial data transmission at the rate of 3.125Gbps using aurora protocol. The speed upto 17Gpbs can be achieved with some other Virtex series boards which support higher line rates using aurora protocol. Much higher data rate can be achieved if all of the 16available Rocket I/OS are used.

## References

- "High speed serial I/O made simple- A designer's guide with FPGA applications", 1<sup>st</sup> ed.,Xilinx, San Jose, CA,2005.
- [2] Volnei A. Pedroni ,"Circuit Design with VHDL", Cambridge, MA: MIT Press, 2005.
- [3] Clive 'Max' Maxfield, "The Design Warrior Guide to FPGA", MA, 2004.
- [4] "Virtex-5 special edition", Xcell Journal, Issue 59, , Xilinx, San Jose, CA, 2006.

- [5] "EDK Concepts, Tools, and Techniques user guide", Xilinx, San Jose, CA.
- [6] "Virtex-5 FPGA Embedded Tri-Mode Ethernet MAC User Guide" (v1.10), Xilinx, San Jose, CA.
- [7] "Chip-scope pro integrated bit error ratio test (IBERT) for virtex-5 FPGA GTX" (v2.01a), DS774, Xilinx, San Jose, CA, October, 2011.
- [8] "Aurora 8b/10b protocol specification", 2010 by XILINX.

http://www.XILINX.com/support/documentation/ip\_doc umentation Aurora\_8b10b\_protocol\_spec\_sp002.pdf.

## **Author Profile**



and IoTs.

: 2319

**Chaitanya Kumar N.V.N.S** completed B.Tech in Electronics and Communication Engineering from Mahaveer Institute of Science and Technology, Hyderabad in June 2016. His current area of interest is on FPGAs.

Mir Mohammed Ali completed B.Tech in Electronics and Communication Engineering from Mahaveer Institute of Science and Technology, Hyderabad in June 2016. His current area of interest is on FPGAs