Toggle navigation
首页
问答
文章
积分商城
专家
专区
更多专区...
文档中心
返回主站
搜索
提问
会员
中心
登录
注册
AT
启用AT Device Sim800C,模块上网后程序崩溃
发布于 2019-08-21 18:07:41 浏览:2190
订阅该版
rthread版本:v4.0.1 at device版本:v1.6.0 各配置如下图 ![TIM截图20190821180418.png](/uploads/201908/21/180459zxavx3azja7tjaal.png) ![TIM截图20190821180403.png](/uploads/201908/21/180454t0wevw0gxf01zggy.png) ![TIM截图20190821180327.png](/uploads/201908/21/180432h26s2vb0c353lb7w.png) 程序日志如下: \ | / - RT - Thread Operating System / | \ 4.0.1 build Aug 21 2019 2006 - 2019 Copyright by rt-thread team [I/sal.skt] Socket Abstraction Layer initialize success. [I/at.clnt] AT client(V1.2.0) on device uart1 initialize success. msh />[D/at.sim800c] Start initializing the SIM800C module [D/at.sim800c] [D/at.sim800c] SIM800 R14.18 [D/at.sim800c] [D/at.sim800c] SIM card detection success [D/at.sim800c] GSM network is registered (0,1) [D/at.sim800c] GPRS network is registered (0,1) [D/at.sim800c] Signal strength: 25,0 [I/at.sim800c] CHINA MOBILE [I/at.sim800c] AT network initialize success! [D/at.sim800c] SIM800C IEMI number: 864626049006478 [D/at.sim800c] SIM800C IP address: 10.60.48.211 [D/at.sim800c] SIM800C primary DNS server address: 211.136.17.107 [D/at.sim800c] SIM800C secondary DNS server address: 211.136.20.203 (rt_object_get_type((rt_object_t)thread) == psr: 0x0100000f r00: 0x20001e3c r01: 0x00000020 r02: 0x00000000 r03: 0x20001e3c r04: 0x00000000 r05: 0xdeadbeef r06: 0xdeadbeef r07: 0x20000738 r08: 0xdeadbeef r09: 0xdeadbeef r10: 0xdeadbeef r11: 0xdeadbeef r12: 0x00000007 lr: 0x08015559 pc: 0x08015484 hard fault on handler bus fault: SCB_CFSR_BFSR:0x04 IMPRECISERR 在获取到DNS服务器地址后就崩溃。 最初跑的时候,sim800c的线程(sim800c_init_thread_entry)还溢出了,我看其栈大小是1K,改成2K后不会溢出,不过就出现上述崩溃的问题。
查看更多
11
个回答
默认排序
按发布时间排序
WillianChan
2019-08-21
-
出现hard fault了,不要慌。建议在menuconfig中开启CmBacktrace软件包,精准追踪产生hard fault的地方和大致原因,可在故障发生时,自动分析出故障的原因,定位发生故障的代码位置
wenbodong
2019-08-23
这家伙很懒,什么也没写!
[i=s] 本帖最后由 wenbodong 于 2019-8-23 09:36 编辑 [/i] 还是线程溢出的问题。 ``` static int sim800c_netdev_check_link_status(struct netdev *netdev) { #define SIM800C_LINK_THREAD_STACK_SIZE 512 #define SIM800C_LINK_THREAD_PRIORITY (RT_THREAD_PRIORITY_MAX - 2) #define SIM800C_LINK_THREAD_TICK 20 rt_thread_t tid; char tname[RT_NAME_MAX]; if (netdev == RT_NULL) { LOG_E("Input network interface device is NULL.\n"); return -RT_ERROR; } rt_memset(tname, 0x00, sizeof(tname)); rt_snprintf(tname, RT_NAME_MAX, "%s_link", netdev->name); tid = rt_thread_create(tname, check_link_status_entry, (void *)netdev, SIM800C_LINK_THREAD_STACK_SIZE, SIM800C_LINK_THREAD_PRIORITY, SIM800C_LINK_THREAD_TICK); if (tid) { rt_thread_startup(tid); } return RT_EOK; } ``` check_link_status_entry对应线程的栈为512字节。用keil编译的固件运行时不溢出,而用gcc编译的固件则会溢出。将栈内存改为1K时,gcc不溢出了。下面为1K大小时,keil与gcc的使用率对比,线程名为sim800c_link。 keil最大使用量仅为33%。 thread pri status sp stack size max used left tick error -------------------------------- --- ------- ---------- ---------- ------ ---------- --- sim800c_link 30 suspend 0x0000009c 0x00000400 33% 0x00000014 000 tshell 20 running 0x00000100 0x00001000 13% 0x00000009 000 at_clnt0 9 suspend 0x000000ac 0x00000600 18% 0x00000001 000 sys_work 23 suspend 0x0000005c 0x00000800 29% 0x00000008 -02 tidle0 31 ready 0x00000040 0x00000100 34% 0x0000001c 000 gcc使用量居然能达到97%,看来还得把栈内存调大一些。 thread pri status sp stack size max used left tick error -------------------------------- --- ------- ---------- ---------- ------ ---------- --- sim800c_link 30 suspend 0x000000c0 0x00000400 97% 0x00000013 000 tshell 20 running 0x00000184 0x00001000 16% 0x00000006 000 at_clnt0 9 suspend 0x000000f0 0x00000600 66% 0x00000002 000 sys_work 23 suspend 0x00000080 0x00000800 59% 0x00000009 -02 tidle0 31 ready 0x00000058 0x00000100 57% 0x00000007 000 两种编译器结果不同,可能是由于该线程里面解析AT命令时使用vsscanf,keil的microlib使用的内存更小。
Cheney_Chen
2019-08-23
这家伙很懒,什么也没写!
>还是线程溢出的问题。 --- 楼主现在你线程栈改为多少没问题了?
还没想好
2019-08-23
这家伙很懒,什么也没写!
sim800c 有两个地方配置栈大小,可能都需要改。 1 。 #define SIM800C_THREAD_STACK_SIZE 1024 ----> 2048 配置工装线程栈大小 2 。#define SIM800C_LINK_THREAD_STACK_SIZE 512 ----> 2048 配置状态检测栈大小
wenbodong
2019-08-26
这家伙很懒,什么也没写!
>楼主现在你线程栈改为多少没问题了? --- 你楼下的配置即可
Cheney_Chen
2019-08-26
这家伙很懒,什么也没写!
>你楼下的配置即可 --- 好的,最新 at_device 软件包已修复该问题
jamguo
2019-08-26
这家伙很懒,什么也没写!
楼主可以把SIM800C部分代码分享下吗? 总是有各种问题搞不定 。 [email]516799640@qq.com[/email] 谢谢 好人一生平安!
wenbodong
2019-08-27
这家伙很懒,什么也没写!
>楼主可以把SIM800C部分代码分享下吗? 总是有各种问题搞不定 。 > >谢谢 好人一生平安! ... --- 你用了rtthread的at device框架吗
wenbodong
2019-08-27
这家伙很懒,什么也没写!
>好的,最新 at_device 软件包已修复该问题 --- 2.0.0吗,那个说是基于rt-thread 4.0.2,我没看到有发布这个版本啊,难道是在master分支上搞?
jamguo
2019-08-27
这家伙很懒,什么也没写!
>你用了rtthread的at device框架吗 --- 用了 就是BSD那块不会用,太抽象了,可以给我点代码看看吗?就是联网 和 发送接收这一块,我以前都是裸机,直接串口发的。。。
撰写答案
登录
注册新账号
关注者
0
被浏览
2.2k
关于作者
wenbodong
这家伙很懒,什么也没写!
提问
19
回答
44
被采纳
3
关注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
RT-thred的stm32h723对应bsp包CubeMX添加其他外设报错
2
RT-Thread中的time溢出问题,时间戳溢出,解决方法
3
ART-PI使用env驱动ETH网卡,pc和板子可以ping通
4
SystemView线程名字不显示
5
只用网页也能跑RT-Smart 无门槛腾讯Cloud studio + smart-build快速构建
热门标签
RT-Thread Studio
串口
Env
LWIP
SPI
AT
Bootloader
Hardfault
CAN总线
FinSH
ART-Pi
DMA
USB
文件系统
RT-Thread
SCons
RT-Thread Nano
线程
MQTT
STM32
RTC
rt-smart
FAL
I2C_IIC
UART
ESP8266
cubemx
WIZnet_W5500
ota在线升级
PWM
BSP
flash
freemodbus
packages_软件包
潘多拉开发板_Pandora
定时器
ADC
GD32
flashDB
socket
编译报错
中断
Debug
rt_mq_消息队列_msg_queue
keil_MDK
ulog
SFUD
msh
C++_cpp
MicroPython
本月问答贡献
RTT_逍遥
8
个答案
2
次被采纳
KunYi
8
个答案
1
次被采纳
三世执戟
7
个答案
1
次被采纳
winfeng
2
个答案
1
次被采纳
chenyaxing
2
个答案
1
次被采纳
本月文章贡献
catcatbing
2
篇文章
5
次点赞
swet123
1
篇文章
3
次点赞
YZRD
1
篇文章
2
次点赞
Days
1
篇文章
2
次点赞
阳光的掌控者
1
篇文章
1
次点赞
回到
顶部
发布
问题
分享
好友
手机
浏览
扫码手机浏览
投诉
建议
回到
底部