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

【经验分享】FLASH 被异常改写

[复制链接]
STMCU小助手 发布时间:2022-2-17 20:19
问题描述:# B$ A/ N2 z1 Z3 N# ^/ b  ^* Q
某客户反馈, 当 MCU 频繁的正常通断电的时候。FLASH 被异常改写,出现各种各样的异常(整片别擦除、中断向量表被改写为 0、写保护被清掉、被加上读保护 ……..)
! x; \; i) ?+ i: L- j2 F9 S9 M# t) l# n
问题调研:( s9 g' m! p8 N0 w5 m
首先跟客户沟通:$ Y+ j5 ]# }# i( ]0 A8 K
• 他们是延续之前的项目,进行的一些软硬件简单修改。之前的项目没有出现过类似的问题。
' F4 A8 a2 M: ]* S+ A! }3 f' q4 r1 \• 确认通断电的时间是足够,就是说他们断电后所有的 VDD 都回到 0.上电的时序也是正常。! [" Z5 q; T" G7 u& @
• 原理图确认这是 follow 了我们的参考设计。
" @7 Y- l; O/ Y• 测量工作时的电压,只是发觉他们上电时会有一些抖动,其它一切正常。尝试让他们改善上电电路,去掉这一抖
/ Q9 |) _( [7 L$ J. x动,再次实验,仍然出现类似的问题。
/ ]7 ~  i" b1 e' w# n3 E$ A到这里似乎跟硬件没有任何的问题了, 接着让客户代码进行删减又做了如下实验:
$ l9 q" b6 ?: w- J2 W1, 去掉能 APP 部分代码,仅仅留下 IAP 代码。做相同的实验,问题再现。0 R' C. \/ s, J, [, M7 C  u  y
2, 进一步删减程序,客户去掉程序中所有跟 flash 以及 OPTION BYTE 相关的部分,做相同的实验,问题再现。7 Y* k, o0 z/ n0 {2 x* U2 R
3, 没招,再删,最后仅仅留下下面程序:
7 c* @2 g( g" w0 q' ?
1 l, ]0 P* H* W% z5 [: v ~99549I651{)%Y7@21Y[9WY.png : s  q  ]/ e) m1 ~7 v; ?# R/ u
  c3 c, Y& Q( Y5 c
P3B)~EUWJ}$V[Q)OW)4]QGH.png ( N6 K1 V5 M8 S5 r

' J+ K. t' ^5 m( ~客户反应只要掉用了 delay_init 函数就会出问题,不调用就不会出问题(仅仅做了一天的实验)。到这里似乎跟我们的软件有关系了,我们进一步分析发现他们改写了我们的 systick 的 config 函数,那么我就做下一个实验。1 v2 @3 }# b: j: Y  i# s5 k/ L
4, 改为标准库中的 systick 例程,去掉写保护,加一个 GPIO 定时翻转程序。同时在烧录之后,加上写保护,做相
- J, Y) W" R8 u8 F同的实验,问题再现。% _5 ?# Y8 n0 H3 |1 d2 R: l
5, 到这里我们都怀疑是芯片真的有损伤了,我们再做了一个实验用 cubemx 生成了一个 GPIO 翻转和 systick 的延
0 c$ G' D0 v4 B" M时,做相同的实验,问题再现。
" {' b/ o; r! h: }. C3 B; F- M0 l% W  _
原因:' h( q. M7 ~* w3 E* U
到这里我们似乎是江郎才尽,只能坐等 FA 的报告,看看芯片是否真的坏了与否。我们抱着怀疑一切的态度,请他们的硬件工程师再次确认他们的硬件和原理图的一致性,我们怀疑他们的硬件是否有装错的元器件。主要集中在 MCU 周边。最后他们的工程反馈,他们的 PDR_ON 脚,板子上装的元器件跟原理图不一致。他们把 R47 和 R48 都装了,那么相当于在 PDR_ON上是一个 0.6v 的电压,也就是关断了 MCU 内部复位。2 e* V- L1 W% u* ^, v
真是山穷水尽疑无路,柳暗花明又一村,问题应该跟内部复位有关。" q' x& g( V7 @8 n

: T; t1 Z; G9 w+ |# l( l 38Q3U_{HU8)Q(R@ZA1@DO1I.png " [3 A9 f, f2 z9 T# _$ Z, m

) K; W9 E' P9 V6 e- b从上面规格书来看,如果我们关断 mcu 内部的复位电路,需要在外部接一个复位信号保证 VDD 达到正常工作电压之前一直使 MCU 处于复位状态。3 m7 N" N5 ?" n. n- U1 i# [1 Q5 G/ {) F3 {

5 s5 o1 ]  q) Q( H5 N解决办法:  X! u& Q( _" V0 S
问题找到后解决办法就很简单,去掉 R48 这个 1k 欧姆的电阻,重做实验,再没有发现问题。; D7 x2 f1 s. _

& {, @$ u2 P- N% h$ t- V结论:0 ?% k# u9 r1 I
其实在之前我们的另外一个西安的客户发生过频繁上电不工作的情况。他们也是使用了就得数据手册,没有把 PDR_ON 脚拉到 VDD 所致。$ Y) ^0 E6 {5 [8 L- M0 b7 f: w
对于 ST MCU 来说,这个 PDR_ON 引脚有的封装是被引出来了,有的封装没有引出,如果没有引出的是默认使能内部复位功能,如果引出的话,大家也要当心有的型号是拉低使能内部复位;有得是拉高使能内部复位。所以在检查电路时一定要当心。. H) r' _4 v# b# N' P, }
3 {) ?/ _: d5 q* h+ g% ?6 n
, W% s" Z- p( R. ?& H# ~
收藏 评论0 发布时间:2022-2-17 20:19

举报

0个回答

所属标签

相似分享

官网相关资源

关于
我们是谁
投资者关系
意法半导体可持续发展举措
创新与技术
意法半导体官网
联系我们
联系ST分支机构
寻找销售人员和分销渠道
社区
媒体中心
活动与培训
隐私策略
隐私策略
Cookies管理
行使您的权利
官方最新发布
STM32N6 AI生态系统
STM32MCU,MPU高性能GUI
ST ACEPACK电源模块
意法半导体生物传感器
STM32Cube扩展软件包
关注我们
st-img 微信公众号
st-img 手机版