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

【经验分享】STM32自锁如何解锁?(解锁方法)No Cortex-M SW Device Found/HardFault_Handler

[复制链接]
STMCU小助手 发布时间:2022-3-24 21:53
在芯片锁住的时候,我们首先要查看是那种错误,/ \" ^: {9 K$ m; F& t+ v
正常情况下,你在Keil下载时遇到错误应该是这样的/ z1 \6 C$ {  h/ p# ~. A$ f
2 x- l& }, f2 T+ \! A, R
ITW8%{KX@P1_7SEC_ILZVHN.png
5 x* K% X, k# o8 Z
* z$ S+ {0 V0 b2 ?& Z找不到Cortex™-M内核
" v* s" M, `9 y8 a2 O+ Y6 \# SFlash下载失败
1 P- P& @; d2 _8 \+ \

: X* s: _" l$ x; l打开J-Link-Commander
7 {! b- P2 F' n U6A)}9FC$G`ZVM7EA6N1J@H.png . E. G) Q/ B+ w+ P6 e
8 N, A+ j  F( Y5 \) [' Y; z9 S; e
如果是正常,则是可以找到Cortex-M3/M4内核,
  I1 c/ u# n. V6 `, F7 C8 R
* Y5 N; f& [& x8 \% O( I5 T {LM4QGMHAP4~X}]LDL3@J6S.png 2 c1 i8 q, e( r7 a

1 y! Q+ b  C8 `; U/ R6 w# h7 D; h如果芯片自锁之后,会发现先是JTAG方式查找,之后SWD方式查找,最后找不到任何内核3 [' v* V  x7 \: x8 z- J
3 W1 t' U% o# r% e1 s
MLGFJ28G4X0TS[HSY13Q3KW.png
- f4 S$ _# q, S5 g' `( x& A: O+ [& m2 r8 a% g7 u6 U5 h5 n, G) Y
以下问题为J-LINK能找到芯片时的异常错误:% H# u5 n) f  ~5 s
BOOT脚配置问题:对于STM32往往都有些BOOT配置脚。因为BOOT脚的焊接或接触不良或者BOOT引脚没有配置正确**,导致很多问题。这种情况多表现在芯片功能时好时坏,或者部分芯片正常,部分芯片异常。) @9 x. W0 R9 r" c% Z. U

0 C: S) Q& O7 X2 z5 @3 n启动文件问题:经常因为选错了启动文件,导致程序无法正常运行,或者说调试时好好的,脱机运行就出鬼。这点在做不同系列芯片间移植时最容易碰到。
* a  [$ x$ D& T" o9 D: P* Y8 R8 O' {  Q2 G+ X5 m" v( H! u
堆或栈越界溢出:
这个也会导致芯片无法正常工作,调试时往往可能会有硬错提示。
4 r- k) e2 s5 a1 W: {1 d# L
  t% X# t1 J( a* ?' z芯片引脚短路:
这是最典型的现象,也是最常见的原因,一般不工作的时候第一反应就是检查是否发生短路,短路引发芯片无法正常工作。! R: I6 n5 ^  v. H
& A) F+ K( C: S" S4 {6 J! N
外部晶振异常:
外部晶振无法正常工作也是导致芯片无法正常工作的原因,如果程序时钟配置中没有增加在外部晶振无法正常工作时切换到内部晶振的代码,将导致单片机无法正常启动,进行调试会发现代码卡在了RCC时钟的初始化中
; A4 m5 S5 M4 b# S7 T- J* R( r( ~: {' \, c' f! S7 ^
数组越界操作:
数组发生越界时,便会进行错误,结果是程序直接卡死
* _: G) u4 h0 z2 m% x- N1 ^+ n" g  M1 [* O; j. r
中断处理错误: 同样会导致单片机卡死: I5 n! U6 f- c/ `; F4 J; a
) X% @* ~* A# z' Z' Y
单片机发生程序异常时,会进入到HardFault_Handler中断
( u2 E" c& i) v5 D4 L6 |" \4 O
解决方法:
" _5 X: `% A$ j( N  l+ \2 I. E
; ~9 F' G& h4 Q9 a( }7 Y* U NL8G29`51D43I3IB4Q9XXD3.png ' F8 @9 i- m0 ~/ p6 }1 a$ m
  @. b8 Y* z7 {
在硬件中断函数HardFault_Handler里的while(1)处打调试断点,程序执行到断点处时点击“STOP”停止仿真8 [2 l3 K% }& l: P& c% z

, z* ], b/ N, I& N ~Q0AS[`F_6JNX6(Y%HDZKB6.png - v* K2 @8 [4 R% Z4 S) e2 M* m

2 ]% f& j4 u' @; B' G }HRXU%BH}@FM}]]V@}Y3}09.png ) k4 i" O$ m. T2 J3 h

, S8 b) t& U& ]3 v! r; v在Keil菜单栏点击“View”——“Call Stack Window”9 {9 ^7 j+ ]. M& d
弹出“Call Stack + Locals”对话框。然后在对话框中右键选择“Show Caller Code”,就会跳转到出错之前的函数处,仔细查看这部分函数被调用或者数组内存使用情况# ]/ Z* {2 X5 t- ]) x
  G' J2 a# A3 }( o7 T
329E25JX7BOYIY246)Z7K9G.png : x" b! f) ]. `( k8 F
+ P/ d& [  j; {6 w
以下问题为J-LINK找不到芯片时的异常错误:
: V4 D3 `* M7 P, A自锁原因:
1 F9 m: @& }0 h% i: T+ V
STM32单片机一般的连接方式是**主闪存存储器(flash)**启动模式,即BOOT0为0,这样在用JTAG或SWD写进程序的时候,如果该程序工程中芯片选型不正确或着程序中复用了JTAG或SW复用引脚导致程序执行后出现启动配置错误或者调试引脚被占用而引起的芯片锁死或Jlnk连接不上的问题,9 B! F* o1 _+ M; G5 V

/ p/ d- [: n" t6 E4 m) W: k7 ^时钟问题:时钟频率设置太高,配置超出芯片主频工作范围,导致单片机自锁
8 `5 c& v) `, k9 B* o, z- L% d- n4 j
/ x) Y/ J- N3 e8 F. u; \电源问题:供电电压不稳,STM32内部存在保护检测,同样会进行芯片的自锁4 n8 S' ~7 E% Q  l
& e/ r  Z+ ]3 K0 Y" i
& N( r. K3 g" X6 y1 ^
解决方法:( J- z3 |+ G( a  o
把BOOT0和BOOT1跳成1和0,(这时候就看下Jlink应该可以找到芯片),让内部程序不运行,然后再重新下载另外的程序,再改回BOOT设置,便可以恢复正常。如果板子上JTAG和SW调试电路都有的话,在其中一种方式导致锁死的情况下可以用另一种方式擦除恢复,而不必调整BOOT设置。
, t' t! L2 f1 {" Q# U1 ^/ t4 J7 \
%SEZA)2A_GAYGOUWY`}1RSA.png 0 R- e1 C% E+ f. F3 z

* r9 L0 L7 s* p' q* X$ ~ {BCZ_CY(K67ASCHP)_~H@JA.png
; H- V6 q( T6 c: q  _5 O8 B3 Q8 T
& Q  P5 J2 V* F+ K$ ]. H简单的说 : 正常的芯片自锁,就是将Flash存储进行读写保护,使得不能运行程序,而我们的做法就是将BOOT0置高,使程序从系统存储器启动,找到芯片之后,重新往Flash中下载一个正常的代码,之后再换回Flash启动,芯片即可完成解锁
6 r2 u7 ]8 w8 r1 Z: M
9 M! K' P# y! L' j0 @& b, v如果即可以JTAG下载又可以SWD下载,假设SWD方式锁了,可以换成JTAG下载方式然后下载正常程序,同样可以解锁- o( s# p9 l& m; [- Y" }

! E1 l' P6 m; j  O. R2 Z( z8 p, V8 d, k, }% e+ w% g! k
" N! J# V+ A% T- a/ b
收藏 评论0 发布时间:2022-3-24 21:53

举报

0个回答

所属标签

相似分享

官网相关资源

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