基于FPGA的UDP 通信(四)
2023-04-18 16:45:50 时间
引言
前文链接:
本文基于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约束,综合实现以后产生比特流。
参数设置:
UDP接收模块例化:
电脑侧
IP设置
DOS绑定
鼠标右键,以管理员身份运行命令提示符。
输入如下命令,显示所有网络连接
netsh i i show in
查询到与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
传输验证
数据抓取
MATLAB 发送1~101,共101个数据,FPGA侧利用 ILA抓取接收数据:
演示视频
相关文章
- 直接在代码里面对list集合进行分页
- .NET Framework 4.5新特性详解
- 大数据的简要介绍
- 大数据的由来
- 高斯混合模型的自然梯度变量推理
- timing-wheel 仿Kafka实现的时间轮算法
- 使用Navicat软件连接自建数据库(Linux系统)
- 那一天,我被Redis主从架构支配的恐惧
- Redis 深入了解键的过期时间
- C#使用委托调用实现用户端等待闪屏
- 基于流计算 Oceanus 和 Elasticsearch Service 构建百亿级实时监控系统
- GRAND | 转录调控网络预测数据库
- JFreeChart API中文文档
- 临床相关突变查询数据库
- TIGER | 人类胰岛基因变化查询数据库
- 视频边缘计算网关EasyNVR在视频整体监控解决方案中的应用分析
- Apache Arrow - 大数据在数据湖后的下一个风向标
- 常见的电商数据指标体系
- AKShare-艺人数据-艺人流量价值
- MySQL中多表联合查询与子查询的这些区别,你可能不知道!