# A Packet Generator on the NetFPGA Platform G. Adam Covington, Glen Gibb, John W. Lockwood, Nick McKeown Presented by César D. Guerrero cguerrer@unab.edu.co Universidad Autónoma de Bucaramanga - Motivation - Related work - Background - Approach - Methodology - Results - Conclusions - Motivation - Related work - Background - Approach - Methodology - Results - Conclusions #### **Motivation** - Software generators running on PCs cannot guarantee when packets are transmitted and don't allow full line rate testing. - Proprietary traffic generators are expensive. - Traffic generators are highly used in network measurement and testing. - Motivation - Related work - Background - Approach - Methodology - Results - Conclusions #### **Related work** - Hardware systems such as Ixia generates traffic in synthetic traces that can be rerun in the future. Ixia does not allow the replay of PCAP traces. - Software programs such as tcpreplay and TCPivo allow the replay of saved network traffic. - In *Tcpreply* the time between packets is affected by OS context switching. - TCPivo attempts to minimize these problems by employing a low latency kernel, and implementing network trace prefetching along with low latency counters. - Motivation - Related work - Background - Approach - Methodology - Results - Conclusions # Background #### NetFPGA Infrastructure - The NetFPGA is a network hardware accelerator. - The NetFPGA has three major components: - The kernel module communicates with the NetFPGA hardware. - Open source utilities used to communicate with the card. - The reference Pipeline - NetFPGA Reference Pipeline - Motivation - Related work - Background - Approach - Methodology - Results - Conclusions # **Approach** #### Packet generator architecture: - Timestamp module - Input Arbiter/Output Port Lookup - Packet Capture - Output Queues - Pkt Gen Output Select - Rate Limiter and Delay - Registers - Pkt Gen Software - Motivation - Related work - Background - Approach - Methodology - Results - Conclusions # Methodology - Experimentation infrastructure: - AMD dual core PC with a dual port e1000 PCI-express x4 NIC. - A PCAP file with 430 packets and 25383 bytes. - Tools evaluated: - Tcpreplay - NetFPGA packet generator - Experimental setup: - Experiment 1: play the PCAP trace on one port. - Experiment 2: play the PCAP trace on one ports simultaneously. - Each experiment was performed ten times and the average rate achieved was measured. - Motivation - Related work - Background - Approach - Methodology - Results - Conclusions # Results (1/2) #### Average line rate | Number of Ports | TCPreplay<br>Rate | NetFPGA<br>Rate | |-----------------|-------------------|-----------------| | One | 901.31 Mbps | 1000 Mbps | | Two | 896.23 Mbps | 1000 Mbps | #### Variation of packet arrival time # Results (2/2) #### Device utilization for the NetFPGA packet generator | | XC2VP50 | Utilization | |---------------|--------------------|-------------| | Resources | Utilization | Percentage | | Slices | 19674 out of 23616 | 83% | | 4-input LUTS | 30049 out of 47232 | 63% | | Flip Flops | 22570 out of 47232 | 47% | | Block RAMs | 140 out of 232 | 60% | | External IOBs | 356 out of 692 | 51% | - Motivation - Related work - Background - Approach - Methodology - Results - Conclusions #### **Conclusions** - Because the NetFPGA hardware runs at line rate, it can play traffic at full line rate. - The NetFPGA packet generator can reliably replay time sensitive traffic while giving users the ability to change the rate of the queues, the delay between packets, and the number of iterations that the PCAP files are cycled through. ### References - W. chang Feng, A. Goel, A. Bezzaz, W. chi Feng, and J. Walpole. Tcpivo: A high-performance packet replay engine. In Proceedings of the ACM SIGCOMM workshop on Models, methods, pages 57–64, 2003. - G. A. Covington, G. Gibb, J. Naous, J. Lockwood, and N. McKeown. Methodology to contribute netfpga modules. In International Conference on Microelectronic Systems Education (submitted to), 2009. - G. Gibb, J. W. Lockwood, J. Naous, P. Hartke, and N. McKeown. Netfpga: An open platform for teaching how to build gigabit-rate network switches and routers. In IEEE Transactions on Education, August 2008. - J. W. Lockwood, N. McKeown, G. Watson, G. Gibb, P. Hartke, J. Naous, R. Raghuraman, and J. Luo. Netfpga an open platform for gigabitrate network switching and routing. In International Conference on Microelectronic Systems Education, 2007. - G. Watson, N. MxKeown, and M. Casado. Netfpga a tool for network research and education. In 2nd Workshop on Architecture Research using FPGA Platforms (WARFP), Febuary 2006.