Toggle navigation
首页
问答
文章
积分商城
专家
专区
更多专区...
文档中心
返回主站
搜索
提问
会员
中心
登录
注册
WIZnet_W5500
bug: W5500 发送超时中断响应 却未清除中断标志,导致重连后无法接收数据
发布于 2022-04-22 16:58:59 浏览:4007
订阅该版
[tocm] ### 主要是用于 电脑端网线 掉线检测 **测试条件**: 1. 使用的时tcp server 非阻塞的方式进行收发 和 主动发送 的 参考的文章:[多线程非阻塞网络编程](https://www.rt-thread.org/document/site/#/rt-thread-version/rt-thread-standard/application-note/components/network/an0019-tcpclient-socket) 只不过我改成了tcp server 模式 **2. 设置超时时间** W5500即使不设置,也存在一个初始的超时时间,手册里写的200ms,但我读取测试发现是2s (本来想用 setsockopt 进行设置,发现没有效果,应该是没适配W5500,所以这里采用直接设置 W5500里的超时寄存器) ![setRTR.png](https://oss-club.rt-thread.org/uploads/20220422/e8df13d65659ea7787c1e6969a9accc7.png) ![fd61503c0184008c06246f4601dba5ff.png.webp](https://oss-club.rt-thread.org/uploads/20220422/fd61503c0184008c06246f4601dba5ff.png.webp) **3. 设置一个单独线程,用于主动发送数据到客户端** ``` static void tcpserv_send(void *arg) { RT_ASSERT(arg); rt_netfd_t* thiz = arg; rt_uint16_t len; char send_buf[256]; while(1) { rt_sprintf(send_buf, "RTR:%d, RCT:%d", getRTR(), getRCR()); len = rt_strlen(send_buf); write(thiz->pipe_send_fd[1], send_buf, len); rt_thread_mdelay(1000); } } ``` **bug情景再现:** 1. 第一阶段,测试的是手动关闭socket,重连后连接正常,通讯都正常 2. 第二阶段,测试的是电脑端网线拔掉后2s内接回,结果同上 3. 第三阶段,测试的是电脑端网线拔掉后 直到W5500 自动关闭socket,结果发现重连后 W5500能往外发送数据,却无法接收数据,且任何中断不响应了。 ![问题排查.gif](https://oss-club.rt-thread.org/uploads/20220422/0db4276939c9a0bca7631353665fc800.gif) 手册中断说明: ![IR.png](https://oss-club.rt-thread.org/uploads/20220422/bf2271868d97dd0152c485ff79d9eef8.png) 这里结果很明显了,应该是响应了发送超时中断,却未进行清除,导致所有中断都无法响应了 **解决办法:** 在发送的过程中如果检测到了 socket关闭,还需增加:判断一下是否是发送超时,是的话清零 ![解决办法.png](https://oss-club.rt-thread.org/uploads/20220422/ef40998563cb14348827bee7ef043500.png) 再次实验: 所有情况都正常,且能实现电脑端的网线 掉线检测
查看更多
2
个回答
默认排序
按发布时间排序
出出啊
2022-04-22
恃人不如自恃,人之为己者不如己之自为也
👍
donglai
2022-12-30
这家伙很懒,什么也没写!
IR和Sn_IR是两个寄存器。
撰写答案
登录
注册新账号
关注者
0
被浏览
4k
关于作者
aingsu
这家伙很懒,什么也没写!
提问
5
回答
3
被采纳
0
关注TA
发私信
相关问题
1
W5500软件包开机无法解析link.rt-thread.org
2
W5500 如何实现断开重连?
3
W5500初始化全部都OK,电脑能ping板子,板子ping不通电脑
4
w5500 编译错误
5
求个SPI上挂W5500、Max6675两个设备的驱动例子
6
TFTP与W5500配合能传文件但无内容
7
wiznet(W5500) 设置MAC
8
SPI总线挂接2个W5500以太网芯片
9
多网卡建立链路问题,求官方解答
10
为什么W5500一直显示无法挂载
推荐文章
1
RT-Thread应用项目汇总
2
玩转RT-Thread系列教程
3
国产MCU移植系列教程汇总,欢迎查看!
4
机器人操作系统 (ROS2) 和 RT-Thread 通信
5
五分钟玩转RT-Thread新社区
6
【技术三千问】之《玩转ART-Pi》,看这篇就够了!干货汇总
7
关于STM32H7开发板上使用SDIO接口驱动SD卡挂载文件系统的问题总结
8
STM32的“GPU”——DMA2D实例详解
9
RT-Thread隐藏的宝藏之completion
10
【ART-PI】RT-Thread 开启RTC 与 Alarm组件
最新文章
1
RT Thread 源码分析笔记 :线程和调度器
2
RT-Thread项目助手v0.2.0 - 支持Env Windows
3
RttreadV5.10上,GD32F450Z RTC时间显示问题
4
rt-smart启动流程分析
5
EtherKit快速上手PROFINET
热门标签
RT-Thread Studio
串口
Env
LWIP
SPI
AT
Bootloader
Hardfault
CAN总线
FinSH
ART-Pi
USB
DMA
文件系统
RT-Thread
SCons
RT-Thread Nano
线程
MQTT
STM32
RTC
FAL
rt-smart
ESP8266
I2C_IIC
UART
WIZnet_W5500
ota在线升级
PWM
cubemx
flash
freemodbus
BSP
packages_软件包
潘多拉开发板_Pandora
定时器
ADC
flashDB
GD32
socket
编译报错
中断
Debug
rt_mq_消息队列_msg_queue
SFUD
msh
keil_MDK
ulog
MicroPython
C++_cpp
本月问答贡献
出出啊
1517
个答案
342
次被采纳
小小李sunny
1444
个答案
290
次被采纳
张世争
813
个答案
177
次被采纳
crystal266
547
个答案
161
次被采纳
whj467467222
1222
个答案
149
次被采纳
本月文章贡献
出出啊
1
篇文章
2
次点赞
小小李sunny
1
篇文章
1
次点赞
张世争
1
篇文章
3
次点赞
crystal266
2
篇文章
2
次点赞
whj467467222
2
篇文章
2
次点赞
回到
顶部
发布
问题
分享
好友
手机
浏览
扫码手机浏览
投诉
建议
回到
底部