Toggle navigation
首页
问答
文章
积分商城
专家
专区
更多专区...
文档中心
返回主站
搜索
提问
会员
中心
登录
注册
freemodbus
RT-Thread Studio
Hardfault
20
同样的代码,studio编译的固件运行出错,MDK5编译的固件就正常
发布于 2022-06-25 20:27:54 浏览:878
订阅该版
我在移植完freemodbus后,因为工程中rtconfig.h定义的 RT_S_REG_HOLDING_NREGS 的大小为100,不够我用,我就定义成了200,而freemodbus源码中 mbfuncholding.c、mbfuncholding_m.c和mbfuncinput.c这三个文件原来定义的 MB_PDU_FUNC_READ_REGCNT_MAX 等于 0x007D(即125)我也修改成了0x0200 (即512)。 然后 MDK5 编译,下载运行,打开 ModScan32 读取 Hold Reg 的前125个数据正常,当设置 ModScan32 读取 126 甚至更多的数据时也正常。 但是,当我 studio 编译,下载运行,打开 ModScan32 读取 Hold Reg 的前125个数据是正常的,而当设置 ModScan32 读取 126 甚至更多的数据时则报错如下: ``` msh > psr: 0x00000000 r00: 0x00000000 r01: 0x10000000 r02: 0x00000001 r03: 0x0800c6e0 r04: 0xdeadbeef r05: 0xdeadbeef r06: 0xdeadbeef r07: 0x20000fd8 r08: 0xdeadbeef r09: 0xdeadbeef r10: 0xdeadbeef r11: 0xdeadbeef r12: 0x00000000 lr: 0x0800be5b pc: 0x0800c6e0 hard fault on thread: slave tr thread pri status sp stack size max used left tick error -------- --- ------- ---------- ---------- ------ ---------- --- slave tr 10 running 0x000000b0 0x00000200 34% 0x00000005 000 md_poll 10 suspend 0x000000b8 0x00000200 72% 0x0000000a 000 save_fla 25 suspend 0x000000c0 0x00000200 37% 0x00000005 000 tshell 20 suspend 0x000000c8 0x00001000 05% 0x0000000a 000 tidle0 31 ready 0x00000080 0x00000100 61% 0x00000015 000 usage fault: SCB_CFSR_UFSR:0x02 INVSTATE ``` 同样的工程代码,在 MDK5 编译出来的固件运行正常,但是 studio 编译出来的固件却会运行报错。开始的时候我以为是 studio 编译的.o文件没有清除,所以将 build 目录整个删除,然后所有代码 reset,但最终结果还是 studio 报错,而 MKD5 正常。 请问这是什么原因呢,有人遇到过吗? *********************************************** 新增: 经过单步调试,发现程序是在执行 xMBRTUTransmitFSM 函数的时候挂死的,同时结合笔记《RT-Thread系统 hard fault on thread erx故障分析》分析,发现这里极大可能是数组内存越界造成的问题。而这个函数只有“pucSndBufferCur++”有对数组进行的操作。检查发现“pucSndBufferCur”是指向数组 ucRTUBuf 的,所以将数组的大小 MB_SER_PDU_SIZE_MAX 从256修改为512,则问题得到解决。同时,经分析 modbus 的发送 Hold Reg 数据帧格式(发送两个数据的格式如下),256的大小确实会导致越界。  但是,但是,为什么 MDK5 编译出来的没有问题呢?
查看更多
2
个回答
默认排序
按发布时间排序
aozima
2022-06-25
调网络不抓包,调I2C等时序不上逻辑分析仪,就像电工不用万用表!多用整理的好的文字,比截图更省流量,还能在整理过程中思考。
先看PC指示的前几条指令,当成普通的 [Hardfault](https://club.rt-thread.org/ask/tag/32c779b3c4ce1bfd.html "Hardfault") 分析即可。
出出啊
2022-06-27
恃人不如自恃,人之为己者不如己之自为也
 这 9 个字节就让 256 个字节的缓存溢出了?
撰写答案
登录
注册新账号
关注者
0
被浏览
878
关于作者
大厨哥
这家伙很懒,什么也没写!
提问
15
回答
15
被采纳
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
【CFP】2025 RT-Thread全球技术大会演讲征集开始啦!
2
在 RT-Thread Studio 环境中为 ART-Pi 2 移植 CherryUSB(以 usb_device 为例)
3
嵌入式ARM RISCV toolchain工具 梳理arm-none-eabi-gcc
4
使用官方BOOT升级,看这一篇就够了?(以STM32F407VGT6为例)
5
可以使用MQTT连接AI大模型吗
热门标签
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
cubemx
ESP8266
WIZnet_W5500
UART
ota在线升级
BSP
PWM
flash
packages_软件包
freemodbus
潘多拉开发板_Pandora
ADC
GD32
定时器
flashDB
编译报错
keil_MDK
socket
中断
rt_mq_消息队列_msg_queue
Debug
SFUD
msh
ulog
C++_cpp
at_device
本月问答贡献
聚散无由
9
个答案
6
次被采纳
RTT_逍遥
7
个答案
2
次被采纳
a1012112796
5
个答案
2
次被采纳
加缪
2
个答案
2
次被采纳
踩姑娘的小蘑菇
9
个答案
1
次被采纳
本月文章贡献
wake_mirco
2
篇文章
7
次点赞
mushroom
1
篇文章
9
次点赞
张世争
1
篇文章
7
次点赞
RTT_逍遥
1
篇文章
5
次点赞
Jack_____
1
篇文章
5
次点赞
回到
顶部
发布
问题
分享
好友
手机
浏览
扫码手机浏览
投诉
建议
回到
底部