前言:
上节课实现了将PHY输出的双沿数据经过IDDR原语变成单沿数据,本节课要将此单沿数进行缓冲和校验。
文章目录
一、本节内容介绍:
本项目使用 PC 机将图像数据信息通过千兆以太网发送给 FPGA,FPGA 接收后需要对 CRC 校验和过滤无效帧传递给下一级模块。其中:数据传输使用UDP协议
1.udp包结构
我们使用 udp 协议传输图像数据,那么每一包数据开始都会有帧头、EII 格式等 50 个字节,然后是有效数据,最后会有四个数据校验位(CRC),图像信息存储在数据中。
即:CRC校验范围:EII 格式-1PFG(8-1073 byte)
2.数据过滤与校验模块设计与分析
RX_BUFFER的读写标志:
rx_en、rx_data为写标志和写数据
rx_sta_buffer开始读时,rx_buffer也开始读,读够一包数据后拉低读使能。
RX_STABUFFER的读写标志:
crc校验完成后会有一个pkg_end标志,作为写使能,写数据就是pkg_status[15:0]。
因为RX_STABUFFER的fifo位宽为16,所以当该fifo不为空时则已经完了一帧数据pkg_status的存储,以此作为读fifo的标志。
3.crc校验相关知识(手算、移位寄存器)
1.循环冗余码校验(Cyclical Redundancy Check),简称 CRC。是数据通信领域中最常用的一种差错校验码(注意:只能进行验证,不能进行纠错)。其特征是:信息字段和校验字段的长度可以任意选定。
2.在通信领域中数据的传输过程会出现丢失、错位等错误,如果说接收端没有任何校验那么就不知道接收到的数是否正确,所以为了保证数据正确性,我们可以使用 CRC 进行判断数据是否正确。如果不正确可以重新发送数据。
3.那么在我们千兆实