基于FPGA的UDP 通信(四)


引言

前文链接:

基于FPGA的UDP 通信(一)

基于FPGA的UDP 通信(二)

基于FPGA的UDP 通信(三)

本文基于FPGA与MATLAB作千兆以太网通信模块UDP数据接收实验板级验证:FPGA接收上位机数据。

设计条件

FPGA芯片:xc7a35tfgg484-2

网络芯片(PHY):RTL8211(支持1000M/100M/10M)

MAC与PHY接口:GMII

接口类型:RJ-45

Vivado版本:2018.3

Matlab版本:R2022a

电脑:小新Pro16 2022 酷睿版 笔记本

转接口:绿联USB转千兆以太网 转接器


MATLAB侧

在实时脚本中编写代码:

clc;
clearvars;

% UDP 参数设置
LocalHost = "192.168.8.1";
LocalPort = 6009;
Timeout = 10;
% 创建UDP端口对象
U_UDP_PORT_OBJ = udpport("ByteOrder","little-endian","LocalHost",LocalHost,"LocalPort",LocalPort,"Timeout",Timeout);

% 写数据
DstHost = "192.168.8.2";
DstPort = 6001;
write(U_UDP_PORT_OBJ,1:101,"uint8",DstHost,DstPort);
% 清除缓存
flush(U_UDP_PORT_OBJ);

clear U_UDP_PORT_OBJ

如有需要,可以在此下载MATLAB实时脚本文件:

链接:百度网盘 请输入提取码

提取码:UDP0

FPGA侧

配置UDP参数,并在顶层例化,添加XDC约束,综合实现以后产生比特流。

参数设置:

基于FPGA的UDP 通信(四)_第1张图片

UDP接收模块例化:

基于FPGA的UDP 通信(四)_第2张图片

电脑侧

IP设置

基于FPGA的UDP 通信(四)_第3张图片

DOS绑定

鼠标右键,以管理员身份运行命令提示符

输入如下命令,显示所有网络连接

netsh i i show in

基于FPGA的UDP 通信(四)_第4张图片

查询到与FPGA连接的以太网 Idx(此处我的Idx为18),用DOS命令绑定目的IP和目的MAC地址,用如下的命令:

netsh -c i i add neighbors 18 192.168.8.2 00-01-02-03-04-05

Idx 后面第一组数据为 FPGA板的IP地址,第二组数据为FPGA板的MAC地址。

利用如下命令查询绑定结果:

arp -a

基于FPGA的UDP 通信(四)_第5张图片

传输验证

数据抓取

MATLAB 发送1~101,共101个数据,FPGA侧利用 ILA抓取接收数据:

基于FPGA的UDP 通信(四)_第6张图片

基于FPGA的UDP 通信(四)_第7张图片

演示视频

C站:基于FPGA的千兆以太网通信——UDP接收演示

B站:基于FPGA的千兆UDP通信演示视频


你可能感兴趣的:(FPGA与接口/通信协议,fpga开发,udp,MATLAB,GMII)