基于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~千兆以太网传输实验

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

  1. 基于 FPGA 的以太网回环测试verilog实现UDP协议

    基于 FPGA 的以太网回环测试verilog实现UDP协议 verilog实现UDP协议: 该 设计使用 UDP 协议,首先通过串口助手接收 PC 发送的 UDP 数据包,然后提取其中的数据部分并使 ...

  2. 基于FPGA的以太网开发

      基于FPGA的以太网开发,在调试过的FPGA玩家开来,其实算不上很难的技术!但是如果只是菜鸟级别的选手,没有调试过的话,就有些头疼了!早在自己在实习的时候,就接触到XAUI(万兆以太网口)接口,但 ...

  3. 基于FPGA的以太网控制器(MAC)设计(中)

    今天给大侠带来基于FPGA的以太网控制器(MAC)设计,由于篇幅较长,分三篇.今天带来第二篇,中篇,以太网控制器(MAC)程序的实现.话不多说,上货. 导读 当前,互联网已经极大地改变了我们的生产和生 ...

  4. 基于FPGA的以太网控制器(MAC)设计(下)

    今天给大侠带来基于FPGA的以太网控制器(MAC)设计,由于篇幅较长,分三篇.今天带来第三篇,下篇,程序的仿真与测试和总结.话不多说,上货. 导读 当前,互联网已经极大地改变了我们的生产和生活.与之相 ...

  5. 从入门到入土:基于C语言采用UDP协议实现通信功能的程序

    此博客仅用于记录个人学习进度,学识浅薄,若有错误观点欢迎评论区指出.欢迎各位前来交流.(部分材料来源网络,若有侵权,立即删除) 本人博客所有文章纯属学习之用,不涉及商业利益.不合适引用,自当删除! 若 ...

  6. Java基于socket服务实现UDP协议的方法

    转载自 Java基于socket服务实现UDP协议的方法 这篇文章主要介绍了Java基于socket服务实现UDP协议的方法,通过两个简单实例分析了java通过socket实现UDP发送与接收的技巧, ...

  7. 从入门到入土:基于C语言采用UDP协议实现远程控制|详细说明|利用流套接字实现一个简单的远程控制系统|代码展示

    此博客仅用于记录个人学习进度,学识浅薄,若有错误观点欢迎评论区指出.欢迎各位前来交流.(部分材料来源网络,若有侵权,立即删除) 本人博客所有文章纯属学习之用,不涉及商业利益.不合适引用,自当删除! 若 ...

  8. 基于FPGA的SSI接口协议实现

    基于FPGA的SSI接口协议实现 SSI 是一种主机和从机点对点的通信接口,其中从机可以是具有 SSI 协议的各种传感器,例如磁致伸缩位移传感器.编码器等. SSI协议采用主机主动式读取方式,从机根据 ...

  9. 基于FPGA的FOC电流采样Bug调试记录

    #基于FPGA的FOC电流采样Bug调试记录 博主在调试FOC闭环控制中遇到了一个bug,冥思苦想两三天,最终一步步地调试时序,最终找到了bug,在调试过程中学会了debug的思想,也明白了调试过程中 ...

最新文章

  1. cordova 环境配制和创建插件
  2. MongoDB 搭建副本集
  3. 下列有关python语言的说法正确的是-关于 Python 语言的注释,以下选项中描述正确的是( )...
  4. cocos2dx游戏开发必备工具之PhysicsEditor【ZT】
  5. as3 访问远程计算机,Flash AS3中数据发送与接收
  6. python的request请求401_Python requests HTTP验证登录(解决401错误)
  7. linux树莓派网易云音乐,基于树莓派的红外遥控版网易云音乐播放器
  8. java注解中可使用对象_Java注解(二):实战 - 直接使用对象列表生成报表...
  9. 4国语言软件下载网站源码
  10. 开发环境与工具部署服务_开发与部署之间的区别
  11. 详解Vue八大生命周期钩子函数
  12. 插件properties_PageHelper分页插件的原理是什么
  13. Airplace平台
  14. jprofiler_监控远程linux服务器的JVM进程(转 非常棒)
  15. HTTP代理,正向反向,代理的作用
  16. 新手平面设计师如何在网上接单赚钱?
  17. 【精华】安卓开发学习路线规划
  18. [透视变换]象棋棋盘矫正Python&OpenCV
  19. 使用AVProVideo的一点小坑
  20. squid+icap测试配置

热门文章

  1. 软考中级软件设计师--1.计算机系统知识
  2. win7 系统盘瘦身
  3. 工商管理专业知识与实务(初级)【9】
  4. Java-实现动态数组(ArrayList<Integer>集合)
  5. 腰 相关 (come from hoopchina。。thanks)
  6. 3dmax顶点动画导入unity_3DMAX点缓存的动画怎么导入unity呀?
  7. 人工智能微信小程序人脸识别之人脸属性检测(附源码)
  8. 中南大学电磁场理论matlab,电磁场 点电荷 电场线 电势 MATLAB 仿真 中南大学
  9. Crackme007
  10. ologit模型与logit_Logit模型和Logistic模型有什么区别?