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

【经验分享】STM32的Flash写了保护怎么办?

[复制链接]
STMCU小助手 发布时间:2022-3-14 21:53
关于STM32对内部Flash的保护
" [4 J! k8 M: S% r    为了防止对Flash的非法访问,所有STM32的芯片都提供对Flash的保护,具体分为写保护和读保护。
    如果对Flash设置了写保护,那就无法对Flash进行编程和擦除。在开发STM32的时候,如果出现这种情况,通常仿真器都支持对Flash进行解锁,像jlink,stlink等仿真器都支持这个功能。
    在使用MDK进行调试的时候,可能会遇到如下图所示的报错信息,这时候就要排查Flash是不是被保护起来了。
. b, E5 ]% R. V+ L: W
Y]JPGI[{_9{OV{RELK$G.png

/ A& f2 a( f# s3 @7 j
    读保护即大家通常说的“加密”,是作用于整个Flash存储区域。一旦设置了Flash的读保护,内置的Flash存储区只能通过程序的正常执行才能读出,而不能通过下述任何一种方式读出:
" j/ E9 [) v! U3 h9 c
  • 通过调试器(JTAG或SWD)
  • 从RAM中启动并执行的程序

    * A# M& m3 E: y1 P! h: ]
    写保护是以四页(1KB/页) Flash存储区为单位提供写保护,对被保护的页实施编程或擦除操作将不被执行,同时产生操作错误标志,读与写设置的效果见下表:
- E, l. b1 D7 g; d
{T`I}2VIH@3@_QFCY7@IB4H.png

* P0 ^1 d9 b8 p0 w8 A
    当Flash读保护生效时,CPU执行程序可以读受保护的Flash区,但存在两个例外情况:
$ R1 W! h7 p- o9 l
  • 调试执行程序时
    / T+ H; y& W) Z  r, [
  • 从RAM启动并执行程序时
    : o$ R' }8 W) n5 b. n
    & L. o1 H! y  O

    1 r! q5 m; A$ v# ^
    STM32还提供了一个特别的保护,即对Flash存储区施加读保护后,即使没有启用写保护,Flash的第 0 ~ 3 页也将处于写保护状态,这是为了防止修改复位或中断向量而跳转到RAM区执行非法程序代码。
7 A: J5 r$ k( J& _5 b
Flash保护的相关函数   
  1. <font face="Tahoma" size="3">FLASH_Unlock();   //Flash解锁 </font><div><font face="Tahoma" size="3">FLASH_ReadOutProtection(DISABLE);  //Flash读保护禁止   </font></div><div><font face="Tahoma" size="3">FLASH_ReadOutProtection(ENABLE);   //Flash读保护允许</font></div>
复制代码
3 `- H, Q: x+ {2 ^/ b* W
STM32如何设置读保护和解除读保护?
    读保护设置后将不能读出Flash中的内容。0 r6 K1 Y2 \. I( Q" k% ?* }
如何设置读保护
    在程序的开头加入“设置读保护”的代码即可,每次运行代码时都检查一下,如果没有开就打开,如果打开了就跳过。其中,设置读保护的代码如下:
  1. int main(void)4 Z' y; e2 l8 v* k; h
  2. {; j( Y: i) \; S( E( J) k  j( p; }9 T
  3.   ...
    8 a6 h9 e/ @0 Z' _, d
  4. if (FLASH_GetReadOutProtectionStatus()!=SET)//检查设置读保护与否' v' {7 a: d, w8 x, |5 g
  5.   {1 d4 \* i" V+ x) x
  6.     FLASH_Unlock();         //写保护时可以不用这句话,可用可不用- B1 s( _  [( ~* P5 c& c
  7.     FLASH_ReadOutProtection(ENABLE);     //设置读保护  t+ a) ^5 I; j" X2 ^. Q  t; ~
  8.   }$ U5 N0 c7 S, B7 z3 K
  9.   ...
    6 d& A5 a# p) l
  10. while(1). X  J/ _3 L' j* n
  11.   {: t. l9 d. V- P$ ~
  12.     ...
    & P  ~$ l4 o9 r* E/ [1 z- `
  13.   }
    2 J7 n* w0 l5 A; @2 v
  14. }
复制代码
! }! Y  J: @  R" L
, v: E1 N; J- O6 p, a  [" ]1 B
    上面的代码执行后,使用j-link就不能读出程序了,实现了代码读保护。需要注意的是,芯片读保护后无法再次烧写新的程序到Flash中,必须要解除读保护才可以。但是当解除读保护的时候STM32会自动擦除整个Flash,起到保护数据的作用。

' }7 e2 _% r# q1 w5 b4 n
通过代码解除Flash保护
% q% h: m, V) z- X; [5 l! y  l
    解除读保护可以设置在按键里面,方便实现解锁,也可以设置在命令中。如下是解除读保护代码:
  1. void Off_Protect(void) //关闭保护
    ! m9 K  P* E! g2 G3 U
  2. {* w! \2 K5 F& p$ H2 o  ~; y" g
  3. if(FLASH_GetReadOutProtectionStatus() != RESET)5 R' ]" a3 ?1 l. R- `. q
  4.   {
    % O, F% Z; c" @* j) f+ y
  5.     FLASH_Unlock(); //不解锁FALSH也可设置读保护,可用可不用
    4 A' A" u# u7 t( e+ M
  6.     FLASH_ReadOutProtection(DISABLE);! b) ~' h8 J$ _. L- J6 p
  7.     FLASH_Lock();   //上锁
    " G" s2 Z. w( S' X
  8.   }
    : S) S2 i! R, y4 G0 Q
  9. }
复制代码
    程序中设置一个按键或者命令,可以随时解除Flash的读保护,让芯片又可以重新烧录程序。如果没有留,还可以专门写一个程序,下载到RAM中去运行,用来解除读保护。
    注意:执行后,Flash会自动全部擦除。
  1. int main(void)
    6 b- |+ _8 B: d% `
  2. {6 ]0 c7 O0 {1 V  K) `% Y
  3. Chip_Init();
    9 i' `9 f6 \0 @; h6 U, s
  4.   FLASH_Unlock(); //不解锁FALSH也可设置读保护,可用可不用
    / T, ?0 H! z$ Z: `2 a4 y
  5.   FLASH_ReadOutProtection(DISABLE);
    : h  n$ ~0 X* m! {% ]! \6 _) [
  6. }
复制代码
; Y: F0 c/ B) r, a4 ]1 \
通过ST-Link Utility来解除Flash保护
    在STLink连接目标板的情况下打开程序烧写软件ST-Link Utility,在菜单栏的Target下选择connect,因为这时候Flash已经被锁住了,能看到如下图所示的错误提示。

8 B  V+ S* @5 s! i* s  x1 ]
%U54CS_}CUJIHO(7`IOD0[6.png

, Y3 T) W! u$ e$ ?* q, {* [: p8 q! t
    下面来操作如何解除Flash保护。
    请确保当前已经正确连接了STLink和目标板,在菜单栏Target里打开Option Bytes...选项,发现在这里Read Out Protection选项是Enable,这个表示无法通过SWD读取STM32内部Flash的程序。
) e5 z* ?" O- X( I' ]( n: `
M5~21]2RWFIPUMH$W1FPQ.png
# ~0 j" [3 n, J# q
    将Read Out Protection选项设置为Disable,并点击Apply。
    这时候Flash已经成功解锁了,跟上文提到的解除Flash保护的结果一样,内部Flash已经被擦除了,如下图红框中所示。
FD6D75G8G0NSS{MV}E]4I.png
& Z) [: \% r& [
- D7 E# F0 H$ M$ z8 e
    完成以上步骤之后,在菜单栏Target下选择Disconnect断开与目标板连接。
    重新进入MDK,可以正常对目标板烧写程序了。
通过ST-Link Utility来设置Flash保护

/ N+ V* z; t- I7 @" K
8FJVF%YWZ)8YXNP_2{H5IV5.png

: w( y4 h( t  ~+ X' ~
    在菜单栏Target里打开Option Bytes...选项,可以看到下面有Flash sector protection选项。选择Select all之后,发现所有Page的Protection项都已经变成Write Protection了,只要选择Apply选项就可以对Flash进行写保护,如上图所示。

) }" P0 ^0 t# p: z3 y# ~3 S) s( L5 V5 R2 x& ?- n) p7 K4 N* S
收藏 评论0 发布时间:2022-3-14 21:53

举报

0个回答

所属标签

相似分享

官网相关资源

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