基于FPGA的以太网UDP协议实现过程记录

基于FPGA的以太网的 UDP协议的学习笔记

一、完整的以太网数据部分包括以下几部分:
  1. 前导码
  2. 帧起始界定符
  3. 以太网帧头
  4. IP首部
  5. UDP首部
  6. UDP数据(有效数据)
  7. CRC校验字节
二、针对每一部分的格式如下:

MAC数据包格式:

MAC 数据包 IEEE 对以太网上传输的数据包格式也进行了统一规定,

在这里插入图片描述

在这里插入图片描述

在这里插入图片描述

  • 前导码:7 个字节的 0x55,用示波器看起来是一段脉冲信号。
  • 帧起始界定符:1字节的0xD5。
  • 目的MAC地址:数据的最终去向的地址,俗称网卡的物理地址,出厂时已经设置完毕,共6字节。
  • 源MAC地址:数据的来源设备的物理地址,占用6个字节。
  • 数据包类型:反映以太网每一包数据的格式,是属于OSI层级中的链路层,
    写入0800 则是 IP协议
    写入0806 则是 ARP协议
    写入0835 则是 RARP协议

note:以太网首部包括 目的MAC地址 + 源MAC地址 +数据包类型

IP首部

在这里插入图片描述

在这里插入图片描述

首部长度(4 bit):最小值为5,最大值为15,以4Byte为单位,故长度可以是 20Byte ~ 60Byte。

总长度(16 bit):该字段定义整个IP数据报的字节长度,包括协议头部和数据。其最大值为65535字节。以太网协议对能够封装在一个帧中的数据有最小值和最大值的限制(46~1500个字节)。

UDP首部

在这里插入图片描述

UDP校验和

在这里插入图片描述

三、 注意事项:
  1. IP数据包的长度最少是46字节,包括20个字节的IP和8字节的UDP的首部。
  2. CRC校验是对IP首部UDP首部有效数据校验
  3. UDP模块的执行过程是,将有效数据提取出来后,在重新打包发出去,即完成了解码和编码的过程。
  4. UDP的长度是指包括有效数据部分和整个UDP首部8字节的总长度。
四、实现 MAC 和 PHY 的通信

RGMII接口的定义:

在这里插入图片描述

UDP模块的引脚:

在这里插入图片描述

在这里插入图片描述

在这里插入图片描述

在这里插入图片描述

当前是完成了UDP的两个模块的接收和发送程序,还需要完成接口转换模块的程序阅读和校验模块的阅读。但是此刻已经完成了核心代码的阅读了。

  • UDP_TX
  • UDP_RX
  • CRC32_D8
  • GMII_TO_RGMII

根据当前的阅读情况,可以进行以下两个任务的完成,分别是完成拓展任务,即将GMII的输出改为RMII的输出。为了方便任务的开展,可以按照以下步骤完成:

  1. 对现在的代码进行仿真分析,确定各个部分的仿真结果和自己的分析过程,没有出入。
  2. 按照教程,真实的下载到板子上,进行实际的测试,保障功能的正常。
  3. 完成拓展任务,即修改通信接口由GMII为RGMII类型。
  4. 根据项目的数据采集部分程序,修改UDP模块,实现启动采集和数据的转发。
五、 参考资料
  1. 踏浪Pro《FPGA Verilog开发实战指南——基于Xilinx Spartan6》进阶提高篇2021.7.10
  2. 黑金的 AX7101~千兆以太网传输实验
  • 3
    点赞
  • 51
    收藏
    觉得还不错? 一键收藏
  • 7
    评论
评论 7
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值