基于fpga的ipv6数据包的拆装实现

基于fpga的ipv6数据包的拆装实现

ID:24498769

大小:50.00 KB

页数:4页

时间:2018-11-14

基于fpga的ipv6数据包的拆装实现_第1页
基于fpga的ipv6数据包的拆装实现_第2页
基于fpga的ipv6数据包的拆装实现_第3页
基于fpga的ipv6数据包的拆装实现_第4页
资源描述:

《基于fpga的ipv6数据包的拆装实现》由会员上传分享,免费在线阅读,更多相关内容在工程资料-天天文库

1、基于FPGA的IPV6数据包的拆装实现

2、第1摘 要:介绍了一种运用FPGA将IPV6数据包的包头和数据部分分离并重新封装的方法。利用该方法,可以使IPV6数据包的拆装处理速度达到2Gbit/s以上。  关键词:FPGAIPV6数据包拆装FIFO  笔者在参与国家“863”重大专题项目“高速密码芯片及验证平台系统”的过程中,遇到了将IPV6数据包的包头和数据部分拆开,然后把数据部分送密码芯片进行加/解密处理,最后再将处理后的数据部分与包头重新封装为数据包的课题。以往对IP包进行拆装多利用软件实现,但本项目涉及到配合高速密码芯片(处理速度在2Gbit/s以上)工作的问题,显然利用软件实现

3、IP包的拆装在速度上达不到要求。为此,笔者运用FPGA(型号为Xilinx公司的XC2VP20—FF896CGB0345)来实现IPV6数据包的拆装。该FPGA内部逻辑框图如图1所示。500)this.style.ouseg(this)">图1FPGA内部逻辑框图  其工作流程为:2.5GHz的标准IPV6数据包串行差分信号通过ROCKETIO高速通道后转换为16位125MHz并行信号,再经信号转换模块进一步转换为66位62.5MHz并行信号后进入FIFO1缓存,然后对其输出数据进行判断,若是报头则送入FIFO3缓存,若是数据部分则送入FIFO2缓存,最后将FIFO2数据送往密码芯片

4、进行处理;经密码芯片处理的数据首先放入FIFO4进行缓存,然后控制FIFO3和FIFO4将一个数据包的头和数据写入FIFO5中,重新封装成一个完整的数据包;重新封装的IPV6数据包经过信号转换模块变为16位125MHz的并行信号,并通过ROCKETIO高速通道转换为2.5GHz高速串行差分信号送出。  可以看出,经过以上流程,实现了一个数据包的拆分和重新封装。1IPV6数据包的拆分  用FPGA实现IPV6数据包的拆分,主要是通过控制几个FIFO的数据输入输出来实现的。FPGA内部的拆分单元电路的物理连接如图2所示,其中FIFO1的作用是缓存IPV6数据包,FIFO2的作用是缓存IP

5、V6数据包的数据部分,FIFO3的作用是缓存IPV6数据包的包头。500)this.style.ouseg(this)">图2拆分单元电路物理连接图  图中的三个FIFO都是由Xilinx公司的开发工具ISE6.1自带的CoreIP生成的。其中FIFO1和FIFO3是同步FIFO,工作时钟为频率62.5MHz,输入输出数据宽度都是66bit;FIFO2是异步FIFO,输入时钟频率为62.5MHz,输出时钟频率为50MHz(密码芯片的工作时钟频率为50MHz),输入输出数据宽度都是64bit。  FIFO1的输入数据为IPV6数据包,格式如表1所示。可以看出,该数据是以并行的66bit

6、信号传输的,即每一时钟周期并行传送66bit数据。其中每个周期的高两位(即65位和64位)为数据包的头尾标志,这是IPV6路由器内部根据实际处理需要加上的,“10”表示一个完整数据包的第一周期,“11”表示数据包的中间内容,“01”表示一个完整数据包的最后一个周期。因为IPV6数据包的包头是固定长度的,为40字节(等于5×64bit),故数据的前五个周期为IPV6数据包的包头,包头后面跟的就是数据包的数据部分。表1FIFO1输入端IPV6数据包格式6564 63010 IPV6数据包包头第一个64bit11 IPV6数据包包头第二个64bit11 IPV6数据包包头第三个64bit1

7、1 IPV6数据包包头第四个64bit11 IPV6数据包包头最后一个64bit11 IPV6数据包数据部分第一个64bit11 IPV6数据包数据部分中间的若干个64bit01 IPV6数据包数据部分最后一个64bit  下面讨论IPV6数据包的包头和数据部分的拆分过程。  首先判断FIFO1输入端数据的头尾标志DATA(65~64)与FIFO1的满标志FULL1,如果DATA(65~64)=“10”且FULL1=“0”,即判断到一个完整数据包的开始且FIFO1未满,则使FIFO1的写使能PTY1=“0”,即FIFO1非空时,令FIFO1的读使能信号RD_EN1有效,将FIFO1中

8、的数据读出,直到EMPTY1=“1”,即FIFO1空为止。对读出的数据设定一计数器COUNTER1进行计数,当DOUT1不为0即FIFO1输出端有信号时开始计数。当0

当前文档最多预览五页,下载文档查看全文

此文档下载收益归作者所有

当前文档最多预览五页,下载文档查看全文
温馨提示:
1. 部分包含数学公式或PPT动画的文件,查看预览时可能会显示错乱或异常,文件下载后无此问题,请放心下载。
2. 本文档由用户上传,版权归属用户,天天文库负责整理代发布。如果您对本文档版权有争议请及时联系客服。
3. 下载前请仔细阅读文档内容,确认文档内容符合您的需求后进行下载,若出现内容与标题不符可向本站投诉处理。
4. 下载文档时可能由于网络波动等原因无法下载或下载错误,付费完成后未能成功下载的用户请联系客服处理。