今天小编要和大家分享的是控制,MCU相关信息,接下来我将从如何使用代码清除STM32单片机上的PCROP,stm32学习之路(一)——st是神马,stm32又是神马这几个方面来介绍。
控制,MCU相关技术文章如何使用代码清除STM32单片机上的PCROP
前言
STM32PCROP专有代码读出保护,将某个区域设置为仅允许执行,可防止代码被非法读出与修改。ST网站提供了免费的PCROP参考代码,但是例程中仅仅提供了用代码设置PCROP。为方便利用PCROP进行知识产权保护的开发和部署,这篇文章提供了方法,可在RDP级别设置为1或者0时,使用代码清除PCROP。
ST网站上的PCROP参考代码
学习使用PCROP,可从ST网站下载文档以及参考代码。文档里有一步一步的详细说明。参考代码则实现了,如何设置编译开发环境去掉文字库(Literal pool),以避免受保护区域需要被读访问;参考代码也实现了如何利用代码使能PCROP保护以及如何导出接口符号供二次开发使用。
你可以编译运行PCROP参考代码。一旦下载到开发板并运行后,扇区2会自动被设置成PCROP保护。你将无法再次下载代码到该扇区,也无法读出该扇区的内容。若想通过STLink工具解除PCROP保护,则会导致整个Flash被擦除。
使用代码清除PCROP
在熟悉ST网站上的PCROP参考代码基础之上,我们将讨论如何使用代码清除PCROP。
1. 原理
根据STM32用户手册,要想清除PCROP保护,读保护RDP级别必须从1设置成0。也就是说,即使当前RDP级别为0,我们也要使用代码将其设置成1。然后,同时关掉PCROP和将RDP设置成0。这也说明,尽管是清除PCROP保护,我们的代码必须加入RDP的设置函数, 而不能仅仅修改参考代码中的PCROP_Enable的状态字段使其变成PCROP_Disable。
2. 材料准备
开发板:STM32F429I_Discovery
开发工具:STM32Cube_FW_F4_V1.15.0
STM32CubeExpansion_AN4701_F4_V1.0.0(从ST网站下载的参考代码)
STM32STLink
IAR/Keil
注:也可以选择其他支持PCROP的STM32系列,并选择相应的STM32开发板与STM32固件库。
3. 代码
? ●设置RDP到级别1
该函数在RDP级别为0时,若需要清除PCROP, 必须被使用。