Research of Packet Generator Based on NetFPGA by 应福军
 
 
学校编码：10384                                                分类号      密级       





硕  士  学  位  论  文 
                                           
基于 NetFPGA 的数据包发生器的研究 




 指 导 教 师： 姚  铭  高级工程师 
   专 业 名 称：  检测技术与自动化装置 
    论文提交日期： 2 0 1 3 年   5   月    
    论文答辩时间： 2 0 1 3 年   6   月 
    学位授予日期： 2 0 1 3 年       月 
  
 
答辩委员会主席：               
























另外，该学位论文为（                            ）课题（组）
的研究成果，获得（               ）课题（组）经费或实验室的




声明人（签名）：             
























（     ）1.经厦门大学保密委员会审查核定的保密学位论文，
于   年  月  日解密，解密后适用上述授权。 







                             声明人（签名）： 









































本文实现的数据包发生系统是基于 NetFPGA 平台实现的。FPGA 技术的应用
使得平台既具有硬件的高速处理性能，又具备像软件一样可编程、重复使用的灵
活性，并且可通过上位机的应用软件实现对数据处理的控制，以满足不同的测试
























基于 NetFPGA 的数据包发生器的研究 
 II


















In recent years, with the massive popularity of the various information devices, 
network data showing a spurt of development, network security is more and more 
people pay attention to, also put forward higher requirements for the performance of 
the network products. The packet generator functions as a network system 
completeness and correctness verification has become an increasingly important part 
of people competing research focus, some traditional packet tools (such as libpcap), 
however, been unable to meet the current network applications in the high-bandwidth 
requirements. Routers, firewalls, IDS and other systems in order to provide a reliable 
packet event of a system, then study the high-traffic packet technology is extremely 
urgent and needs. 
At present, most of the data packet generator libpcap-based software, the Linux 
kernel and related network equipment technology, packet transmission process in the 
entire operating system bottlenecks, and through a series of measures to addressthese 
bottlenecks, making the network packet transmission performance has been improved 
to some extent. This method is demanding the performance of the operating system, 
and still can not achieve the requirements of line-rate contract. 
The packet event of a system implemented in this article is based on NetFPGA 
platform. FPGA technology makes the hardware platform has both high-speed 
processing performance, have like software programmable, re-use flexibility, and 
control of data processing by the host computer application software to meet different 
testing needs. The system most amount: Based on the hardware portion of the board 
and the host computer software portion of NetFPGA. 
The hardware part of the implementation is the difficulty of the system, first of 
all from the SRAM read data to be transmitted packets, and add it to the data path 













基于 NetFPGA 的数据包发生器的研究 
 IV
bucketnetwork traffic rate-limiting method, the transmission speed of each port to be 
limiting. 
The software part of the main complete the configuration, configure each port to 
be sent PCAP file, the transmission speed, the number of iterations, by reading the 
PCAP packet and downloaded to the specified address SRAM, according to the set 
speed, the use of tokenthe bucket algorithm calculated for each time interval to the 
token and the token number. Data path control is achieved by the read register. 
The design of the final test results show that the system to be completed by the 
four network port wire-speed gigabit-level contract, depending on the application 
software configurable port transmission speed, the number of iterations to meet 
different testing needs. 
 

















目  录 
第一章 绪论 .............................................. 1 
1.1  研究的背景 ................................................ 1 
1.2  国内外研究现状 ............................................ 2 
1.3  本文研究的主要内容 ........................................ 3 
第二章 NetFPGA 开发平台介绍 ............................... 5 
2.1  NetFPGA 开发平台概述 ....................................... 5 
2.2  NetFPGA 开发板介绍 ......................................... 6 
2.3  NetFPGA 软件介绍 ........................................... 8 
2.4  NetFPGA 平台搭建 ........................................... 9 
2.4.1  Java 环境安装 ......................................... 9 
2.4.2  安装 rpmforge ........................................ 10 
2.4.3  NetFPGA 基础开发包的安装 ............................. 10 
2.4.4  安装 NetFPGA 驱动 ..................................... 11 
2.4.5  NetFPGA 工具软件 ..................................... 12 
第三章 NetFPGA 开发基础 .................................. 13 
3.1  参考路由器的总体结构 ..................................... 13 
3.2  数据处理流程 ............................................. 15 
3.3  流水线设计 ............................................... 17 
3.3.1  数据流水线 ........................................... 18 
3.3.2  寄存器流水线 ......................................... 20 
3.3.3  流水线总结 ........................................... 23 
第四章 数据包发生器的设计与实现 ......................... 25 
4.1  总体设计 ................................................. 25 
4.1.1  设计目标 ............................................. 25 
4.1.2  系统结构 ............................................. 25 













基于 NetFPGA 的数据包发生器的研究 
 VI
4.2.1  寄存器的定义 ......................................... 27 
4.2.2  寄存器编址 ........................................... 27 
4.3   软件功能的实现 .......................................... 31 
4.3.1  数据包的产生 ......................................... 33 
4.3.2  限速算法 ............................................. 35 
4.4  硬件模块的实现 ........................................... 39 
4.4.1  硬件模块的整体结构 ................................... 39 
4.4.2  output_queues 输出队列模块功能的修改 ................. 41 
4.4.3  Pkt_gen_output_sel 端口选择模块的实现 ................ 42 
4.4.4  rate_limiter 限速模块功能的实现 ...................... 44 
第五章 包发生器的测试 ................................... 47 
5.1  数据包发生器的功能验证 .................................... 47 
5.2  数据包发生器的性能测试 .................................... 48 
第六章  总结与展望 ...................................... 49 
6.1 总结 ....................................................... 49 
6.2 展望 ....................................................... 49 
参考文献 ................................................ 51 
攻读硕士期间发表的论文 .................................. 54 



















CHAPTER 1 Introduction ....................................................................... 1 
1.1 research background ............................................ 1 
1.2 Overseas and Domestic Research Status ............................ 2 
1.3 Research object and main content of this paper ...................... 3 
CHAPTER2  NetFPGA development platform ................................... 5 
2.1 Overview of NetFPGA development platform ........................ 6 
2.2 NetFPGA development board introduced ........................... 8 
2.3 NetFPGA software introduction ................................... 9 
2.4 NetFPGA platform building ...................................... 9 
2.4.1 Install Java ................................................. 10 
2.4.2 Install RPMforge Yum repository ............................... 11 
2.4.3 Install NetFPGA Base Package ................................. 11 
2.4.4 Compile and Load Driver ...................................... 12 
2.4.5 NetFPGA CAD Tools ......................................... 12 
CHAPTER3 Basic knowledge of NetFPGA development .................. 14 
3.1 The overall structure of the reference router ........................ 14 
3.2 Data processing  ............................................... 16 
3.3 The pipeline design ............................................. 18 
3.3.1 Data pipeline ................................................ 19 
3.3.2 Register pipeline ............................................. 21 
3.3.3 Pipeline summary ............................................ 23 
CHAPTER4 Design and implementation of packet generator .......... 25 
4.1 The overall design ............................................. 25 
4.1.1 Design goals ................................................ 25 













基于 NetFPGA 的数据包发生器的研究 
 VIII
4.2 Register system ................................................ 27 
4.2.1 Register definition ............................................ 27 
4.2.2 Register addressing ...................................................................................... 27 
4.3 Realization of software function .................................. 31 
4.3.1 Packet generation ............................................ 33 
4.3.2 Rate limit algorithm .......................................... 35 
4.4 Hardware functional module .................................... 39 
4.4.1 The overall structure of the hardware modules ...................... 39 
4.4.2 output_queues module changes ................................. 41 
4.4.3 Pkt_gen_output_sel module Implementation ....................... 42 
4.4.3 Rate_limiter module Implementation ............................. 44 
CHAPTER5 Packet generator test ........................................................ 47 
5.1 Packet generator functional verification ........................... 47 
5.2 Packet generator performance testing ............................. 48 
CHAPTER6 Conclusion and prospect .................................................. 49 
6.1 Conclusion.................................................... 49 
6.2 Prospect ...................................................... 49 
References ................................................................................................ 51 
Main achivement of scientific research ................................................. 54 































































基于 NetFPGA 的数据包发生器的研究 
 2
1.2  国内外研究现状 
对于数据包发生系统很多从事网络研究或者网络管理人员并不陌生，如我们
大家所熟知的网络分析软件 sniffer pro，功能就非常的强大，它是基于 winpcap
编写的便携式网管和应用故障诊断分析软件，也有很多网络研究人员自己编写的











































FPGA 的高性能网络研究迎来了新的热潮，目前全球已有 170 余所高校加入到
NetFPGA 的研究中，所涉及的项目很多，如：路由器、四口网卡、交换机、防火






NetFPGA 板卡通过 PCI 接口进行信息通信。 
以 PCI 接口为分界线，在上层主机运行 centos 5.5 操作系统，通过用户
软件配置各端口要发送的数据包 PCAP 文件，发送速度，迭代次数等，并以写寄








第二章 NetFPGA 平台介绍 
本章首先从软、硬件的角度介绍了 NetFPGA 平台的组成部分，然后介绍了整
个开发平台的构建，包括搭建 NetFPGA 开发环境所需要的各种软件及硬件配置。 











































Degree papers are in the “Xiamen University Electronic Theses and Dissertations Database”. Full
texts are available in the following ways: 
1. If your library is a CALIS member libraries, please log on http://etd.calis.edu.cn/ and submit
requests online, or consult the interlibrary loan department in your library. 
2. For users of non-CALIS member libraries, please mail to etd@xmu.edu.cn for delivery details.
厦
门
大
学
博
硕
士
论
文
摘
要
库
