Toggle navigation
首页
问答
文章
积分商城
专家
专区
更多专区...
文档中心
返回主站
搜索
提问
会员
中心
登录
注册
at-device
sim800c
5
AT-DEVICE接收应答无效
发布于 2021-01-24 00:43:52 浏览:1044
订阅该版
RAW看到已经回了0, CONNECT OK... 为什么还是sim0 device socket(0) wait connect result timeout 怎么设置接收事件 ![2222.png](https://oss-club.rt-thread.org/uploads/20210124/b30fece4685804b61030d02397c86282.png) 已经注册 ``` static int sim800c_device_register(void) { return at_device_register(&(sim800c->device), sim800c->device_name, sim800c->client_name, AT_DEVICE_CLASS_SIM800C, (void *) sim800c); } INIT_APP_EXPORT(sim800c_device_register); ``` ``` if(sim800c->device.sockets->ops->at_connect(sim800c->device.sockets, "47.96.147.99", 18085,AT_SOCKET_TCP,1)==RT_EOK) { rt_kprintf("Socket create ok.\n"); } else{ rt_kprintf("Socket create failed.\n"); return -RT_ERROR; } ``` 我看sim800c_socket_connect里面是由SET_EVENT的 ``` static int sim800c_socket_connect(...) { .... __retry: /* clear socket connect event */ event = SET_EVENT(device_socket, SIM800C_EVENT_CONN_OK | SIM800C_EVENT_CONN_FAIL); sim800c_socket_event_recv(device, event, 0, RT_EVENT_FLAG_OR); } ```
查看更多
Juggernaut
2021-01-24
①②③
```c SET_EVENT(device_socket, SIM800C_EVENT_CONN_OK | SIM800C_EVENT_CONN_FAIL) ``` 无效吗
3
个回答
默认排序
按发布时间排序
xiangxistu
2021-01-24
这家伙很懒,什么也没写!
这种现象是偶发还是必现呢? 我看到这个 Connect 操作中插入了一条 ``` AT+CGREG? ```命令,这个命令是 TCP Connect 外的命令。 我怀疑是由于这条命令,导致接收超时了;后面看到了``` CONNECT OK ```的信息,可以尝试延时。 ```c /* waiting result event from AT URC, the device default connection timeout is 75 seconds, but it set to 10 seconds is convenient to use */ if (sim800c_socket_event_recv(device, SET_EVENT(device_socket, 0), 10 * RT_TICK_PER_SECOND, RT_EVENT_FLAG_OR) < 0) { LOG_E("%s device socket(%d) wait connect result timeout.", device->name, device_socket); result = -RT_ETIMEOUT; goto __exit; } ``` ``` /* waiting result event from AT URC, the device default connection timeout is 75 seconds, but it set to 10 seconds is convenient to use */ ```
armboy
2021-01-24
E-mail:730456@qq.com
改了链接的程序 ``` rt_mutex_take(sim800c->device.client->lock, RT_WAITING_FOREVER); if(sim800c->device.sockets->ops->at_connect(sim800c->device.sockets, "47.96.147.99", 18085,AT_SOCKET_TCP,1)==RT_EOK) { rt_kprintf("Socket create ok.\n"); } else{ rt_kprintf("Socket create failed.\n"); return -RT_ERROR; } rt_mutex_release(sim800c->device.client->lock); ``` 我调用的就是sim800下的 at_socket_sim800c.c 文件中的sim800c_socket_connect 结果: ![2222.png](https://oss-club.rt-thread.org/uploads/20210124/b9302e977be562dd8f84baee785f9253.png)
撰写答案
登录
注册新账号
关注者
0
被浏览
1k
关于作者
armboy
E-mail:730456@qq.com
提问
20
回答
18
被采纳
0
关注TA
发私信
相关问题
1
sim800c 为什么最后不用释放rt_free(recv_buf);
2
http_ota失败 可能是什么原因造成的
3
send 发送数据900个字节失败 发送600个字节可以
4
实在太难受了at_resp_parse_line_args_by_kw多一个\r
5
http_ota升级
6
http_ota详细了解
7
air720 at-device回复命令冲突
8
RT-THREAD settings添加新的at device设备
9
编译at-client报错
10
能否出一个 at client 适配教程
推荐文章
1
RT-Thread应用项目汇总
2
玩转RT-Thread系列教程
3
机器人操作系统 (ROS2) 和 RT-Thread 通信
4
五分钟玩转RT-Thread新社区
5
国产MCU移植系列教程汇总,欢迎查看!
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
FRDM-MCXN947 Flash实践--W25Q64
3
NXP MCXN947测评(一)开箱+环境配置
4
stm32f103的adc+dma多通道采集数据
5
NXP MCXN947测评之 I2C (硬件) 实践
热门标签
RT-Thread Studio
串口
LWIP
Env
SPI
Bootloader
AT
ART-Pi
CAN总线
Hardfault
FinSH
USB
文件系统
RT-Thread
DMA
SCons
线程
RT-Thread Nano
MQTT
STM32
RTC
FAL
rt-smart
ESP8266
WIZnet_W5500
ota在线升级
cubemx
I2C
flash
UART
packages_软件包
freemodbus
潘多拉开发板_Pandora
PWM
定时器
BSP
ADC
keil_MDK
socket
中断
编译报错
MicroPython
GD32
Debug
ulog
SDIO总线
msh
rt_mq_消息队列_msg_queue
C++_cpp
SFUD
本月问答贡献
xiaorui
20
个答案
3
次被采纳
Juggernaut
12
个答案
3
次被采纳
踩姑娘的小蘑菇
12
个答案
2
次被采纳
小小李sunny
10
个答案
2
次被采纳
crystal266
4
个答案
2
次被采纳
本月文章贡献
ZVML_9668
4
篇文章
6
次点赞
Lu_盼盼
4
篇文章
3
次点赞
Z_Y
3
篇文章
5
次点赞
ThinkCode
2
篇文章
2
次点赞
oxlm
2
篇文章
1
次点赞
回到
顶部
发布
问题
分享
好友
手机
浏览
扫码手机浏览
投诉
建议
回到
底部