利用ZYNQ SOC快速打开算法验证通路(2)——数据传输最简方案:网络调试助手+W5500协议栈芯片
在上一篇该系列博文中讲解了MATLAB待处理数据写入.bin二进制数据文件的过程,接下来需要将数据通过以太网发送到ZYNQ验证平台。之前了解过Xilinx公司面向DSP开发的System Generator可以通过硬件协仿真的方式,进行算法板级验证。一个是本人不熟悉这种方式,再一个缺乏通用性,也无法在系统层面进行硬件验证。当然方案有很多,熟悉上位机的朋友完全可以自己写个软件完成数据传输和算法结果对比等功能。
这里选择最简单的方案:在上位机通过网络调试助手将数据打包并发送至以太网端口,ZYNQ端利用W5500硬件协议栈芯片解析数据。有人可能会说用ZYNQ这么高端的设备还使用外接协议栈芯片连接以太网真是浪费,这里就算是开个头吧,只能说根据能力和现有条件选择传输方案。如果数据量较大的场合,可考虑用LWIP开源协议栈或直接利用verilogHDL编写UDP/IP协议和MAC控制器的方式实现1000Mbps速率传输。
本文主要总结内容包括:TCP协议基础 网络调试助手应用事项,以及W5500的驱动移植。为了保证数据正确性,选用TCP这一可靠传输协议。以下介绍两个比较浅显易懂的博文,供没有网络和TCP协议基础的朋友参考。(见参考链接1 2)
有了以上基础知识,我们就可以正确配置网络参数了。查看W5500驱动中网络参数配置部分代码:
void Load_Net_Parameters(void) {
//加载端口0的工作模式,TCP客户端模式
S0_Mode = TCP_CLIENT; //UDP_MODE
Gateway_IP[] = ; //加载设备网关参数
Gateway_IP[] = ;
Gateway_IP[] = ;
Gateway_IP[] = ;
Sub_Mask[] = ; //加载设备子网掩码
Sub_Mask[] = ;
Sub_Mask[] = ;
Sub_Mask[] = ;
Phy_Addr[] = 0x0c; //加载设备物理地址(mac)
Phy_Addr[] = 0x29;
Phy_Addr[] = 0xab;
Phy_Addr[] = 0x7c;
Phy_Addr[] = 0x00;
Phy_Addr[] = 0x01;
IP_Addr[] = ; //加载本设备(FPGA端)IP地址
IP_Addr[] = ;
IP_Addr[] = ;
IP_Addr[] = ;
//加载设备端口0(socket 0)的端口号5000
S0_Port[] = 0x13; //十六进制 1388转换成十进制为5000
S0_Port[] = 0x88;
//设定的是客户端模式
if(S0_Mode == TCP_CLIENT)
{
//加载端口0的目的(如调试用的pc机)IP地址
S0_DIP[] = ;
S0_DIP[] = ;
S0_DIP[] = ;
S0_DIP[] = ;
//加载端口0的目的(如调试用的pc机)端口号6000
S0_DPort[] = 0x17;
S0_DPort[] = 0x70;
}
//设定的是UDP模式,初始化给一个目的IP和端口号。
if(S0_Mode == UDP_MODE)
{
//加载端口0的目的(如调试用的pc机)IP地址
UDP_DIPR[] = ;
UDP_DIPR[] = ;
UDP_DIPR[] = ;
UDP_DIPR[] = ;
//加载端口0的目的(如调试用的pc机)端口号6000
UDP_DPORT[] = 0x17;
UDP_DPORT[] = 0x70;
}
}
此处将PC端作为TCP协议中服务器,ZYNQ验证平台视为客户端,即为“呼叫端”。由代码看出PC端IP地址为192.168.90.188,子网掩码应设为:255.255.255.0,这样ZYNQ与PC端在一个子网内,可直接通过网线连接。 端口号为6000。驱动中包含W5500 SPI用户接口时序部分代码,可简单修改调用本人的博文《ZYNQ EMIO使用及可重用封装》中的EMIO接口函数(见参考链接3)。
根据上面参数配置好PC端的IP地址 子网掩码后,我们来看下网络调试助手的“坑”。

基本使用没什么可说的,网上教程很多。关键是画红框的部分。这里的发送周期要尽量设置大些,因为整个数据文件会被切割成多个数据包,每个包的发送和允许重传时间由总的发送周期分配得到。如果文件较大,发送周期又设置的较小,会导致后半部分被丢弃(所设置时间只够传输文件的前半部分)。RX方向接收数据时选择接收转向文件,注意两点:1 接收文件的扩展名同样要为.bin 2 不要选择十六进制显示,否则接收数据会变成字符串(可能是软件bug)。
W5500的C语言驱动基于网上流传的STM32版本代码。其中应用API为Process_Socket_Data中的发送和接收函数:Write_SOCK_Data_Buffer Read_SOCK_Data_Buffer。两者内部控制读写指针偏移以及调用SPI接口函数完成数据传输,此处不进行详述,关于W5500的C语言驱动可看教程视频(见参考链接4)。最后附上环回数据的demo效果:

对于网络传输部分的总结就到这里,后边可能会考虑利用LWIP完成高速传输。数据传到ZYNQ了,下一步当然是先缓存起来,再发送到PL端验证算法模块,这样做的好处是可以模拟实时数据流,比如验证通信算法和视频处理算法时尤为适用。华丽分割线
---------------------------------------------------------------------------------------------------------------------------------------------------------
参考链接:
1 五分钟读懂TCP 协议——TCP协议简介 - CSDN博客
https://blog.csdn.net/ningdaxing1994/article/details/73076795
2 计算机网络: IP地址,子网掩码,网段表示法,默认网关,DNS服务器详解 - 互联网隐者 - 博客园
https://www.cnblogs.com/iceJava/p/5372033.html
3《ZYNQ EMIO使用及可重用封装》 - 没落骑士 - 博客园
https://www.cnblogs.com/moluoqishi/p/9198772.html
4 STM32F103+W5500 全硬件以太网开发板视频教程 (1)- TCP服务器(静态)_土豆视频
http://new-play.tudou.com/v/XMzQyODk0NjAzNg==.html?from=s1.8-1-1.2
利用ZYNQ SOC快速打开算法验证通路(2)——数据传输最简方案:网络调试助手+W5500协议栈芯片的更多相关文章
- 利用ZYNQ SOC快速打开算法验证通路(1)——MATLAB浮点数与定点二进制补码互转
最近本人一直在学习ZYNQ SOC的使用,目的是应对科研需要,做出通用的算法验证平台.大概思想是:ZYNQ PS端负责与MATLAB等上位机数据分析与可视化软件交互:既可传输数据,也能通过上位机配置更 ...
- 利用ZYNQ SOC快速打开算法验证通路(6)——LWIP实现千兆TCP/IP网络传输
一.前言 之前ZYNQ与PC之间的网络连接依赖于外接硬件协议栈芯片,虽然C驱动非常简单,但网络带宽受限.现采用LWIP+PS端MAC控制器+PHY芯片的通用架构.关于LWIP库,已经有很多现成的资料和 ...
- 利用ZYNQ SOC快速打开算法验证通路(6)——利用AXI总线实时配置sysGen子系统
利用ZYNQ验证算法的一大优势在于,可以在上位机发送指令借助CPU的控制能力和C语言易开发特点,实时配置算法模块的工作模式.参数等对来对其算法模块性能进行全面的评估.最重要的是无需重新综合硬件模块. ...
- 利用ZYNQ SOC快速打开算法验证通路(4)——AXI DMA使用解析及环路测试
一.AXI DMA介绍 本篇博文讲述AXI DMA的一些使用总结,硬件IP子系统搭建与SDK C代码封装参考米联客ZYNQ教程.若想让ZYNQ的PS与PL两部分高速数据传输,需要利用PS的HP(高性能 ...
- 利用ZYNQ SOC快速打开算法验证通路(5)——system generator算法IP导入IP integrator
一.前言 利用FPGA设计算法一直以来都是热点,同样也是难点.将复杂的数学公式 模型通过硬件系统来搭建,在低延时 高并行性等优势背后极大提高了设计难度和开发周期.Xilinx公司的sysGen(sys ...
- 利用ZYNQ SOC快速打开算法验证通路(3)——PS端DMA缓存数据到PS端DDR
上篇该系列博文中讲述W5500接收到上位机传输的数据,此后需要将数据缓存起来.当数据量较大或者其他数据带宽较高的情况下,片上缓存(OCM)已无法满足需求,这时需要将大量数据保存在外挂的DDR SDRA ...
- 利用Zynq Soc创建一个嵌入式工程
英文题目:Using the Zynq SoC Processing System,参考自ADI的ug1165文档. 利用Zynq Soc创建一个嵌入式工程,该工程总体上包括五个步骤: 步骤一.新建空 ...
- 基于Python的函数回归算法验证
看机器学习看到了回归函数,看了一半看不下去了,看到能用方差进行函数回归,又手痒痒了,自己推公式写代码验证: 常见的最小二乘法是一阶函数回归回归方法就是寻找方差的最小值y = kx + bxi, yiy ...
- 利用朴素贝叶斯算法进行分类-Java代码实现
http://www.crocro.cn/post/286.html 利用朴素贝叶斯算法进行分类-Java代码实现 鳄鱼 3个月前 (12-14) 分类:机器学习 阅读(44) 评论(0) ...
随机推荐
- HTML入门教程,多年心血总结,一看就会
笔者在武汉蚂蹄软件服务中心做软件开发多年,最近花一天时间总结出一套HTML入门级的教程,全篇没有任何废话,全部是精华,希望对你入门web开发有一定的帮助. HTML基本格式 <html> ...
- Go使用Makefile构建
我们平常很多时候都是直接在命令行输入go build进行编译的: go build . 或者测试使用go run运行项目 go run main.go 我看有很多大型开源项目都是如下方式: mak ...
- eclipse项目有红叉的解决办法
eclipse项目上有红叉,说明这个项目存在一些的问题,对于这种情况需要具体来看. 1 新导入项目的红叉 如果是新导入的项目,一般红叉就只在项目名称上面有红叉,项目下的分项上面没有,这一般是由于当初项 ...
- 在.net core上使用Entity FramWork(Db first)
在.net core中不可以向往常一样去直接可视化创建EF了,那我们可以通过命令安装 其依赖项有 Install-package Microsoft.EntityFrameworkCore Insta ...
- [Python Web]常见的 POST 提交数据的方式
本文参考整理于:https://imququ.com/post/four-ways-to-post-data-in-http.html 简介 这里介绍了,用 POST 方法提交数据时,常见的三种方式: ...
- 从无到有-在create-react-app基础上接入react-router、redux-saga
搭建项目框架 新建项目 执行如下代码,用create-react-app来建立项目的基础框架,然后安装需要用到的依赖. $ npx create-react-app my-test-project $ ...
- mariadb 内存占用优化
本文由云+社区发表 作者:工程师小熊 摘要:我们在使用mariadb的时候发现有时候不能启动起来,在使用过程中mariadb占用的内存很大,在这里学习下mariadb与内存相关的配置项,对mariad ...
- Zuul上实现限流(spring-cloud-zuul-ratelimit)
简述 Spring Cloud Zuul RateLimit项目Github地址: https://github.com/marcosbarbero/spring-cloud-zuul-ratelim ...
- js内存深入学习(一)
一. 内存空间储存 某些情况下,调用堆栈中函数调用的数量超出了调用堆栈的实际大小,浏览器会抛出一个错误终止运行.这个就涉及到内存问题了. 1. 数据结构类型 栈: 后进先出(LIFO)的数据结构 堆 ...
- 大前端的自动化工厂(5)—— 基于Karma+Mocha+Chai的单元测试和接口测试
一. 前端自动化测试 大多数前端开发者对测试相关的知识是比较缺乏的,一来是开发节奏很快,来不及写,另一方面团队里也配备了"人肉测试机",完全没必要自己来.但随着项目体量的增大,许多 ...