fpga以太网通信例程_verilog参数传递

fpga以太网通信例程_verilog参数传递1本实验将实现FPGA芯片和PC之间进行千兆以太网数据通信,通信协议采用Ethernet UDP通信协议。FPGA通过GMII总线和开发板上的GigabitPHY芯片通信,GigabitPHY芯片把数据通过网线发给PC。在上次的实验中,我们详细讲解了网络传输的过程中如何对数据进行传输,以及数据传输的格式,这次实验中,我们详细讲解如何使用Verilog语言

大家好,又见面了,我是你们的朋友全栈君。如果您正在找激活码,请点击查看最新教程,关注关注公众号 “全栈程序员社区” 获取激活教程,可能之前旧版本教程已经失效.最新Idea2022.1教程亲测有效,一键激活。

Jetbrains全家桶1年46,售后保障稳定

1

本实验将实现 FPGA 芯片和 PC 之间进行千兆以太网数据通信, 通信协议采用 Ethernet  UDP 通信协议。 FPGA 通过 GMII 总线和开发板上的 Gigabit PHY 芯片通信, Gigabit PHY芯片把数据通过网线发给 PC。在上次的实验中,我们详细讲解了网络传输的过程中如何对数据进行传输,以及数据传输的格式,这次实验中,我们详细讲解如何使用Verilog语言来实现将UDP数据的发送。

以太网数据通信的示意图如下:

fpga以太网通信例程_verilog参数传递


这里我再展示数据传输的格式图片。

fpga以太网通信例程_verilog参数传递


  其中数据包括三个方面的内容:IPv4数据包头,UDP包头,和用户数据。

IPv4数据包头:

fpga以太网通信例程_verilog参数传递


UDP数据包头。

fpga以太网通信例程_verilog参数传递



2


   AX515/AX530开发板我们采用了Realtek千兆GPHY芯片RTL8211E 来实现千兆以太网数据通信。当网口 Link 到千兆以太网时, FPGA 通过 GMII 总线和 PHY 芯片进行数据通信,当网口 Link 到百兆以太网时, PGA 通过 MII 总线和 PHY 芯片进行数据通信。 另外 FPGA 可以通过 MDI/MDIO 管理接口来配置或读取 PHY 芯片内部的寄存器。

本实验以千兆以太网 GMII 通信为例来设计 verilog 程序。整个Ethernet_test测试是一个顶层模块,UDP发送模块。我们要发送的数据为Hello World。

首先我们先实现UDP模块。 UDP模块包括UDP发送模块和CRC校验模块。RTL电路示意图:

fpga以太网通信例程_verilog参数传递


 Ipsend模块是UDP发送模块。各个引脚的解释请看各个模块的Verilog代码。代码在下面。UDP发送顶层模块。

fpga以太网通信例程_verilog参数传递

fpga以太网通信例程_verilog参数传递


UDP发送数据模块。

fpga以太网通信例程_verilog参数传递

fpga以太网通信例程_verilog参数传递

fpga以太网通信例程_verilog参数传递fpga以太网通信例程_verilog参数传递

fpga以太网通信例程_verilog参数传递

fpga以太网通信例程_verilog参数传递

fpga以太网通信例程_verilog参数传递

fpga以太网通信例程_verilog参数传递


       UDP 发送模块实现把 RAM 里的数据组成 UDP IP 包格式通过 GMII 总线发给 PHY 芯片,PHY 芯片再把数据发送到开发板的网口。

IP 数据包发送之前需要先发送 IP 数据包的包头,IP 包头由 8 个字节的前导码, 目标 MAC Address,源 MAC 地址和两个字节的 IP 包类型组成。前导码是由 7 个 0x55, 1个 0xD5 字节组成, 表示一个IP数据包传输的开始; 目标MAC Address为数据要发送对象的MAC地址,如果开发板的网口是和您的 PC 机相连, 那目标 MAC Address的值为你 PC 机的 MAC 地址。源 MAC Address 是指开发板本地的 MAC 地址。IP 包类型值为 0x0800。

发完 IP 包头之后开始发送 IP 数据报首部,IP 数据报首部的格式我们在前面已经讲过,接着发送 ram中的数据,最后发送 4 个字节的 CRC32 的值。

CRC模块我们不把代码贴出来了,请到最后我提供的链接进行下载。

Ethernet顶层测试模块。

fpga以太网通信例程_verilog参数传递

fpga以太网通信例程_verilog参数传递

fpga以太网通信例程_verilog参数传递

fpga以太网通信例程_verilog参数传递


 Ethernet顶层设计模块是首先将发送的数据写进ram中,此时ram作为一个缓存,每次发送数据的时候首先需要去读取ram中的数据,将读取ram中的数据读入UDP模块中,然后进行按照数据发送的格式进行发送,每次发送的一帧数据即为Hello World。即为12字节。

3


实验结果:

fpga以太网通信例程_verilog参数传递


   通过wireshark软件我们抓取Ethernet网络的数据,在wireshark抓包窗口我们可以看到开发板(192.168.0.2)向PC网口(192.168.0.2)发来的数据包,这里会显示数据包的目标MAC, 源MAC,IP包头和UDP包等信息。

千兆以太网的数据传输速度非常快,而且是全双工传输,通过环路测试,UDP 通信的数据速度可以达到 900Mbps 以上,非常适合高速数据传输的场合,比如视频图像传输,高速数据采集等等。

  注意:以太网的数据帧的传输有包长的要求, 一般在46~1500字节。所以在发送以太网数据包的时候,数据帧的长度不能太短, 不然会导致PC数据包发送而FPGA收不到数据包的情况。

  工程链接地址:链接:http://pan.baidu.com/s/1geWb771 密码:64wf

版权声明:本文内容由互联网用户自发贡献,该文观点仅代表作者本人。本站仅提供信息存储空间服务,不拥有所有权,不承担相关法律责任。如发现本站有涉嫌侵权/违法违规的内容, 请联系我们举报,一经查实,本站将立刻删除。

发布者:全栈程序员-站长,转载请注明出处:https://javaforall.net/206686.html原文链接:https://javaforall.net

(0)
上一篇 2025年8月6日 下午3:22
下一篇 2025年8月6日 下午4:01


相关推荐

  • chgrp linux,linux命令chgrp

    chgrp linux,linux命令chgrplinux 命令 chgrpLinuxch 命令用来变更文件或目录的所属群组 Linuxchgrp 命令说明 Linuxchgrp 命令用来改变文件或目录所属的用户组 该命令用来改变指定文件所属的用户组 其中 组名可以是用户组的 id 也可以是用户组的组名 文件名可以是由空格分开的要改变属组的文件列表 也可以是由通配符描述的文件集合 如果用户不是该文件的文件主或超级用户 root 则不能改变该文件

    2025年7月2日
    4
  • 小白也能快速上手 百度智能云推出OpenClaw极速简易部署方案

    小白也能快速上手 百度智能云推出OpenClaw极速简易部署方案

    2026年3月13日
    2
  • Android应用之PreferenceFragment

    Android应用之PreferenceFragment最近在看 Android 源码 Setting 代码的时候 发现其中配置都是用的 PreferenceFr 以前对这一块不是很了解 查资料看了一下 感觉用起来好方便 nbsp nbsp nbsp nbsp nbsp nbsp PreferenceFr 的界面也是写在一个 XML 文件中 不过不是放在 layout 目录下 需要自己在 res 下面新建一个 xml 命名的文件夹 然后在该文件夹下再新建一个 xml 文件 这个文件就是我们 Pref

    2026年3月17日
    2
  • 豆包变回以前版本方法

    豆包变回以前版本方法

    2026年3月12日
    3
  • 中国剩余定理【数论】

    中国剩余定理【数论】中国剩余定理

    2026年3月18日
    3
  • 真封神之天尊地魔引擎修改系列教程

    真封神之天尊地魔引擎修改系列教程真封神引擎技术研究QQ交流群:157754180真封神之天尊地魔SF引擎研修目录:本套教程分为三个部分:客户端部分、服务端部分  、以及引擎部分!引擎部分:1.真封神GC去MD5教程      2.引擎修改之突破仓库金钱上限20亿                           3.引擎修改之多次转职            

    2022年7月24日
    40

发表回复

您的邮箱地址不会被公开。 必填项已用 * 标注

关注全栈程序员社区公众号