你的浏览器版本过低,可能导致网站不能正常访问!
为了你能正常使用网站功能,请使用这些浏览器。

程序运行在 STM32H750 的外扩 FLASH 上两小时后死机

[复制链接]
STMCU小助手 发布时间:2023-2-17 16:03
1. 问题现象/ r' W( u4 q" F$ W
3 V* G* F: `8 P. H
客户使用 STM32H750VBT6,通过 QSPI 外扩了一个 4M 的 NOR FLASH,采用memory map 模式。当程序跳转运行到外设 FLASH 后,大约两个小时后程序死机。, I: L, s( [' f& E+ f' @
客户使用的 IDE 是 KEIL,此问题可以固定重现。 在 KEIL 调试模式下重现问题时,通过多次观察发现,程序死的位置总体上会停在两个位置,并不是同一个位置。一个是 TIM15函数的入口;另一个是进入中断函数后的一个赋值语句。
- z- X& {7 }9 g+ _8 e  r! a  \, i2 o% s/ M% g
+ {, E4 s3 T) H
2. 问题分析及测试
$ M+ K. M! A: z' h通过拜访客户,观察到死机位置处于即将进入 TIM15 中断入口处,但还未进入之时。查看客户的原理图,发现两个 VCAP 并未从外部相连,于是要求客户直接从外部将此两个引脚飞线短连。 但是,后来经测试问题仍然重现。
2 g' N$ H7 q5 l! ?/ g9 V3 z% c又观察到 PC13 连接为 GPIO 输出引脚,用于驱动一外部组件。 考虑到备份域相关的一些引脚其驱动能力相对弱一些,于是让客户将 PC13 引脚断开后再测试,结果问题仍然重现。6 S8 n9 M) ]; c2 m$ @1 M; l
上面是一些硬件相关的怀疑点,经测试结果来看,与此问题无关。 看来主要可能还是软件方面的问题。
4 O. [7 ?4 D( X( N5 P在软件上确定客户已经打开了 IO 补偿功能,但 IO 速度设置的是 HIGH,于是让客户修改成 “VERY_HIGH”,经测试问题仍然存在。
9 {1 n: f% A- K5 H" K- z9 X由于之前发生过一个从低功耗唤醒后死机的问题,是与 Cache 相关的问题,于是要测试下将 CACHE 关闭的情况。 这次经测试客户反馈问题没现重现 ! 但客户同时也反馈,之前的代码也存在稍微修改一处代码,问题就不再重现的现象,没有找到具体规律。 这次代码修改也没排除这种可能性。9 O( ^1 [4 n$ h& R
为了让关闭 Cache 的方法更具效力,于是让客户在调试模式下通过手动关闭 CACHE的方式,代码仍然保持为原先可以重现问题的代码。如下图所示 :  X- Q8 i: j1 v" \+ w! c/ ^# G

) h  W6 m) y- k, V8 b
/ j. k  R# T- E9 h" d3 l1 }
UB$~E1`7OO9B48(X34AF9_7.png
  h9 P0 P; D, r$ d* T
: P9 _: C9 U$ a5 W

. f. Y( h. F* A, T如上图所示,在代码运行到使用 CACHE 后一行设置断点,当程序停下来后,打开 Sys Ctrl/Cfg 窗口(菜单 view->system viewer->Core peripherals->system control and configuration),将对应的位去掉。 最终客户反馈,关闭 DC,或者 IC 任何一个或者两个都关闭,问题现象消失。 至此可以确定地是,此问题与 CACHE 相关 !
9 _5 u4 j! I3 V) }, A7 G' H8 K* O于是查看客户的 MPU 相关配置,并将 Cube 包里的 H750 示例工程中的 MPU 配置发给客户测试下,但问题仍然存在。
7 @" h5 z) f3 E* y5 U接下来查看勘误手册,发现 2.4.4 节有 QSPI 相关的内容:! I" f/ i; S6 F# I0 }" v

$ A. a& ?- b' F: S

; {3 C* k8 w% T# a  _ QH(A00HU{RITIQYE]R8HNJ1.png
5 C+ l2 Q" y# e
$ I1 Y% U1 H9 Y! l4 c$ r

( P, P4 L# d3 r% y这里有提到在 QSPI 外设 FLASH 并工作在 memory-mapped 模式的时候,当读取由FSIZE 定义的最后一个字节的时候,不管内容如何,有可能会导致 AXIs 总线 STALL 掉。并同时给出了三种规避措施。 其中第一种是将 FSIZE 定义得比实际大,以留有足够的裕量。 于是让客户修改代码:
. R; L* e3 q8 A0 H  i% H$ [$ w9 M0 ~在 QSPI 初始化时将 size 设置成大一倍:5 |( M1 i2 p7 \4 W8 @  o& z- X' P
上面红色部分表示的 nor flash 设置成实际的两倍大小。
3 n' m* q% A3 K同时考虑到此处定义了实际两倍大小的 FLASH,多出来的另外一半实际是不存在的,为了避免 CPU 意外访问这个实际不存在的区域,使用 MPU“告诉”CPU 这多出来的一半区间是不可访问的。 于是 MPU 按如下来配置:
# l6 W& k# `2 ?3 g7 J7 v- v' k0 `' f% X6 P& z; [

9 H5 F# D" \. c& s1 |  c, R0 P Q(B}H}[%LGRI(AM62S3E31F.png % V" y- }& t3 v; P
- H0 k  F+ ?: Q1 M9 w, F

1 p1 g& V" F! t" ~, ~8 ]3 \客户再次测试,结果问题不再重现。 为了进一步验证问题,客户尝试按原先的代码直接读取 NOR FLASH 的最后一个字节,结果问题也会重现,再次验证此方法的有效性,至此问题解决。
! g- L4 `( M4 K$ X& j+ x( B+ A( Y
/ A" q- P( c* u& g

7 S1 a  ]& ^% `* A& g% @完整版请查看:附件 程序运行在 STM32H750 的外扩 FLASH 上两小时后死机.pdf (452.44 KB, 下载次数: 1)
收藏 评论0 发布时间:2023-2-17 16:03

举报

0个回答
关于意法半导体
我们是谁
投资者关系
意法半导体可持续发展举措
创新和工艺
招聘信息
联系我们
联系ST分支机构
寻找销售人员和分销渠道
社区
媒体中心
活动与培训
隐私策略
隐私策略
Cookies管理
行使您的权利
关注我们
st-img 微信公众号
st-img 手机版