Toggle navigation
首页
问答
文章
积分商城
专家
专区
更多专区...
文档中心
返回主站
搜索
提问
会员
中心
登录
注册
AT
使用at client功能 接收响应时显示堆栈溢出(新手请教)
发布于 2019-01-10 18:30:16 浏览:2140
订阅该版
本人新手,使用AT组件开发移远BC95模块。串口发送正常,接收时finsh打印出thread heap stack overflow,和所有线程都挂起的信息。 不知道是哪里出了问题,是有地方没有配置还是程序本身问题?请指教,以下为程序源码: static void bc95_init_thread_entry(void *parameter) { #define CIMI_RETRY 10 #define CSQ_RETRY 10 #define CRGE_RETRY 10 #define CGREG_RETRY 20 at_response_t resp = RT_NULL; rt_err_t result = RT_EOK; int i; char parsed_data[10]; resp = at_create_resp(128, 0, rt_tick_from_millisecond(300)); if(!resp) { LOG_E("No memory for response structure!"); result = -RT_ENOMEM; goto __exit; } LOG_D("Start initializing the BC95 module"); /*wait BC95 starup finish*/ if(at_client_wait_connect(BC95_WAIT_CONNECT_TIME)) { result = -RT_ETIMEOUT; goto __exit; } /* disable echo */ AT_SEND_CMD(resp, 300, "ATE0"); /* get module version */ AT_SEND_CMD(resp, 300, "ATI"); /* show module version */ for (i = 0; i < (int) resp->line_counts - 1; i++) { LOG_D("%s", at_resp_get_line(resp, i + 1)); } /* check SIM card */ for (i = 0; i < CIMI_RETRY; i++) { at_exec_cmd(at_resp_set_info(resp, 128, 2, rt_tick_from_millisecond(5000)), "AT+CIMI"); if (at_resp_get_line_by_kw(resp, "OK")) { LOG_D("USIM card detection success"); break; } rt_thread_delay(rt_tick_from_millisecond(1000)); } if (i == CIMI_RETRY) { LOG_E("USIM card detection failed!"); result = -RT_ERROR; goto __exit; } /*waiting for dirty data to be digested*/ rt_thread_delay(rt_tick_from_millisecond(10)); /*check signal strength*/ for (i=0; i < CSQ_RETRY; i++) { AT_SEND_CMD(resp, 300, "AT+CSQ"); at_resp_parse_line_args_by_kw(resp, "+CSQ:", "+CSQ: %s", &parsed_data); if (strncmp(parsed_data, "99,99", sizeof(parsed_data))) { LOG_D("Signal strength: %s", parsed_data); break; } rt_thread_delay(rt_tick_from_millisecond(1000)); } if (i == CSQ_RETRY) { LOG_E("Signal strength check faild"); result = -RT_ERROR; goto __exit; } AT_SEND_CMD(resp, 300, "AT+CFUN=1"); AT_SEND_CMD(resp, 300, "AT+NCONFIG=AUTOCONNECT,TRUE"); AT_SEND_CMD(resp, 300, "AT+CGATT=1"); AT_SEND_CMD(resp, 300, "AT+CSCON=1"); AT_SEND_CMD(resp, 300, "AT+NCDP=180.101.147.115"); AT_SEND_CMD(resp, 300, "AT+NSMI=1"); AT_SEND_CMD(resp, 300, "AT+NNMI=1"); __exit: if (resp) { at_delete_resp(resp); } if (!result) { LOG_I("AT bc95 initialize success!"); } else { LOG_E("AT bc95 initialize failed (%d)!", result); } } int bc95_net_init(void) { /* initialize AT client */ at_client_init(AT_DEVICE_NAME, AT_DEVICE_RECV_BUFF_LEN); /* register URC data execution function */ at_set_urc_table(urc_table, sizeof(urc_table) / sizeof(urc_table[0])); bc95_init_thread_entry(RT_NULL); return RT_EOK; } int bc95_send_data(int data) { at_response_t resp = RT_NULL; rt_err_t result = RT_EOK; char SensorData[20]; sprintf(&SensorData[0],"%012x",(int)data); resp = at_create_resp(128, 0, rt_tick_from_millisecond(300)); if (!resp) { LOG_E("No memory for response structure!"); result = -RT_ENOMEM; goto __exit; } result = at_exec_cmd(resp, "AT+NMGS=7,00%s", SensorData); if (result != RT_EOK) { LOG_E("BC95 send commands failed or return response error!"); goto __exit; } /*print response line buffer*/ { const char *line_buffer = RT_NULL; LOG_D("Response buffer"); for(rt_size_t line_num = 1;line_num <= resp->line_counts; line_num++) { if((line_buffer = at_resp_get_line(resp, line_num)) !=RT_NULL) { LOG_D("line %d buffer : %s", line_num, line_buffer); } else { LOG_E("Parse line buffer error!"); } } } __exit: if (resp) { at_delete_resp(resp); } return result; }
查看更多
1
个回答
默认排序
按发布时间排序
yqiu
2019-01-11
这家伙很懒,什么也没写!
thread heap stack overflow 这个提示是线程栈溢出了,可以看下是否是哪个线程栈设置小了。
撰写答案
登录
注册新账号
关注者
0
被浏览
2.1k
关于作者
村长66
这家伙很懒,什么也没写!
提问
2
回答
0
被采纳
0
关注TA
发私信
相关问题
1
rt-thread 2g/3g/4g通信模块的教程有吗?
2
基于AT指令,用esp8266如何连接mqtt?
3
AT组件使用问题
4
官方AT客户端应用笔记的几个小tip
5
RTT的SAL能够判断使用LWIP或者AT?
6
rt_therad AT组件移植不成功(结贴)
7
AT组件在哪个版本的?
8
AT组件 连接 Onenet 连接失败
9
esp8266 AT指令 MQTT连接问题
10
AT组件使用问题之模块主动上报【已解决】
推荐文章
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
STM32G030移植RT-Thread
2
CubeMX & RT-Thread Studio 联合开发说明
3
RT-Thread动态模块
4
RT-Thread项目助手v0.3 | Ubuntu与MacOS平台的RT-Thread Env
5
【FRA156测评DM-MCX】- 环境配置篇
热门标签
RT-Thread Studio
串口
Env
LWIP
SPI
AT
Bootloader
Hardfault
CAN总线
FinSH
ART-Pi
USB
DMA
文件系统
RT-Thread
SCons
RT-Thread Nano
线程
MQTT
STM32
rt-smart
RTC
FAL
I2C_IIC
ESP8266
UART
cubemx
WIZnet_W5500
ota在线升级
PWM
BSP
flash
freemodbus
packages_软件包
潘多拉开发板_Pandora
GD32
定时器
ADC
flashDB
编译报错
socket
中断
rt_mq_消息队列_msg_queue
Debug
keil_MDK
SFUD
msh
ulog
C++_cpp
MicroPython
本月问答贡献
lchnu
3
个答案
2
次被采纳
张世争
1
个答案
2
次被采纳
a1012112796
9
个答案
1
次被采纳
三世执戟
8
个答案
1
次被采纳
聚散无由
5
个答案
1
次被采纳
本月文章贡献
jinchanchan
9
篇文章
13
次点赞
ssdd45555
3
篇文章
2
次点赞
聚散无由
1
篇文章
4
次点赞
hywing
1
篇文章
1
次点赞
rvcore
1
篇文章
1
次点赞
回到
顶部
发布
问题
分享
好友
手机
浏览
扫码手机浏览
投诉
建议
回到
底部