在上一篇该系列博文中讲解了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协议栈芯片的更多相关文章

  1. 利用ZYNQ SOC快速打开算法验证通路(1)——MATLAB浮点数与定点二进制补码互转

    最近本人一直在学习ZYNQ SOC的使用,目的是应对科研需要,做出通用的算法验证平台.大概思想是:ZYNQ PS端负责与MATLAB等上位机数据分析与可视化软件交互:既可传输数据,也能通过上位机配置更 ...

  2. 利用ZYNQ SOC快速打开算法验证通路(6)——LWIP实现千兆TCP/IP网络传输

    一.前言 之前ZYNQ与PC之间的网络连接依赖于外接硬件协议栈芯片,虽然C驱动非常简单,但网络带宽受限.现采用LWIP+PS端MAC控制器+PHY芯片的通用架构.关于LWIP库,已经有很多现成的资料和 ...

  3. 利用ZYNQ SOC快速打开算法验证通路(6)——利用AXI总线实时配置sysGen子系统

    利用ZYNQ验证算法的一大优势在于,可以在上位机发送指令借助CPU的控制能力和C语言易开发特点,实时配置算法模块的工作模式.参数等对来对其算法模块性能进行全面的评估.最重要的是无需重新综合硬件模块. ...

  4. 利用ZYNQ SOC快速打开算法验证通路(4)——AXI DMA使用解析及环路测试

    一.AXI DMA介绍 本篇博文讲述AXI DMA的一些使用总结,硬件IP子系统搭建与SDK C代码封装参考米联客ZYNQ教程.若想让ZYNQ的PS与PL两部分高速数据传输,需要利用PS的HP(高性能 ...

  5. 利用ZYNQ SOC快速打开算法验证通路(5)——system generator算法IP导入IP integrator

    一.前言 利用FPGA设计算法一直以来都是热点,同样也是难点.将复杂的数学公式 模型通过硬件系统来搭建,在低延时 高并行性等优势背后极大提高了设计难度和开发周期.Xilinx公司的sysGen(sys ...

  6. 利用ZYNQ SOC快速打开算法验证通路(3)——PS端DMA缓存数据到PS端DDR

    上篇该系列博文中讲述W5500接收到上位机传输的数据,此后需要将数据缓存起来.当数据量较大或者其他数据带宽较高的情况下,片上缓存(OCM)已无法满足需求,这时需要将大量数据保存在外挂的DDR SDRA ...

  7. 利用Zynq Soc创建一个嵌入式工程

    英文题目:Using the Zynq SoC Processing System,参考自ADI的ug1165文档. 利用Zynq Soc创建一个嵌入式工程,该工程总体上包括五个步骤: 步骤一.新建空 ...

  8. 基于Python的函数回归算法验证

    看机器学习看到了回归函数,看了一半看不下去了,看到能用方差进行函数回归,又手痒痒了,自己推公式写代码验证: 常见的最小二乘法是一阶函数回归回归方法就是寻找方差的最小值y = kx + bxi, yiy ...

  9. 利用朴素贝叶斯算法进行分类-Java代码实现

    http://www.crocro.cn/post/286.html 利用朴素贝叶斯算法进行分类-Java代码实现  鳄鱼  3个月前 (12-14)  分类:机器学习  阅读(44)  评论(0) ...

随机推荐

  1. 剑指Spring源码(一)

    Spring,相信每个Java开发都用过,而且是每天都在用,那强大又神秘的IoC,AOP,让我们的开发变得越来越简单,只需要一个注解搞定一切,但是它内部到底是什么样子的呢?跟着我,一起探究Spring ...

  2. 受到 1 万点暴击,二狗子被 DDoS 攻击的惨痛经历

    二狗子的遭遇 “好消息,好消息,免费 DDoS 攻击软件上线了,性感黑客在线攻击,帮您攻克所有商业难题.”二狗子不知道在看着什么网站,新买的 Mac 中发出热闹的声音. 二狗子想知道“DDoS 是什么 ...

  3. 『字符串模式匹配 KMP』

    字符串模式匹配 我们要先了解一下问题是什么. 模式匹配是数据结构中字符串的一种基本运算,给定一个子串,要求在某个字符串中找出与该子串相同的所有子串,这就是模式匹配. KMP 然后我们来认识一下今天的主 ...

  4. Elasticsearch 分词器

    无论是内置的分析器(analyzer),还是自定义的分析器(analyzer),都由三种构件块组成的:character filters , tokenizers , token filters. 内 ...

  5. redis 系列24 哨兵Sentinel (中)

    四. 检测下线状态 对于Redis的Sentinel中关于下线有两个不同的概念:(1)主观下线(Subjectively Down, 简称 Sdown) 指的是单个 Sentinel 实例对服务器做出 ...

  6. Android--SoundPool

    前言 在Android中播放音频文件经常会用到MediaPlayer,但是MediaPlayer存在一些不足的地方,如:资源占用量较高.加载延迟时间较长.不支持多个音频同时播放等.这些缺点决定了Med ...

  7. 服务测试碰钉子Server GC

    如果发现你的dotnet core服务并发上不去,但cpu资源还比较充足那就要注意了!因为这很有可能是你没有设置一个运行项导致...,下面要提到的就是GC.Server这玩意,实际上项目编译中并没有这 ...

  8. source map 的原理探究

    线上产品代码一般是编译过的,前端的编译处理过程包括不限于 转译器/Transpilers (Babel, Traceur) 编译器/Compilers (Closure Compiler, TypeS ...

  9. PyQt:个性化登录界面模仿QQ登录

    写在前面 写了一个登录界面的demo,类似QQ的,写的自己喜欢的样式,贴一下代码,先上效果,如下 陈述 PyQt5+Python3.5.2 login.py是里登录的主界面loginWnd类,Head ...

  10. Python:数据可视化pyecharts的使用

    什么是pyecharts? pyecharts 是一个用于生成 Echarts 图表的类库. echarts 是百度开源的一个数据可视化 JS 库,主要用于数据可视化.pyecharts 是一个用于生 ...