W6100-EVB-PICO作为TCP Client 进行数据回环测试(五)
前言
上一章我们用W6100-EVB-PICO开发板通过DNS解析www.baidu.com(百度域名)成功得到其IP地址,那么本章我们将用我们的开发板作为客户端去连接服务器,并做数据回环测试:收到服务器发送的数据,并回传给服务器。
TCP是什么?什么是TCP Client? 能做什么?
TCP (Transmission Control Protocol) 是一种面向连接的、可靠的、基于字节流的传输协议,用于在计算机网络上传输数据。TCP Client是指TCP网络服务的客户端连接,主动向服务器发起连接请求并建立连接,用于实现串口数据和服务器数据的交互,保证数据的可靠交换。TCP Clent通常用于设备与服务器之间的数据交互,是最常用的联网通信方式。
TCP Client的主要作用是建立和管理与TCP服务器之间的连接,实现数据的可靠传输。通过TCP Client,设备可以向服务器发送数据并从服务器接收数据,从而实现设备与服务器之间的数据交互。
在TCP Client中,客户端程序需要指定服务器的IP地址和端口号,并使用TCP协议与服务器建立连接。一旦连接建立成功,客户端程序就可以通过数据流对象 (NetworkStream) 与服务器进行数据交互。
因此,TCP Client可以帮助设备实现与服务器之间的可靠数据交换,是设备联网通信的重要方式之一。在工业自动化、物联网、智能家居等应用中,TCP Client被广泛使用。
连接方式
使开发板和我们的电脑处于同一网段:
- 开发板(设备)通过交叉线直连主机(PC)
- 开发板和主机都接在路由器LAN口
测试工具
- 网络调试工具(任意)
- wireshark抓包工具
回环测试
1. 相关代码
如下所示,我们可以看到应用实例里面loopback_tcpc的具体实现,我们需要传入五个参数:socket端口号、收发缓存、目的IP地址、目的端口号和回环模式;函数里面用一个Switch状态机,对socket端口状态轮询并进行相应的处理,处于连接状态就判断是否收到数据,如果有就获取数据大小,并做回传处理,回传失败就关闭端口;处于关闭状态就跑tcp协议并打开端口;处于初始化状态就连接服务器;处于等待关闭状态就断开连接。
值得一提的是W6100这款以太网芯片支持IPv6,因此在回环模式上有着不同选择,相应地处理上也会根据模式分别进行处理,这里选择IPv4模式进行回环测试。
int32_t loopback_tcpc(uint8_t sn, uint8_t* buf, uint8_t* destip, uint16_t destport, uint8_t loopback_mode)
{int32_t ret; // return value for SOCK_ERRORsdatasize_t sentsize=0;uint8_t status,inter,addr_len;datasize_t received_size;uint8_t tmp = 0;uint8_t arg_tmp8;wiz_IPAddress destinfo;// Socket Status Transitions// Check the W6100 Socket n status register (Sn_SR, The 'Sn_SR' controlled by Sn_CR command or Packet send/recv status)getsockopt(sn,SO_STATUS,&status);switch(status){case SOCK_ESTABLISHED :ctlsocket(sn,CS_GET_INTERRUPT,&inter);if(inter & Sn_IR_CON) // Socket n interrupt register mask; TCP CON interrupt = connection with peer is successful{#ifdef _LOOPBACK_DEBUG_printf("%d:Connected to - %d.%d.%d.%d : %d\r\n",sn, destip[0], destip[1], destip[2], destip[3], destport);#endifarg_tmp8 = Sn_IR_CON;ctlsocket(sn,CS_CLR_INTERRUPT,&arg_tmp8);// this interrupt should be write the bit cleared to '1'}//// Data Transaction Parts; Handle the [data receive and send] process//getsockopt(sn, SO_RECVBUF, &received_size);if(received_size > 0) // Sn_RX_RSR: Socket n Received Size Register, Receiving data length{if(received_size > DATA_BUF_SIZE) received_size = DATA_BUF_SIZE; // DATA_BUF_SIZE means user defined buffer size (array)ret = recv(sn, buf, received_size); // Data Receive process (H/W Rx socket buffer -> User's buffer)if(ret <= 0) return ret; // If the received data length <= 0, receive failed and process endreceived_size = (uint16_t) ret;sentsize = 0;// Data sentsize controlwhile(received_size != sentsize){ret = send(sn, buf+sentsize, received_size-sentsize); // Data send process (User's buffer -> Destination through H/W Tx socket buffer)if(ret < 0) // Send Error occurred (sent data length < 0){close(sn); // socket closereturn ret;}sentsize += ret; // Don't care SOCKERR_BUSY, because it is zero.}}//break;case SOCK_CLOSE_WAIT :#ifdef _LOOPBACK_DEBUG_printf("%d:CloseWait\r\n",sn);#endifgetsockopt(sn, SO_RECVBUF, &received_size);if((received_size = getSn_RX_RSR(sn)) > 0) // Sn_RX_RSR: Socket n Received Size Register, Receiving data length{if(received_size > DATA_BUF_SIZE) received_size = DATA_BUF_SIZE; // DATA_BUF_SIZE means user defined buffer size (array)ret = recv(sn, buf, received_size); // Data Receive process (H/W Rx socket buffer -> User's buffer)if(ret <= 0) return ret; // If the received data length <= 0, receive failed and process endreceived_size = (uint16_t) ret;sentsize = 0;// Data sentsize controlwhile(received_size != sentsize){ret = send(sn, buf+sentsize, received_size-sentsize); // Data send process (User's buffer -> Destination through H/W Tx socket buffer)if(ret < 0) // Send Error occurred (sent data length < 0){close(sn); // socket closereturn ret;}sentsize += ret; // Don't care SOCKERR_BUSY, because it is zero.}}if((ret=disconnect(sn)) != SOCK_OK) return ret;#ifdef _LOOPBACK_DEBUG_printf("%d:Socket Closed\r\n", sn);#endifbreak;case SOCK_INIT :#ifdef _LOOPBACK_DEBUG_if(loopback_mode == AS_IPV4)printf("%d:Try to connect to the %d.%d.%d.%d, %d\r\n", sn, destip[0], destip[1], destip[2], destip[3], destport);else if(loopback_mode == AS_IPV6){printf("%d:Try to connect to the %04X:%04X", sn, ((uint16_t)destip[0] << 8) | ((uint16_t)destip[1]),((uint16_t)destip[2] << 8) | ((uint16_t)destip[3]));printf(":%04X:%04X", ((uint16_t)destip[4] << 8) | ((uint16_t)destip[5]),((uint16_t)destip[6] << 8) | ((uint16_t)destip[7]));printf(":%04X:%04X", ((uint16_t)destip[8] << 8) | ((uint16_t)destip[9]),((uint16_t)destip[10] << 8) | ((uint16_t)destip[11]));printf(":%04X:%04X,", ((uint16_t)destip[12] << 8) | ((uint16_t)destip[13]),((uint16_t)destip[14] << 8) | ((uint16_t)destip[15]));printf("%d\r\n", destport);}#endifif(loopback_mode == AS_IPV4)ret = connect(sn, destip, destport, 4); /* Try to connect to TCP server(Socket, DestIP, DestPort) */else if(loopback_mode == AS_IPV6)ret = connect(sn, destip, destport, 16); /* Try to connect to TCP server(Socket, DestIP, DestPort) */printf("SOCK Status: %d\r\n", ret);if( ret != SOCK_OK) return ret; // Try to TCP connect to the TCP server (destination)break;case SOCK_CLOSED:switch(loopback_mode){case AS_IPV4:tmp = socket(sn, Sn_MR_TCP4, any_port++, SOCK_IO_NONBLOCK);break;case AS_IPV6:tmp = socket(sn, Sn_MR_TCP6, any_port++, SOCK_IO_NONBLOCK);break;case AS_IPDUAL:tmp = socket(sn, Sn_MR_TCPD, any_port++, SOCK_IO_NONBLOCK);break;default:break;}if(tmp != sn){ /* reinitialize the socket */#ifdef _LOOPBACK_DEBUG_printf("%d : Fail to create socket.\r\n",sn);#endifreturn SOCKERR_SOCKNUM;}printf("%d:Socket opened[%d]\r\n",sn, getSn_SR(sn));sock_state[sn] = 1;break;default:break;}return 1;
}
主函数就比较简单,在此之前我们先声明socket端口号和所用最大的缓存大小,不做分片处理默认为2KB;然后初始化网络信息、目标IP地址和目标端口,最后在while循环里调用loopback_tcpc并传入相应参数即可。
注意:这里的目的IP地址设置为我们的电脑IP地址,因为我们要让电脑端作为服务器,使用网络调试助手进行数据回环测试;另外目标端口选择尽量避免使用特殊端口,这里使用8080
#define SOCKET_ID 0
#define ETHERNET_BUF_MAX_SIZE (1024 * 2)void network_init(void);wiz_NetInfo net_info = {.mac = {0x00, 0x08, 0xdc, 0x16, 0xed, 0x2e},.ip = {192, 168, 1, 10},.sn = {255, 255, 255, 0},.gw = {192, 168, 1, 1},.dns = {8, 8, 8, 8},.ipmode = NETINFO_STATIC_V4};
wiz_NetInfo get_info;
static uint8_t ethernet_buf[ETHERNET_BUF_MAX_SIZE] = {0,};static uint8_t des_ip[4] = {192, 168, 1, 2};
static uint16_t des_port = 8080;int main()
{ stdio_init_all();sleep_ms(2000);network_init();while(true){loopback_tcpc(SOCKET_ID, ethernet_buf, des_ip, des_port, AS_IPV4);sleep_ms(500);}}void network_init(void)
{uint8_t temp;wizchip_initialize();printf("W6100 dns test example.\r\n");sleep_ms(2000);/* Determine the network lock register status */if(!ctlwizchip(SYS_NET_LOCK, &temp)){ printf("unlock.\n");NETUNLOCK();}wizchip_setnetinfo(&net_info);print_net_info(&get_info);sleep_ms(2000);
}
2.测试现象
我们编译烧录后,打开串行监视器,可以看到,配置相关信息后,尝试连接我们初始化设置的目的IP(电脑IP),然后我们在电脑上打开网络调试助手,选择tcp服务器模式,IP选择电脑的本机IP(一般默认即为电脑IP),端口号写8080(跟我们在开发板配置的信息一致,不然监听不到),配置完成打开后,可以看到客户端上线提示,尝试发送数据,可以看到成功回传。


我们也可以在打开wireshark抓包工具,输入命令<ip.addr == 192.168.1.10 and tcp>过滤数据包(IP地址改成自己电脑的,也即开发板设置的目标IP地址);我这里先关闭网络调试助手,然后又打开,接着发送0~9十个阿拉伯数字,可以通过抓包工具十分清楚明了的看到具体交互过程,如下图所示。

相关链接:
本章相应例程链接
https://gitee.com/wiznet-hk/example-of-w6100-evb-pico.gitwireshark抓包工具下载链接
https://www.wireshark.org/download.html
相关文章:
W6100-EVB-PICO作为TCP Client 进行数据回环测试(五)
前言 上一章我们用W6100-EVB-PICO开发板通过DNS解析www.baidu.com(百度域名)成功得到其IP地址,那么本章我们将用我们的开发板作为客户端去连接服务器,并做数据回环测试:收到服务器发送的数据,并回传给服务器…...
emqx-5.1.4开源版使用记录
emqx-5.1.4开源版使用记录 windows系统安装eqmx 去官网下载 emqx-5.1.4-windows-amd64.zip,然后找个目录解压 进入bin目录,执行命令启动emqx 执行命令 emqx.cmd start使用emqx 访问内置的web管理页面 浏览器访问地址 http://localhost:18083/#/dashboard/overv…...
Java 线程池的原理与实现
最近在学习线程池、内存控制等关于提高程序运行性能方面的编程技术,线程池就是其中之一,一提到线程,我们会想到以前《操作系统》的生产者与消费者,信号量,同步控制等等。一提到池,我们会想到数据库连接池,但是线程池又如何呢?建议:在阅读本文前,先理一理同步的知识,…...
【idea】点击idea启动没反应
RT 点击idea启动的时候没反应,接着百度报错,基本跟他们的也不一样。 首先我是做版本升级。其次,我之前是破解的。如果你也是跟我一样的话,那问题可能就处在破解上了 解决方式 首先,是跟大部分解决思路一样。先找到项…...
C# Atrribute和反射的简单例子
Attribute 需要以Attribute 结尾, 并继承Attribute namespace AttributeTest {public class HeroAttribute : Attribute{} }namespace AttributeTest {public class SkillAttribute : Attribute{} }namespace AttributeTest {[Hero]public class Blademaster{[Skill]public vo…...
ASP.NET Core - 缓存之分布式缓存
分布式缓存是由多个应用服务器共享的缓存,通常作为访问它的应用服务器的外部服务进行维护。 分布式缓存可以提高 ASP.NET Core 应用的性能和可伸缩性,尤其是当应用由云服务或服务器场托管时。 与其他将缓存数据存储在单个应用服务器上的缓存方案相比&am…...
代理模式(C++)
定义 为其他对象提供一种代理以控制(隔离,使用接口)对这个对象的访问。。 应用场景 在面向对象系统中,有些对象由于某种原因(比如对象创建的开销很大,或者某些操作需要安全控制,或者需要进程外的访问等)直接访问会给使用者、或…...
C# 有效的字母异位词
242 有效的字母异位词 给定两个字符串 和 ,编写一个函数来判断 是否是 的字母异位词。stts 注意:若 和 中每个字符出现的次数都相同,则称 和 互为字母异位词。stst 示例 1: 输入: s “anagram”, t “nagaram” 输出: true 示例 2: 输…...
R语言安装包Seurat
环境Ubuntu22,R4.1 also installing the dependencies ‘curl’, ‘openssl’, ‘httr’, ‘plotly’ R包安装的时候报了这个错误ERROR: dependencies httr, plotly are not available for package Seurat 解决方法,退出R,在terminal中键入…...
vue2中使用mixins(混入)和vue3中使用composable
文章目录 一、mixins混入1、 新建mixins文件夹,新建myMixins.js2、myMixins.js 文件3、index.vue 文件(要使用的文件) mixins 总结二、composable(组合式api composition )1、 新建composables文件夹,新建useEdit.js2、useEdit.js…...
通过OpenTelemetry上报Python-flask应用数据(阿里云)
参考文档 https://help.aliyun.com/document_detail/611711.html?spma2c4g.90499.0.0.34a056ddTu2WWq 先按照 方法一:手动埋点上报Python应用数据 步骤测试上报是否正常。 flas 上报 在 手动埋点上报Python应用数据 的基础上,上报flask应用的数据&#…...
使用node搭建服务器,前端自己写接口,将vue或react打包后生成的dist目录在本地运行
使用node.jsexpress或者使用node.jspm2搭建服务器,将vue或react打包后生成的dist目录在本地运行 vue项目打包后生成的dist目录如果直接在本地打开index.html,在浏览器中会报错,无法运行起来。 通常我是放到后端搭建的服务上面去运行,当时前端…...
一篇文章搞懂如何使用JDBC操作数据库,还有JDBC进阶操作
目录 简介什么是JDBC如何使用JDBC1、获取连接2、操作数据3、关闭连接,释放资源使用技巧 查询操作创建表,插入模拟数据使用Java查询数据的数据SQL注入问题使用PreparedStatement查询 更新操作插入插入并获取主键更新删除 JDBC事务JDBC的批量操作JDBC连接池…...
9.3.2.1网络原理(UDP)
1.UDP的基本特点:无连接,不可靠传输,面向数据报,全双工. 2.1~1024的端口号有特定的含义,不建议使用.比如21:ftp,22:ssh,80:http,443:https. 3.CRC校验算法:循环冗余校验和,把UDP报中的每个字节都依次进行累加,把累加的结果,放到两个字节的变量中,溢出也无所谓,因为都加了一遍.…...
21、stm32使用LTDC驱动LCD
注:本文基于stm32使用FMC驱动SDRAM(IS42S32800G-6BLI)工程继续开发 本例使用安富莱的H743XIH板子驱动LTDC点亮7寸LCD 硬件接线:RGB888 一、cubemx配置 1、LTDC配置 注意此引脚应于上面的硬件接线图一致 2、配置DMA2D 3、背光引脚和触摸引脚 4、时钟…...
合并两个有序链表
就像一个贪吃蛇将两个链表一一的吃进来 class Solution(object):def mergeTwoLists(self, list1, list2):""":type list1: Optional[ListNode]:type list2: Optional[ListNode]:rtype: Optional[ListNode]"""p ListNode(0)cur pwhile list1 a…...
深入了解Unity的Physics类:一份详细的技术指南(七)(上篇)
前言 Unity的Physics类是Unity物理系统的核心,提供了一套用于处理和控制物理模拟的API。这个类提供了用于控制物理系统的全局属性和方法,以及检测和施加力到游戏对象,处理碰撞和触发器事件等。为了让开发者都能更好理解这个Physics类&#x…...
数据结构与算法-数组(附阿里面试题)
一 面试经典: 给你一个文件里面包含全国人民(14亿)的年龄数据(0~180),现在要你统计每一个年龄 有多少人? 给定机器为 单台2CPU2G内存。不得使用现成的容器,比如map等。&am…...
k8s集群网络插件搭建——————解决集群notready(k8s1.20版本,docker24)
前面已经提到,在初始化 k8s-master 时并没有网络相关配置,所以无法跟 node 节点通信,因此状态都是“NotReady”。但是通过 kubeadm join 加入的 node 节点已经在k8s-master 上可以看到。 那么,这个时候我们该怎么办呢?…...
有血有肉的PPT
1、PPT是Powerpoint缩写 2、引申的含义是Powerpoint Power(力量/能量) Point(观点/要点) 3、用PPT做的文档是讲演稿,讲演的内容要有力度,之所以要去演讲是为了能够影响受众 4、其次演讲稿上的内容要列出要点、表明观点,所以一般P…...
FPGA上FFT IP核配置避坑指南:从Streaming模式选择到sink_sop时序调试
FPGA上FFT IP核配置避坑指南:从Streaming模式选择到sink_sop时序调试 当你在Vivado或Quartus中拖拽FFT IP核时,可能以为这只是一个简单的配置过程。但现实往往比想象残酷——我曾在一个项目中因为sink_sop信号错位导致频谱完全失真,花了整整三…...
一张“网”如何拯救生命?浅谈医疗系统集成平台iPaaS
2026年2月,一项覆盖12家美国医院的队列研究发表于《BMJ Quality & Safety》,揭示了一个令人警醒的事实:当一名住院患者的医疗档案被系统重复创建时,其院内死亡风险飙升近5倍,入住重症监护室的概率增加3.5倍&#x…...
暗黑破坏神2重生记:用d2dx让20年老游戏焕发现代光彩
暗黑破坏神2重生记:用d2dx让20年老游戏焕发现代光彩 【免费下载链接】d2dx D2DX is a complete solution to make Diablo II run well on modern PCs, with high fps and better resolutions. 项目地址: https://gitcode.com/gh_mirrors/d2/d2dx 还在为经典《…...
别急着换Ubuntu!在Fedora上搞定U-Boot交叉编译的‘multiple definition of yylloc‘报错
在Fedora上根治U-Boot交叉编译的yylloc多重定义错误 当你在Fedora 35或更高版本上交叉编译较旧版本的U-Boot时,可能会遇到一个令人头疼的错误:"multiple definition of yylloc"。这个错误通常出现在编译dtc(设备树编译器࿰…...
从.NET 8到.NET 10预览版:C# 14 AOT编译Dify客户端的3次架构跃迁,第3次将彻底淘汰MSI安装包
第一章:C# 14 原生 AOT 部署 Dify 客户端 2026 最新趋势C# 14 正式引入对原生 AOT(Ahead-of-Time)编译的深度集成支持,结合 .NET 9 的跨平台运行时优化,为构建轻量、安全、启动极速的 Dify 客户端提供了全新范式。Dify…...
《RocketMQ实战与进阶》08 结合实际场景顺序消费、消息过滤实战
顺序消费 业务场景描述 现在开发一个银行类项目,对用户的每一笔余额变更都需要发送短信通知到用户。如果用户同时在电商平台下单,转账两个渠道在同一时间进行了余额变更,此时用户收到的短信必须顺序的,例如先网上购物,…...
OAK-D vs OAK-D-Lite怎么选?从项目需求出发,聊聊我的选购心得和避坑指南
OAK-D vs OAK-D-Lite实战选型指南:从参数表到真实项目落地的深度解析 当你在机器人导航系统中需要精准的深度感知,或在AR/VR项目中追求轻量化的3D视觉方案时,OAK-D和OAK-D-Lite这两款明星产品总会同时出现在选购清单上。作为深度参与过仓储机…...
[1]锁相环 PLL 几个版本的matlab相位噪声拟合仿真代码,质量杠杠的,都是好东西
[1]锁相环 PLL 几个版本的matlab相位噪声拟合仿真代码,质量杠杠的,都是好东西 [2]锁相环matlab建模稳定性仿真,好几个版本 [3]锁相环2.4G小数分频 simulink建模仿真最近在折腾锁相环设计,发现手头这几个版本的Matlab相位噪声拟合…...
基于YOLOv26深度学习算法的社区流浪动物检测系统研究与实现
文章目录 基于YOLOv26深度学习算法的社区流浪动物检测系统研究与实现 一、研究背景和意义 二、相关技术介绍 2.1 流浪动物管理现状 2.2 YOLOv26目标检测算法 2.3 动物跟踪技术 三、基于YOLOv26的社区流浪动物检测算法研究实现方法 3.1 系统架构设计 3.2 数据集构建 3.3 动物检测…...
3D Tiles Tools实战指南:从GLB到B3DM的格式转换与批量处理技术
3D Tiles Tools实战指南:从GLB到B3DM的格式转换与批量处理技术 【免费下载链接】3d-tiles-tools 项目地址: https://gitcode.com/gh_mirrors/3d/3d-tiles-tools 在3D地理空间数据可视化领域,3D Tiles Tools项目提供了强大的格式转换能力…...
