Toggle navigation
首页
问答
文章
积分商城
专家
专区
更多专区...
文档中心
返回主站
搜索
提问
会员
中心
登录
注册
4G模块
AT组件
AT组件中的at_resp_parse_line_args_by_kw解析异常
发布于 2022-06-16 10:15:25 浏览:1145
订阅该版
硬件配置:GD32F450+EC200S 问题现象:**偶现**设备连不上网 日志分析:发现设备是卡在联网解析的一个步骤中,后续加入部分日志,定位为at_resp_parse_line_args_by_kw函数解析存在异常 问题是偶现的,正常也能解析出来,这个是偶发的就不行了的 具体问题是正常按照这个函数应该解析出来的结果link_stat应该是等于1, ```c at_resp_parse_line_args_by_kw(commu_4g_at_resp, "+CGREG:", "+CGREG: %d,%d", &link_stat_n, &link_stat) ``` 但是日志却显示出来解析的结果是0 ````c if (at_obj_exec_cmd(ec200s_data.client, commu_4g_at_resp, "AT+CGREG?\r\n") == RT_EOK) { rt_kprintf("AT+CGREG? send OK\r\n"); for (i = 0; i < (int) commu_4g_at_resp->line_counts; i++) { rt_kprintf("AT+CGREG? rec line(%d):%s", (i + 1), at_resp_get_line(commu_4g_at_resp, i + 1)); } link_stat = 0; if (at_resp_parse_line_args_by_kw(commu_4g_at_resp, "+CGREG:", "+CGREG: %d,%d", &link_stat_n, &link_stat)>0) { rt_kprintf("AT+CGREG? link_stat:(%d)\r\n",link_stat); if ((link_stat == 1) || (link_stat == 5)) { // LOG_D("device GPRS is registered"); break; } } else { rt_kprintf("AT+CGREG? process err\r\n"); } } else { rt_kprintf("AT+CGREG? send err\r\n"); } ```` 日志现象如下 ``` AT+CGREG? send OK AT+CGREG? rec line(1): AT+CGREG? rec line(2):+CGREG: 0,1 AT+CGREG? rec line(3): AT+CGREG? rec line(4):OK AT+CGREG? link_stat:(0) AT+CGREG? send OK AT+CGREG? rec line(1): AT+CGREG? rec line(2):+CGREG: 0,1 AT+CGREG? rec line(3): AT+CGREG? rec line(4):OK AT+CGREG? link_stat:(0) ```
查看更多
swet123
2022-06-19
ztlchina@foxmail.com
按照经验来讲, 有几种可能性: 1)CGREG 检查在一个定时器里, 他的返回结果和你在其他线程(atclient) 发送的指令混在一起,造成解析错误。 2)接收数据出错。 解决方案: 一次解析为0, 不要认为断网, 连续5次或者其他次数再认为是断网。 或者,将解析为0的时候的接收到的数据打印出来,排查一下。
3
个回答
默认排序
按发布时间排序
红枫
认证专家
2022-06-17
这家伙很懒,什么也没写!
### 参考这个试试: ```c int link_stat = 0; if (at_resp_parse_line_args_by_kw(resp, "+CGREG:", "+CGREG: %*d,%d", &link_stat) > 0) { if (link_stat == 1 || link_stat == 5) { result = RT_EOK; } } ```
crystal266
2022-06-16
嵌入式
看结果 `+CGREG: 0,1` 结果中的
等于 1 或者 5,表示模块已在 UMTS/LTE 网络注册上PS业务,应该是已经注册网络了。 另外直接开启下面两个选项,可以看到具体的手法过程中的AT指令,就不用自己写代码来打印相关的日志了。 ![微信图片_20220616151216.png](https://oss-club.rt-thread.org/uploads/20220616/a1e6591d92cce4bb5608e1902684d465.png.webp "微信图片_20220616151216.png")
撰写答案
登录
注册新账号
关注者
0
被浏览
1.1k
关于作者
wndjinguoguo
这家伙很懒,什么也没写!
提问
3
回答
2
被采纳
0
关注TA
发私信
相关问题
1
关于AT组件移植到裸机,uart部分和轮询解析如何处理?
2
AT组件开启之后有报错
3
rt-thread studio 添加了AT Device组件后,编译报错
4
使用AT组件的时候,使用一个客户端,却提醒我创建一个客户端,该怎么创建客户端呢
5
AT组件设置接收符不起作用
6
AT组件遇到\r\n后是怎么处理数据的?
7
AT组件启动流程是怎么样的?
8
AT组件和MQTT组件的使用问题
9
中移M5311软件包使用问题
10
关于AT组件的URC数据处理问题
推荐文章
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
UART
ota在线升级
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
篇文章
3
次点赞
ThinkCode
1
篇文章
1
次点赞
Betrayer
1
篇文章
1
次点赞
回到
顶部
发布
问题
分享
好友
手机
浏览
扫码手机浏览
投诉
建议
回到
底部