搜索
bottom↓
回复: 356

【开源】ARM Cortex-M 错误追踪库,让 HardFault 不再可怕

  [复制链接]

出0入0汤圆

发表于 2017-4-20 09:52:33 | 显示全部楼层
下面这个错误不知道你的代码能不能定位出来。就是当用SDRAM作为栈空间,函数返回时执行到pop{Rx,Ry,PC}指令,如果下面这种读取错误发生,就会将错误的值读取到PC,就会发生HardFault。这种HardFault发生有很大的不确定性,有时运行10个小时都不发生,有时运行10分钟就发,HardFault的种类也会有变化。若有多个任务,HardFault的位置可能有多个,代码上看不出任何问题,极难定位。
而且由于发生HardFault时,R0~R3,R12,LR,PC,XPSR,这8个寄存器会自动入栈,正好会把栈空间上发生读取错误的位置上的数据覆盖掉,就无法确认是否是栈上的数据真的错了。当然HardFault时入栈的PC值是个异常值,这是可以清楚看到的。

STM32F42xx and STM32F43xx silicon limitations
DocID023833 Rev 10

2.11.5 Interruption of CPU read burst access to an end of SDRAM row

Description:
If an interrupt occurs during an CPU AHB burst read access to an end of SDRAM row, it may result in wrong data read from the next row if all the conditions below are met:
• The SDRAM data bus is 16-bit or 8-bit wide. 32-bit SDRAM mode is not affected.
• RBURST bit is reset in the FMC_SDCR1 register (read FIFO disabled).
• An interrupt occurs while CPU is performing an AHB incrementing bursts read access of unspecified length (using LDM = Load Multiple instruction).
• The address of the burst operation includes the end of an SDRAM row.

Workaround:
Enable the read FIFO by setting the RBURST bit in the FMC_SDCR1 register.

出0入0汤圆

发表于 2017-6-11 22:08:52 | 显示全部楼层
zzj0329 发表于 2017-6-11 13:53
你这个错误我最近碰到过,用常规的方法根本追踪不到,后来把整个芯片的代码上FPGA用内嵌的逻辑分析仪工具 ...

是的,这个错误很难调试,要不是有官方文档,根本无从下手
回帖提示: 反政府言论将被立即封锁ID 在按“提交”前,请自问一下:我这样表达会给举报吗,会给自己惹麻烦吗? 另外:尽量不要使用Mark、顶等没有意义的回复。不得大量使用大字体和彩色字。【本论坛不允许直接上传手机拍摄图片,浪费大家下载带宽和论坛服务器空间,请压缩后(图片小于1兆)才上传。压缩方法可以在微信里面发给自己(不要勾选“原图),然后下载,就能得到压缩后的图片】。另外,手机版只能上传图片,要上传附件需要切换到电脑版(不需要使用电脑,手机上切换到电脑版就行,页面底部)。
您需要登录后才可以回帖 登录 | 注册

本版积分规则

手机版|Archiver|amobbs.com 阿莫电子技术论坛 ( 粤ICP备2022115958号, 版权所有:东莞阿莫电子贸易商行 创办于2004年 (公安交互式论坛备案:44190002001997 ) )

GMT+8, 2024-5-7 05:31

© Since 2004 www.amobbs.com, 原www.ourdev.cn, 原www.ouravr.com

快速回复 返回顶部 返回列表