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

【实战经验】代码实现PCROP清除

[复制链接]
zero99 发布时间:2017-6-21 14:12
代码实现 PCROP清除
0 P, x1 B1 |9 T# L5 n
前言8 J/ t' W* t0 c' i+ r- f
STM32 PCROP专有代码读出保护,将某个区域设置为仅允许执行,可防止代码被非法读出与修改。ST网站提供了免费的PCROP参考代码,但是例程中仅仅提供了用代码设置PCROP。为方便利用PCROP进行知识产权保护的开发和部署,这篇文章提供了方法, 可在RDP级别设置为1或者0时,使用代码清除PCROP。  X+ d0 f% g" Z  Q9 d: M1 i

9 h2 L  _* [# Q: K# ]ST网站上的PCROP参考代码
* O% a4 m/ r& V4 p. ]5 U学习使用PCROP,可从ST网站http://www.st.com/en/embedded-software/x-cube-pcrop.html 下载文档以及参考代码。文档里有一步一步的详细说明。参考代码则实现了,如何设置编译开发环境去掉文字库(Literal pool),以避免受保护区域需要被读访问;参考代码也实现了如何利用代码使能PCROP保护以及如何导出接口符号供二次开发使用。
3 V; K: p; J5 P你可以编译运行PCROP参考代码。一旦下载到开发板并运行后,扇区2会自动被设置成PCROP保护。你将无法再次下载代码到该扇区,也无法读出该扇区的内容。若想通过STLink工具解除PCROP保护,则会导致整个Flash被擦除。' \. x2 V% @0 X* q( d  `
- m, D5 @3 L4 N5 _& d. V0 D
使用代码清除PCROP
, t, C0 c/ i- D' }在熟悉ST网站上的PCROP参考代码基础之上,我们将讨论如何使用代码清除PCROP。$ i1 C( t# T  ^& S
% I0 M/ a( o! J7 K2 {7 C
  1. 原理( G' Q8 N% m* }" p9 ^2 Y
根据用户手册,要想清除PCROP保护,读保护RDP级别必须从1设置成0。也就是说,即使当前RDP级别为0,我们也要使用代码将其设置成1。然后,同时关掉PCROP和将RDP设置成0。这也说明,尽管是清除PCROP保护,我们的代码必须加入RDP的设置函数, 而不能仅仅修改参考代码中的PCROP_Enable的状态字段使其变成PCROP_Disable。" F1 C" T# i7 K( P3 {6 d
$ ?1 w3 h" y& B( X
11.jpg 0 ~  U  L. D! ~( P' f

) F8 I) L( W1 Q  2. 材料准备. A$ O- W: I: ^" k: I- @
开发板: STM32F429I-Discovery9 b. K" r& U3 `/ U. [0 C
开发工具:STM32Cube_FW_F4_V1.15.0/ f* L% [8 q; u9 [7 I
                STM32CubeExpansion_AN4701_F4_V1.0.0(从ST网站下载的参考代码)/ z' `, W2 Z5 ^- R% Q
                STM32 STLink+ U: v: E$ h$ m5 w8 @9 n' {( m
                IAR/Keil& J! _; \5 I5 s0 l# ?2 e) C$ p
注:也可以选择其他支持PCROP的STM32系列并选择相应的开发板与固件库。
4 x0 t8 z8 |8 N2 T" P  b# E
9 `# Q' Y3 i4 E0 N- s3 P3. 代码: ]' Z' C' c1 R, u, Q2 F3 J
●设置RDP到级别16 {3 ?8 o2 U& P8 y% n* l% L
该函数在RDP级别为0时,若需要清除PCROP, 必须被使用。 ; p$ g! ]  t- X2 z2 l
12.jpg 9 z( h5 s; F" X9 n
●设置RDP到级别05 h% j9 z# w% Y" E
在清除PCROP保护的代码里不会直接调用这个函数。参考手册提到,PCROP的清除必须与RDP从1到0同时发生,而下列RDP_Disable函数则是完整独立的,无法与PCROP的Option bytes同时操作。不过,这个代码的中间部分,也就是实际功能部分,将在清除PCROP时被重用。9 T& u. Q- U* T3 y% |0 I
13.png
! t+ u- U( S: W1 E- ] 6 w) A' Z3 U. p# w) @
●清除PCROP
  P) s# w4 x9 t/ {: [( v( ]下述代码清除PCROP, 它基于参考代码中的PCROP_Enable函数改写而成。首先,它通过RDP_Enable将RDP设置成1。注意实验中不要将RDP设置成为2,否则所有的Option bytes将不再被允许修改。然后将RDP和PCROP都设置完毕,调用一次HAL_FLASH_OB_Launch达到同时将RDP设置成1并清除PCROP保护。& ^7 Y8 V4 `! l5 i' Z2 R, \' l
14.jpg
8 ]; I7 W; A3 P* j 15.jpg
& u1 o, J% x7 ^ 2 ?! u+ m2 }5 Q9 V; u& e! c
4.运行
, e, Q8 R+ V  l% ^% e在主函数中,调用PCROP_Disable可解除PCROP保护。RDP_Enable后需要关闭电源,重新启动,然后系统正常运行解除PCROP保护。解除保护后,可通过STLink确认PCROP Option bytes已恢复,同时也可以看到整个Flash内容已被擦除。2 }! j" c4 F+ Q
+ X3 n0 |: d  e3 f* P4 e( i
结论
; h- x& d  j6 P) E4 Z0 ?本文讨论了完全使用代码控制PCROP的设置与清除。它可以使用在PCROP代码保护的开发与部署阶段。
! n$ p) y; h8 M& w2 ^
* p' {4 i9 S: U2 U/ m8 L  h

' i3 A0 N( z' `2 `- T& f

: O( p0 v: E5 y6 Z" M4 m" a8 Y  l* p7 z' K+ u+ E0 O
" Y( F  \# M! H5 Z
文档下载
/ @- D0 x& w; Z
* t3 [4 Z6 A$ [9 H; B5 E9 E/ f

+ A: m! j2 _# U更多实战经验
) ^+ g/ Q! Q) D0 ~, \  H0 ^' K5 ~9 J3 B
, C/ I, s5 M6 O$ B1 W
收藏 评论2 发布时间:2017-6-21 14:12

举报

2个回答
Inc_brza 回答时间:2017-6-26 14:35:23
顶破总,PCROP这个东西一定要谨慎的使用,稍微不注意锁到flash了,简单的还可以通过在sram中运行代码来解除,不会用sram运行代码然后刚刚锁了flash的童鞋,恭喜,因为你无法下载代码了(芯片锁死了)
miraclexue 回答时间:2018-7-12 16:53:46
Inc_brza 发表于 2017-6-26 14:35
8 M# M' f  F1 U3 f, q* o& j顶破总,PCROP这个东西一定要谨慎的使用,稍微不注意锁到flash了,简单的还可以通过在sram中运行代码来解除 ...

% Q) [! Z( {' W6 w3 XSTLink工具就可以取消啊

所属标签

相似分享

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