Toggle navigation
首页
问答
文章
积分商城
专家
专区
更多专区...
文档中心
返回主站
搜索
提问
会员
中心
登录
注册
Hardfault
MQTT
30
esp8266+ pahomqtt软件包断线重连会进入hardfault
发布于 2020-12-17 20:12:09 浏览:2289
订阅该版
使用STM32H743 esp8266+ pahomqtt软件包连接云平台,数据能够正常通信,但是如果断线重连会进入hardfault,进入hardfault是在断线连上之后,如果断线一直连接不上,是不会进入的,求助大佬,这个问题困扰我一个月了,之前解决办法是,断线回调函数内,直接调用rt_hw_cpu_reset();,简单粗暴,但是板子会经常重启,太头疼了 ``` \ | / - RT - Thread Operating System / | \ 4.0.2 build Dec 17 2020 2006 - 2019 Copyright by rt-thread team [I/sal.skt] Socket Abstraction Layer initialize success. [I/at.clnt] AT client(V1.3.0) on device uart7 initialize success. msh />[I/at.dev.esp] esp0 device wifi is disconnect. [I/at.dev.esp] esp0 device wifi is connected. [I/at.dev.esp] esp0 device network initialize successfully. app_mqtt_thread startup ok. [E/at.clnt] execute command (AT+CIPDNS_CUR?) failed! [W/at.dev.esp] please check and update esp0 device firmware to support the "AT+CIPDNS_CUR?" cmd. mqtt connect success! [D/mqtt] ipv4 address port: 1883 [D/mqtt] HOST = '47.92.249.234' [I/mqtt] MQTT server connect success. [I/mqtt] Subscribe #0 device/a649324baf71ef9d/down OK! mqtt online Receive topic: device/a649324baf71ef9d/down, message data: {"message":"SUCCESS","code":"2000","type":"sys"} Receive topic: device/a649324baf71ef9d/down, message data: {"message":"SUCCESS","code":"2000","type":"sys"} [E/at.skt.esp] esp0 device socket(0) send failed. [D/mqtt] MQTTSerialize_publish sendPacket rc: -1 mqtt offline [D/mqtt] restart! mqtt connect success! [D/mqtt] ipv4 address port: 1883 [D/mqtt] HOST = '47.92.249.234' [I/mqtt] MQTT server connect success. [I/mqtt] Subscribe #0 device/a649324baf71ef9d/down OK! mqtt online psr: 0x21010000 r00: 0x8f73f631 r01: 0x8f73f630 r02: 0x00000000 r03: 0x8f73f631 r04: 0x00000001 r05: 0x00000009 r06: 0x00000a2c r07: 0x2000a7a8 r08: 0xdeadbeef r09: 0xdeadbeef r10: 0xdeadbeef r11: 0xdeadbeef r12: 0xffffffff lr: 0x080142e3 pc: 0x080008ee hard fault on thread: mqtt0 thread pri status sp stack size max used left tick error -------- --- ------- ---------- ---------- ------ ---------- --- mqtt0 10 running 0x000002f4 0x00001000 27% 0x00000002 000 app_mqtt 6 suspend 0x000001c8 0x00001000 22% 0x00000008 000 at_clnt 9 suspend 0x000000f4 0x00000600 67% 0x00000004 000 tshell 20 suspend 0x00000188 0x00001000 09% 0x00000009 000 sys_work 23 suspend 0x00000110 0x00000800 65% 0x00000001 000 tidle0 31 ready 0x00000060 0x00000100 53% 0x0000001b 000 timer 4 suspend 0x00000080 0x00000200 34% 0x00000009 000 main 10 suspend 0x00000144 0x00000800 40% 0x0000000a 000 FPU active! bus fault: SCB_CFSR_BFSR:0x82 PRECISERR SCB->BFAR:8F73F630 ```
查看更多
tianqing324
2021-11-12
这家伙很懒,什么也没写!
```c message = (MQTTMessage *)c->readbuf; message->payload = c->readbuf + sizeof(MQTTMessage); topic.cstring = (char *)c->readbuf + sizeof(MQTTMessage) + message->payloadlen; if(message->payloadlen > c->readbuf_size){ continue; } ``` 增加了payloadlen判断,规避了这个问题
4
个回答
默认排序
按发布时间排序
xiangxistu
2020-12-18
这家伙很懒,什么也没写!
从 log 上看,是 PRECISERR 错误,也就是程序运行到一个精确地址引发的,SCB->BFAR:8F73F630 提示了错误地址。 我倾向于判断,这个是错误遍历到了这个地址引发的。 1. 如果会反汇编的话,可以看看这个 PC 的地址。如果使用 RT-Studio 的话,本身自带的就有反汇编功能,可以通过 PC 指针和 LR 指针判断问题出现的具体语句。 2. 如果不太熟悉,建议使用 CmBacktrace 软件包,定位问题语句。 3. 直接重启,感觉是奇技淫巧,不可取。
我心永恒~
2020-12-21
这家伙很懒,什么也没写!
![image.png](/uploads/20201221/132129bdbd95ee8b7c2d75d8c6736aee.png) 定位到是MQTTSerialize_publishLength这里的问题,里面是计算字符串长度的,调用了strlen,自己编写一个strlen还是同样的问题,可能是这里传入了异常的地址,导致错误,问题还未解决,最近论坛里很多人都遇到同样的问题了 ![image.png](/uploads/20201221/f4309a370d822917cdb3abcd41b05451.png)
sundyluo
2020-12-28
这家伙很懒,什么也没写!
有人解决了问题吗?
撰写答案
登录
注册新账号
关注者
1
被浏览
2.3k
关于作者
我心永恒~
这家伙很懒,什么也没写!
提问
3
回答
8
被采纳
0
关注TA
发私信
相关问题
1
RTT1.0,STM32调试时会跑到HardFault【已解决】,出现新问题
2
新手请教关于hardfault怎么查
3
github最新版本库中stm32f0X分支,运行切换任务时候出现hardfault[已解决]
4
实现iap功能,bootloader使用了rtt操作系统,在跳转到app代码的时候提示出现hardfault的问题
5
ymodem在on_begin内发送can无法断开连接,而且RTT会报hardfault
6
挂载UFFS文件系统执行到退出_BuildTreeStepOne函数时hardfault异常
7
STM32F1+RTT串口接收中断进入hardfault
8
STM32F746NG随机进入hardfault(已解决)
9
[已解决]自已建了个STM32F103的MDK工程,初始化时总是进入HardFault,求教!
10
将 Cortex M3 的 hardfault 处理与 M4、M7、M0 保持一致?
推荐文章
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
ota在线升级
UART
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
次被采纳
张世争
8
个答案
2
次被采纳
rv666
5
个答案
2
次被采纳
用户名由3_15位
11
个答案
1
次被采纳
KunYi
6
个答案
1
次被采纳
本月文章贡献
程序员阿伟
6
篇文章
2
次点赞
hhart
3
篇文章
4
次点赞
大龄码农
1
篇文章
2
次点赞
ThinkCode
1
篇文章
1
次点赞
Betrayer
1
篇文章
1
次点赞
回到
顶部
发布
问题
分享
好友
手机
浏览
扫码手机浏览
投诉
建议
回到
底部