FPGA纯verilog实现UDP协议栈,GMII接口驱动88E1111,提供工程源码和技术支持

这篇具有很好参考价值的文章主要介绍了FPGA纯verilog实现UDP协议栈,GMII接口驱动88E1111,提供工程源码和技术支持。希望对大家有所帮助。如果存在错误或未考虑完全的地方,请大家不吝赐教,您也可以点击"举报违法"按钮提交疑问。

1、前言

目前网上的fpga实现udp基本生态如下:
1:verilog编写的udp收发器,但中间的FIFO或者RAM等调用了IP,或者不带ping功能,这样的代码功能正常也能用,但不带ping功能基本就是废物,在实际项目中不会用这样的代码,试想,多机互联,出现了问题,你的网卡都不带ping功能,连基本的问题排查机制都不具备,这样的代码谁敢用?
2:带ping功能的udp收发器,代码优秀也好用,但基本不开源,不会提供源码给你,这样的代码也有不足,那就是出了问题不知道怎么排查,毕竟你没有源码,无可奈何;
3:使用了Xilinx的Tri Mode Ethernet MAC三速网IP实现,这样的代码也很优秀,但还是那个问题,没有源码,且三速网IP需要licence,三速网IP实现了rgmii到gmii再到axis的转换;
4:使用FPGA的GTX资源利用SFP光口实现UDP,通信,这种方案不需要外接网络变压器即可完成;
5:真正意义上的verilog实现的UDP协议栈,真正意义上的verilog实现意思是UDP协议栈全部代码均使用verilog代码,不适用任何IP核,包括FIFO、RAM等,这样的UDP协议栈移植性很强,这样的协议栈在市面上也很少,几乎很难得到,而很设计就是这样的协议栈,呵呵。。。

本设计使用纯verilog实现的UDP协议栈实现UDP回环通信测试,FPGA驱动88E1111 网络变压器实现数据收发,UDP协议栈与PHY的交互接口为GMII,速率最高为1G,UDP协议栈的用户接口为AXIS,使得用户无需关心复杂的UDP协议而只需关心简单的用户接口时序即可操作UDP收发,将AXIS数据接口做简单的回环处理,即可完成自发自收的功能,并在电脑端使用网络调试助手进行UDP收发验证;

本设计经过反复大量测试稳定可靠,可在项目中直接移植使用,工程代码可综合编译上板调试,可直接项目移植,适用于在校学生、研究生项目开发,也适用于在职工程师做项目开发,可应用于医疗、军工等行业的数字通信领域;
提供完整的、跑通的工程源码和技术支持;
工程源码和技术支持的获取方式放在了文章末尾,请耐心看到最后;

免责声明

本工程及其源码即有自己写的一部分,也有网络公开渠道获取的一部分(包括CSDN、Xilinx官网、Altera官网等等),若大佬们觉得有所冒犯,请私信批评教育;基于此,本工程及其源码仅限于读者或粉丝个人学习和研究,禁止用于商业用途,若由于读者或粉丝自身原因用于商业用途所导致的法律问题,与本博客及博主无关,请谨慎使用。。。

2、我这里已有的UDP方案

目前我这里有大量UDP协议的工程源码,包括UDP数据回环,视频传输,AD采集传输等,也有TCP协议的工程,对网络通信有需求的兄弟可以去看看:直接点击前往

3、该UDP协议栈性能

1:纯verilog实现,没有用到任何一个IP核;
2:移植性天花板,该协议栈可在Xilinx、Altera等各大FPGA型号之间任意移植,因为是没有任何IP,源语也有参数可选择;
3:适应性强,目前已在88E1111上成功测试,也可以用GT资源的SFP接口实现UDP协议的以太网通信;
4:时序收敛很到位;
5:动态ARP功能;
6:不带ping功能;
7:与PHY的接口为GMII,市面上的RGMII接口代码很多,GMII相对较少;
8:最高支持1G速率;

4、详细设计方案

详细设计方案如下:
FPGA纯verilog实现UDP协议栈,GMII接口驱动88E1111,提供工程源码和技术支持,菜鸟FPGA以太网专题,fpga开发,udp,网络协议,88E1111,GMII

网络PHY

FPGA驱动88E1111 网络变压器实现数据收发,UDP协议栈与PHY的交互接口为GMII,速率最高为1G,UDP数据经过网络PHY实现和电脑网络调试助手的数据收发;

GMII AXIS接口模块

GMII AXIS接口模块的代码架构如下:
FPGA纯verilog实现UDP协议栈,GMII接口驱动88E1111,提供工程源码和技术支持,菜鸟FPGA以太网专题,fpga开发,udp,网络协议,88E1111,GMII
该模块用于对接1G/2.5G Ethernet PCS/PMA or SGMII IP核的GMII接口,是UDP协议栈的对外接口,采用纯verilog代码实现,包括AXIS FIFO;

AXIS FIFO

由于使用到了AXIS 数据流,必然需要AXIS FIFO作为哥哥模块的桥接,一般的设计直接调用AXIS FIFO IP核,但本设计为了通用性和移植性,采用纯verilog代码实现,代码中的位置如下:
FPGA纯verilog实现UDP协议栈,GMII接口驱动88E1111,提供工程源码和技术支持,菜鸟FPGA以太网专题,fpga开发,udp,网络协议,88E1111,GMII

UDP协议栈

UDP协议栈采用纯verilog代码实现,代码架构如下:
FPGA纯verilog实现UDP协议栈,GMII接口驱动88E1111,提供工程源码和技术支持,菜鸟FPGA以太网专题,fpga开发,udp,网络协议,88E1111,GMII
协议栈由ARP、IP层、UDP层、AXIS FIFO几个模块组成,全部使用纯verilog代码实现,ARP层实现动态ARP功能,IP层、UDP层实现MAC数据帧的IP层和UDP层的数据解包和组包,这是UDP协议的核心操作,其本身并不复杂,就是根据UDP协议进行对应的数据解析和数据组包即可,使用几个状态机的事儿,很假单,这里就不细说了,AXIS FIFO的作用是将复杂的UDP协议封装为AXIS数据流格式作为用户接口供开发者使用,开发者甚至都不需要去理解里面的协议,就当它是一个AXIS的FIFO用就行了;

5、vivado工程详解

开发板:Xilinx–>xc7k325tffg900-2;
开发环境:Vivado2019.1;
网络PHY:88E1111 ;
输入\输出:UDP 网络通信;
测试项:数据收发;
工程代码架构如下:
FPGA纯verilog实现UDP协议栈,GMII接口驱动88E1111,提供工程源码和技术支持,菜鸟FPGA以太网专题,fpga开发,udp,网络协议,88E1111,GMII
FPGA资源消耗和功耗预估如下;
FPGA纯verilog实现UDP协议栈,GMII接口驱动88E1111,提供工程源码和技术支持,菜鸟FPGA以太网专题,fpga开发,udp,网络协议,88E1111,GMII

6、上板调试验证并演示

准备工作

开发板连接如下,然后上电下载bit:
FPGA纯verilog实现UDP协议栈,GMII接口驱动88E1111,提供工程源码和技术支持,菜鸟FPGA以太网专题,fpga开发,udp,网络协议,88E1111,GMII
首先设置电脑端IP如下:
FPGA纯verilog实现UDP协议栈,GMII接口驱动88E1111,提供工程源码和技术支持,菜鸟FPGA以太网专题,fpga开发,udp,网络协议,88E1111,GMII
开发板的IP地址在代码中的设置如下,在fpga_core.v里,可以自由修改:
FPGA纯verilog实现UDP协议栈,GMII接口驱动88E1111,提供工程源码和技术支持,菜鸟FPGA以太网专题,fpga开发,udp,网络协议,88E1111,GMII

查看ARP

打开cmd,输入 arp -a查看电脑的arp缓存表,如下:
FPGA纯verilog实现UDP协议栈,GMII接口驱动88E1111,提供工程源码和技术支持,菜鸟FPGA以太网专题,fpga开发,udp,网络协议,88E1111,GMII

UDP数据回环测试

打开网络调试助手并配置,如下:
FPGA纯verilog实现UDP协议栈,GMII接口驱动88E1111,提供工程源码和技术支持,菜鸟FPGA以太网专题,fpga开发,udp,网络协议,88E1111,GMII
单次发送数据测试结果如下:
FPGA纯verilog实现UDP协议栈,GMII接口驱动88E1111,提供工程源码和技术支持,菜鸟FPGA以太网专题,fpga开发,udp,网络协议,88E1111,GMII
循环发送数据测试结果如下,1秒时间间隔循环:
FPGA纯verilog实现UDP协议栈,GMII接口驱动88E1111,提供工程源码和技术支持,菜鸟FPGA以太网专题,fpga开发,udp,网络协议,88E1111,GMII

7、福利:工程代码的获取

福利:工程代码的获取
代码太大,无法邮箱发送,以某度网盘链接方式发送,
资料获取方式:私,或者文章末尾的V名片。
网盘资料如下:
FPGA纯verilog实现UDP协议栈,GMII接口驱动88E1111,提供工程源码和技术支持,菜鸟FPGA以太网专题,fpga开发,udp,网络协议,88E1111,GMII
FPGA纯verilog实现UDP协议栈,GMII接口驱动88E1111,提供工程源码和技术支持,菜鸟FPGA以太网专题,fpga开发,udp,网络协议,88E1111,GMII
FPGA纯verilog实现UDP协议栈,GMII接口驱动88E1111,提供工程源码和技术支持,菜鸟FPGA以太网专题,fpga开发,udp,网络协议,88E1111,GMII文章来源地址https://www.toymoban.com/news/detail-545576.html

到了这里,关于FPGA纯verilog实现UDP协议栈,GMII接口驱动88E1111,提供工程源码和技术支持的文章就介绍完了。如果您还想了解更多内容,请在右上角搜索TOY模板网以前的文章或继续浏览下面的相关文章,希望大家以后多多支持TOY模板网!

本文来自互联网用户投稿,该文观点仅代表作者本人,不代表本站立场。本站仅提供信息存储空间服务,不拥有所有权,不承担相关法律责任。如若转载,请注明出处: 如若内容造成侵权/违法违规/事实不符,请点击违法举报进行投诉反馈,一经查实,立即删除!

领支付宝红包 赞助服务器费用

相关文章

  • FPGA纯verilog实现UDP协议栈 AXIS用户接口,可替代Tri Mode Ethernet MAC,提供三套工程源码和技术支持

    FPGA高端项目:纯verilog的 UDP 协议栈,提供11套工程源码和技术支持 目前网上的fpga实现udp基本生态如下: 1:verilog编写的udp收发器,但中间的FIFO或者RAM等调用了IP,或者不带ping功能,这样的代码功能正常也能用,但不带ping功能基本就是废物,在实际项目中不会用这样的代码,

    2024年02月13日
    浏览(50)
  • 千兆以太网芯片88E1111 RGMII模式的FPGA驱动实现

    千兆以太网芯片88E1111 RGMII模式的FPGA驱动实现 在网络应用领域,千兆以太网已经成为主流,而88E1111作为一款先进的千兆以太网芯片,其驱动实现对于网络设备的性能和稳定性有着至关重要的影响。本文将介绍在RGMII模式下,如何实现88E1111芯片在FPGA上的驱动。 一、准备工作

    2024年01月22日
    浏览(60)
  • FPGA实现 RDMA NIC 10G UDP协议栈网卡,纯verilog代码编写,提供工程源码和技术支持

    FPGA实现 NIC 10G 网卡,纯verilog代码编写,提供3套工程源码和技术支持 网络接口控制器(NIC)是计算机与网络进行交互的网关。NIC构成了软件协议栈和网络之间的桥梁,该桥梁的功能定义了网络接口。网络接口的功能以及这些功能的实现都在迅速发展。这些变化是由提高线速和

    2024年02月10日
    浏览(80)
  • FPGA实现 RDMA NIC 100G UDP协议栈网卡,UltraScale+ 100G Ethernet Subsystem驱动,提供工程源码和技术支持

    FPGA实现 NIC 100G 网卡,GTY+100G Ethernet Subsystem架构,纯verilog代码实现,提供2套工程源码和技术支持 网络接口控制器(NIC)是计算机与网络进行交互的网关。NIC构成了软件协议栈和网络之间的桥梁,该桥梁的功能定义了网络接口。网络接口的功能以及这些功能的实现都在迅速发

    2024年02月08日
    浏览(49)
  • FPGA高端项目:纯verilog的 UDP 协议栈,提供11套工程源码和技术支持

    FPGA高端项目:纯verilog的 UDP 协议栈,提供11套工程源码和技术支持 目前网上的fpga实现udp基本生态如下: 1:verilog编写的udp收发器,但中间的FIFO或者RAM等调用了IP,或者不带ping功能,这样的代码功能正常也能用,但不带ping功能基本就是废物,在实际项目中不会用这样的代码,

    2024年02月03日
    浏览(56)
  • FPGA纯vhdl实现XGMII接口10G万兆网UDP协议 配合10G Ethernet PCS/PMA使用 提供工程源码和技术支持

    目前网上的fpga实现udp基本生态如下: 1:verilog编写的udp收发器,但不带ping功能,这样的代码功能正常也能用,但不带ping功能基本就是废物,在实际项目中不会用这样的代码,试想,多机互联,出现了问题,你的网卡都不带ping功能,连基本的问题排查机制都不具备,这样的代

    2024年02月09日
    浏览(53)
  • FPGA纯vhdl实现XGMII接口10G万兆网UDP协议DMA传输 配合10G Ethernet PCS/PMA使用 提供工程源码和技术支持

    目前网上的fpga实现udp基本生态如下: 1:verilog编写的udp收发器,但不带ping功能,这样的代码功能正常也能用,但不带ping功能基本就是废物,在实际项目中不会用这样的代码,试想,多机互联,出现了问题,你的网卡都不带ping功能,连基本的问题排查机制都不具备,这样的代

    2024年02月08日
    浏览(48)
  • 基于FPGA的GMII与RGMII接口相互转换(包含源工程文件)

      这段时间通过FPGA把ARP、ICMP、UDP协议全部通过FPGA实现了一遍,本来本文打算记录一下arp协议的,但在此之前应该先解决RGMII接口与GMII接口的转换问题。   经过前文讲解,开发板上使用的以太网PHY芯片是88R1518,原理图如下所示,留给用户的是RGMII双沿传输数据,时钟频率

    2024年03月18日
    浏览(92)
  • FPGA 高端项目:基于 SGMII 接口的 UDP 协议栈,提供2套工程源码和技术支持

    FPGA 高端项目:基于 SGMII 接口的 UDP 协议栈,提供2套工程源码和技术支持 目前网上的fpga实现udp基本生态如下: 1:verilog编写的udp收发器,但中间的FIFO或者RAM等调用了IP,或者不带ping功能,这样的代码功能正常也能用,但不带ping功能基本就是废物,在实际项目中不会用这样的

    2024年01月21日
    浏览(49)
  • 千兆以太网传输层 UDP 协议原理与 FPGA 实现(UDP接收)

    相关文章: (1)千兆以太网网络层 ARP 协议的原理与 FPGA 实现 (2)千兆以太网硬件设计及链路层 MAC 协议格式 (3)CRC校验原理及实现 (4)RGMII 与 GMII 转换电路设计 (5)千兆以太网网络层 IP 协议介绍与 IP 校 验和算法实现 (6)千兆以太网传输层 UDP 协议原理与 FPGA 实现(

    2024年02月04日
    浏览(127)

觉得文章有用就打赏一下文章作者

支付宝扫一扫打赏

博客赞助

微信扫一扫打赏

请作者喝杯咖啡吧~博客赞助

支付宝扫一扫领取红包,优惠每天领

二维码1

领取红包

二维码2

领红包