Toggle navigation
首页
问答
文章
积分商城
专家
专区
更多专区...
文档中心
返回主站
搜索
提问
会员
中心
登录
注册
RT-Thread一般讨论
AT ESP8266
发布于 2019-08-13 16:49:37 浏览:1823
订阅该版
Dear sir: 在K210 BSP调试AT client遇到TCP通讯时,挂死的情况,tcpclient代码见附件![tcpclient.c](/uploads/201908/13/164715kowzp7xvlks3wtk0.attach) 。 硬件上有运行指示灯闪烁,单独的线程控制,挂死时运行指示灯不闪了。 请问这怎么解决啊?log打了很多地方,未能找到原因! ![1565686010(1).jpg](https://oss-club.rt-thread.org/uploads/201908/13/164715ve6i906zgc9l909j.jpg)
查看更多
14
个回答
默认排序
按发布时间排序
Cheney_Chen
2019-08-13
这家伙很懒,什么也没写!
[i=s] 本帖最后由 Cheney_Chen 于 2019-8-13 17:37 编辑 [/i] 看了你的 tcpclient 应用代码,感觉写的有点奇怪,如下图所示,这里你使用了两个 select 分别处理接收和发送的事件,如果按这个逻辑这里需要先等待发送事件等不到之后再等待接收事件。按理说这里 select 完全可以同时处理发送和接收事件,至于你说的卡死的问题,你提供的日志有限,我觉你先理一下你的应用逻辑在考虑这块问题。 [attach]10107[/attach] 这块代码可以多参考 network-sample 软件包 select 例程文件 [https://github.com/RT-Thread-packages/network-sample/blob/master/tcpclient_select_sample.c](https://github.com/RT-Thread-packages/network-sample/blob/master/tcpclient_select_sample.c)
aichip_mac
2019-08-13
这家伙很懒,什么也没写!
>看了你的 tcpclient 应用代码,感觉写的有点奇怪,如下图所示,这里你使用了两个 select 分别处理接收和发 ... --- 这是模仿现有的业务逻辑特意为之,虽然不是最优的, 但是不是错的, 我来按照你说的最优方法测下
aichip_mac
2019-08-13
这家伙很懒,什么也没写!
[i=s] 本帖最后由 aichip_mac 于 2019-8-13 19:49 编辑 [/i] >看了你的 tcpclient 应用代码,感觉写的有点奇怪,如下图所示,这里你使用了两个 select 分别处理接收和发 ... --- 改成 最优的方式 还是会 hang住 while (is_running) { FD_ZERO(&wrset); FD_SET(sock, &wrset); FD_ZERO(&readset); FD_SET(sock, &readset); if(select(sock + 1, &readset, &wrset, RT_NULL, &timeout)>0) { if(FD_ISSET(sock,&wrset)) { int start = rt_tick_get(); ret = send(sock, send_data, rt_strlen(send_data), 0); printf("send cost tick is %d\n",rt_tick_get()-start); if (ret < 0) { /* 接收失败,关闭这个连接 */ LOG_I("send error, close the socket."); goto __exit; } else if (ret == 0) { /* 打印send函数返回值为0的警告信息 */ LOG_W("Send warning, send function return 0."); } } if(FD_ISSET(sock,&readset)) { bytes_received = recv(sock, recv_data, BUFSZ - 1, 0); if (bytes_received < 0) { /* 接收失败,关闭这个连接 */ LOG_E("Received error, close the socket."); goto __exit; } else if (bytes_received == 0) { /* 打印recv函数返回值为0的警告信息 */ LOG_W("Received warning, recv function return 0."); continue; } else { /* 有接收到数据,把末端清零 */ recv_data[bytes_received] = '\0'; if (rt_strcmp(recv_data, "q") == 0 || rt_strcmp(recv_data, "Q") == 0) { /* 如果是首字母是q或Q,关闭这个连接 */ LOG_I("Got a 'q' or 'Q', close the socket."); goto __exit; } else { /* 在控制终端显示收到的数据 */ LOG_D("Received data = %s", recv_data); } } } } rt_thread_delay(20); /* 发送数据到sock连接 */
Cheney_Chen
2019-08-13
这家伙很懒,什么也没写!
>改成 最优的方式 还是会 hang住 > > while (is_running) --- 现在你卡死在什么地方?调试确定一下具体卡死的位置,然后详细描述一下你的问题吧
aichip_mac
2019-08-13
这家伙很懒,什么也没写!
[i=s] 本帖最后由 aichip_mac 于 2019-8-13 19:52 编辑 [/i] >现在你卡死在什么地方?调试确定一下具体卡死的位置,然后详细描述一下你的问题吧 ... --- 就是没有好办法 知道卡死在哪个地方:'(
Cheney_Chen
2019-08-13
这家伙很懒,什么也没写!
[i=s] 本帖最后由 Cheney_Chen 于 2019-8-13 20:12 编辑 [/i] >就是没有好办法 知道卡死在哪个地方 --- 不是很明白你这里指的 “hang 住” 具体指什么意思,是 shell 挂起无法输入命令,还是 hard fail 或者断言这种问题。不用急着在 AT 底层打印这么多调试日志,先确定应用层问题出在哪步,再一步一步深入分析。还有这类纯软的代码完全可以在 QEMU 中运行,调试什么的都很方便。
aichip_mac
2019-08-13
这家伙很懒,什么也没写!
>不是很明白你这里指的 “hang 住” 具体指什么意思,是 shell 挂起无法输入命令,还是 hard fail 或者断言 ... --- 表象上是shell挂起 无法输入命令 我们有个最高优先级单独线程运行指示灯 然后指示灯也不闪了 不太清楚 是不是你说的几种之一
Cheney_Chen
2019-08-13
这家伙很懒,什么也没写!
>表象上是shell挂起 无法输入命令 我们有个最高优先级单独线程运行指示灯 然后指示灯也不闪了 不太清楚 ... --- 这时候 timeout 给的多少,改一下代码每次 select 返回值打印出来看看,然后在循环中加 10 ms 延时试试,我怀疑你应用层循环有问题
aichip_mac
2019-08-14
这家伙很懒,什么也没写!
[i=s] 本帖最后由 aichip_mac 于 2019-8-14 09:09 编辑 [/i] >这时候 timeout 给的多少,改一下代码每次 select 返回值打印出来看看,然后在循环中加 10 ms 延时试试, ... --- 见附件, 完整的tcpclient.c,timeout是10 ms, 每次循环延时20ms
Cheney_Chen
2019-08-14
这家伙很懒,什么也没写!
>见附件, 完整的tcpclient.c,timeout是10 ms, 每次循环延时20ms --- 我这边测试,IoT-Board 开发板,官方 BSP,at_device 软件包 2.0.0 版本,github 最新 RT-Thread 系统, 使用你提供的 tcpclient 例程测试半个小时左右,没出现你说的卡死问题。是不是你其他应用程序影响这块处理,你可以把例程单独拿出来测试,还有建议你使用最新版本系统和 at_device 软件包。
撰写答案
登录
注册新账号
关注者
0
被浏览
1.8k
关于作者
aichip-sai
这家伙很懒,什么也没写!
提问
14
回答
16
被采纳
0
关注TA
发私信
相关问题
1
有关动态模块加载的一篇论文
2
最近的调程序总结
3
晕掉了,这么久都不见layer2的踪影啊
4
继续K9ii的历程
5
[GUI相关] FreeType 2
6
[GUI相关]嵌入式系统中文输入法的设计
7
20081101 RT-Thread开发者聚会总结
8
嵌入式系统基础
9
linux2.4.19在at91rm9200 上的寄存器设置
10
[转]基于嵌入式Linux的通用触摸屏校准程序
推荐文章
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
次被采纳
本月文章贡献
聚散无由
2
篇文章
12
次点赞
Wade
2
篇文章
2
次点赞
xiaorui
1
篇文章
1
次点赞
zhuzhuzhu
1
篇文章
1
次点赞
catcatbing
1
篇文章
1
次点赞
回到
顶部
发布
问题
分享
好友
手机
浏览
扫码手机浏览
投诉
建议
回到
底部