Toggle navigation
首页
问答
文章
积分商城
专家
专区
更多专区...
文档中心
返回主站
搜索
提问
会员
中心
登录
注册
Network
WIZnet_W5500
由wiznet引发的ISR (660)行错误,已解决
发布于 2020-04-25 16:18:09 浏览:2126
订阅该版
[tocm] ## 现象发现的过程 W5500使用的网线是由路由器的LAN网口接出,测试的时候将路由器上的WLAN网口拔掉2s左右控制台不能输入,30秒左右后出现了以下错误。 ``` Function[rt_mutex_take]shall not be used in ISR (0)assertion failed at function:rt_mutex_take, line number:660 ``` 推测控制台不能输入应该是停在在wiz线程中的某个while中 跳转不出来。 之后将断言中的`while(dummy == 0)`给屏蔽掉。 再次重现异常,打印了后续的错误信息 ``` Function[rt_mutex_take]shall not be used in ISR(0) assertionfailed at function:rt_mutex_take, line number:660 Function[rt_mutex_release]shall not be used in ISR(0) assertion failed atfunction:rt_mutex_release, line number:803 04-25 15:53:18 W/UART:Warning: There is no enough buffer for saving data, please increase theRT_SERIAL_RB_BUFSZ opt ``` 用断点调试之后出乎意料的发现rt_mutex_take是由i2c调用的,我i2c在工作的器件只有ds2312,使用了ds2312软件包来代替系统的rtc。 进一步调试,发现是此时串口一直在接收数据,缓冲区超过设定的大小,输出警告的时间戳时会调用i2c去读取ds2312的时间。 由于我连接了阿里云,一直在上报信息,(不上报数据时不会出现此问题, 不过阿里云心跳消息上报时也会出现此状况,发生这个异常只是时间问题)。所以很快的出现了此问题,进一步跟踪错误发现在发送数据时进入了`wizchip_socket.c` 的 394行 这个`while(1)`中,将tmp参数打印出来之后发现, 正常情况下tmp的值为23 也就是SOCK_ESTABLISHED的值0x17,频率在1秒3次左右,拔掉WLAN网口的网线时就一直在输出tmp = 23, 30s左右tmp的值才变成0, 之后跳出这个while(1),然后就会立刻触发这个异常。 ## 解决办法 1. 如果W5500能检测到网口拔掉的话就能避免这个问题,但是没有研究过W5500 不知道能不能实现,不过rtt至今没有实现,猜想W5500的硬件是没有这个功能的。 2. 既然如此就暂时弄个解决办法,在这个while里加入超时检测。 再次试验,没有再触发这个异常,猜想:这里是系统获取时间调用了i2c去读取ds2312发生的错误,那么当用户的线程优先级高于wiz这个线程时,去调用i2c或者spi时也会发生此类错误。
查看更多
4
个回答
默认排序
按发布时间排序
HelloBye
2020-04-25
这家伙很懒,什么也没写!
图片被吃了 这里补上
aozima
2020-04-25
调网络不抓包,调I2C等时序不上逻辑分析仪,就像电工不用万用表!多用整理的好的文字,比截图更省流量,还能在整理过程中思考。
感谢分享
s453209
2022-05-18
为线程而生
将tshell进程的优先级调高一些,不会出现控制台不能输入的情况
DAIXIANSHENG666
2023-03-02
这家伙很懒,什么也没写!
w5500可以检测到网线断开, ![W5500.png](https://oss-club.rt-thread.org/uploads/20230302/1efe6a02f2948316d10a666d2126d65b.png.webp)
撰写答案
登录
注册新账号
关注者
0
被浏览
2.1k
关于作者
HelloBye
这家伙很懒,什么也没写!
提问
8
回答
33
被采纳
1
关注TA
发私信
相关问题
1
lwip1.4.1连接经常会断开无法连接上,可以ping通
2
LPC1768:RTT+LWIP+webserver用IE刷网页出现硬件中断错误(已经解决)
3
求一些LWIP开发的经验,目前ping一直不稳定。
4
stm32f207+dp83848无法ping通
5
RTT下的LWIP传递机制
6
rtt内lwip的socket是否是线程安全?
7
Lwip+enc28j60无法ping通
8
坑爹的rtconfig.h lwip关掉了checksum
9
花了一个晚上,把RT2.0的LWIP、网卡驱动、文件系统整合起来了,发现一点小问题
10
lwip例程中udp发送时如何指定源端口发送到指定目的地端口
推荐文章
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
使用百度AI助手辅助编写一个rt-thread下的ONVIF设备发现功能的功能代码
2
RT-Thread 发布 EtherKit开源以太网硬件!
3
rt-thread使用cherryusb实现虚拟串口
4
《C++20 图形界面程序:速度与渲染效率的双重优化秘籍》
5
《原子操作:程序世界里的“最小魔法单位”解析》
热门标签
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
WIZnet_W5500
ota在线升级
UART
PWM
cubemx
freemodbus
flash
packages_软件包
BSP
潘多拉开发板_Pandora
定时器
ADC
GD32
flashDB
socket
中断
Debug
编译报错
msh
SFUD
keil_MDK
rt_mq_消息队列_msg_queue
at_device
ulog
C++_cpp
本月问答贡献
踩姑娘的小蘑菇
7
个答案
3
次被采纳
a1012112796
13
个答案
2
次被采纳
张世争
9
个答案
2
次被采纳
rv666
5
个答案
2
次被采纳
用户名由3_15位
11
个答案
1
次被采纳
本月文章贡献
程序员阿伟
7
篇文章
2
次点赞
hhart
3
篇文章
4
次点赞
大龄码农
1
篇文章
2
次点赞
ThinkCode
1
篇文章
1
次点赞
Betrayer
1
篇文章
1
次点赞
回到
顶部
发布
问题
分享
好友
手机
浏览
扫码手机浏览
投诉
建议
回到
底部