二、fpga对接收到的iddr输出的单沿数据进行包过滤和crc校验

本文详述了FPGA如何对接收到的IDDR数据进行UDP包的CRC校验和过滤。介绍了UDP包结构,CRC校验原理及硬件实现步骤,包括CRC计算的移位寄存器方法,并提供了功能模块划分示意图和波形设计。
摘要由CSDN通过智能技术生成

前言:
上节课实现了将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.那么在我们千兆实

  • 8
    点赞
  • 10
    收藏
    觉得还不错? 一键收藏
  • 0
    评论
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值