46.1 选项字节与读写保护

1.1 选项字节的内容

选项字节是一段特殊的 FLASH 空间,STM32 芯片会根据它的内容进行读写保护配置,选项字节的构成见表选项字节的构成

STM32F103 系列芯片的选项字节有 8 个配置项,即上表中的 USER、RDP、DATA0/1 及 WRP0/1/2/3,而表中带 n 的同类项是该项的反码,即 nUSER 的值等于 (~USER)、nRDP 的值等于 (~RDP),STM32利用反码来确保选项字节内容的正确性。

选项字节的 8 个配置项具体的数据位配置说明见表选项字节具体的数据位配置说明

1.2 RDP 读保护

修改选项字节的 RDP 位的值可设置内部 FLASH 为以下保护级别:

• 0xA5:无保护
• 其它值:使能读保护
• 解除保护

芯片被配置成读保护后根据不同的使用情况,访问权限不同,总结

1.3 WRP 写保护

使用选项字节的 WRP0/1/2/3 可以设置主 FLASH 的写保护,防止它存储的程序内容被修改。

• 设置写保护
• 解除写保护

46.2 修改选项字节的过程

  1. 解除 FLASH_CR 寄存器的访问限制

• 往 FPEC 键寄存器 FLASH_KEYR 中写入 KEY1 = 0x45670123

• 再往 FPEC 键寄存器 FLASH_KEYR 中写入 KEY2 = 0xCDEF89AB

  1. 解除对选项字节的访问限制

• 往 FLASH_OPTKEYR 中写入 KEY1 = 0x45670123

• 再往 FLASH_OPTKEYR 中写入 KEY2 = 0xCDEF89AB

  1. 配置 FLASH_CR 的 OPTPG 位,准备修改选项字节

  2. 直接使用指针操作修改选项字节的内容,根据需要修改 RDP、WRP 等内容

  3. 对于读保护的解除,由于它会擦除 FLASH 的内容,所以需要检测状态寄存器标志位以确认FLASH 擦除操作完成

  4. 若是设置读保护及其解除,需要给芯片重新上电复位,以使新配置的选项字节生效;对于设置写保护及其解除,需要给芯片进行系统复位,以使新配置的选项字节生效

46.3 操作选项字节的库函数

3.1 选项字结构体定义

3.2 设置写保护及解除

3.3 设置读保护及解除

注意

函数 FLASH_ReadOutProtection设置 FLASH 的读保护及解除和函数FLASH_EnableWriteProtection 可用于设置写保护及解除同样有对 FLASH_CR 寄存器的访问,但并没有进行解锁操作,所以调用本函数前,同样需要先使用 FLASH_Unlock 函数解锁。

46.4 实验:设置读写保护及解除

4.1 硬件设计

本实验完全针对内部 FLASH 的操作,对外部硬件无特殊要求。即使是在 SRAM 调试模式下,由于是使用Debug 强制加载 PC 和 SP 指针,所以也无需设置 BOOT0 和 BOOT1 的引脚。

4.2 软件设计

4.2.1 代码分析

(1)设置写保护及解除

(2)设置读保护及解除

(3)main 函数

RAM.sct

;若RAM版本工程提示找不到sct文件,把本文件改名为“RAM版本.sct”复制至Output目录即可
; *************************************************************
; *** Scatter-Loading Description File generated by uVision ***
; *************************************************************LR_IROM1 0x20000000 0x00008000  {    ; load region size_regionER_IROM1 0x20000000 0x00008000  {  ; load address = execution address*.o (RESET, +First)*(InRoot$$Sections).ANY (+RO)}RW_IRAM1 0x20008000 0x00008000  {  ; RW data.ANY (+RW +ZI)}
}

flash.sct

; *************************************************************
; *** Scatter-Loading Description File generated by uVision ***
; *************************************************************LR_IROM1 0x08000000 0x00080000  {    ; load region size_regionER_IROM1 0x08000000 0x00080000  {  ; load address = execution address*.o (RESET, +First)*(InRoot$$Sections).ANY (+RO).ANY (+XO)}RW_IRAM1 0x20000000 0x00010000  {  ; RW data.ANY (+RW +ZI)}
}

main.c

#include "stm32f10x.h"
#include "./usart/bsp_usart.h"
#include "./key/bsp_key.h"
#include "./led/bsp_led.h"
#include "./protect/bsp_readWriteProtect.h"   // 函数原型声明
void Delay(__IO uint32_t nCount);//【 !!】注意事项:
//1.当芯片处于读写保护状态时,均无法下载新的程序,需要先解除保护状态后再下载
//2.本工程包含两个版本,可在MDK的“Load”下载按钮旁边的下拉框选择:
//  FLASH版本: 接上串口调试助手后,直接点击MDK的“Load”按钮把程序下载到STM32的FLASH中,
//              复位运行,串口会输出当前芯片的保护状态,可使用KEY1和KEY2切换。切换写保护
//              状态时,芯片会自动复位,程序重新执行;切换读保护状态时,按键后需要重新给
//              开发板上电复位,配置才会有效(断电时,串口与电脑的连接会断开,所以上电后
//              注意重新打开串口调试助手),若是执行解除读保护过程,运行后芯片FLASH中自身
//              的代码都会消失,所以要重新给开发板下载程序。
//  RAM版本  : 若无SRAM调试程序的经验,请先学习前面的《SRAM调试》章节。接上串口调试助手后,
//              只能使用MDK的“Debug”按钮把程序下载到STM32的内部SRAM中,然后点击全速运行,
//              可在串口查看调试输出。由于SRAM调试状态下,复位会使芯片程序乱飞,所以每次切
//              换状态后,都要重新点击“Debug”按钮下载SRAM程序,再全速运行查看输出。//3.若自己修改程序导致使芯片处于读写保护状态而无法下载,
//  且 FALSH程序自身又不包含自解除状态的程序,可以使用本工程的“RAM版本”解除,解除即可重新下载。/** 函数名:main* 描述  :主函数* 输入  :无* 输出  :无*/
int main(void)
{   /*初始化USART,配置模式为 115200 8-N-1*/USART_Config();LED_GPIO_Config();Key_GPIO_Config();LED_BLUE;//芯片自动复位后,串口可能有小部分异常输出,如输出一个“?”号printf("\r\n欢迎使用野火  STM32  开发板。\r\n"); printf("这是读写保护测试实验\r\n");/* 获取写保护寄存器的值进行判断,寄存器位为0表示有保护,为1表示无保护 *//*  若不等于0xFFFFFFFF,则说明有部分页被写保护了 */if(FLASH_GetWriteProtectionOptionByte() !=0xFFFFFFFF ){printf("\r\n目前芯片处于写保护状态,按Key1键解除保护\r\n");printf("写保护寄存器的值:WRPR=0x%x\r\n",FLASH_GetWriteProtectionOptionByte());}else //无写保护{printf("\r\n目前芯片无 写 保护,按 Key1 键可设置成 写 保护\r\n");printf("写保护寄存器的值:WRPR=0x%x\r\n",FLASH_GetWriteProtectionOptionByte());}/*  若等于SET,说明处于读保护状态 */if(FLASH_GetReadOutProtectionStatus () == SET ){printf("\r\n目前芯片处于读保护状态,按Key2键解除保护\r\n");}else{printf("\r\n目前芯片无 读 保护,按 Key2 键可设置成 读 保护\r\n");}while(1)                            {       if( Key_Scan(KEY1_GPIO_PORT,KEY1_GPIO_PIN) == KEY_ON  ){LED1_TOGGLE;WriteProtect_Toggle();} if( Key_Scan(KEY2_GPIO_PORT,KEY2_GPIO_PIN) == KEY_ON  ){LED2_TOGGLE;ReadProtect_Toggle();            }       }   }void Delay(__IO uint32_t nCount)
{for(; nCount != 0; nCount--);
}
/*********************************************END OF FILE**********************/

其他配置:

4.3 下载测试

本工程包含两个版本,可在 MDK 的“Load”下载按钮旁边的下拉框选择:

• FLASH 版本:

接上串口调试助手后,直接点击 MDK 的“Load”按钮把程序下载到 STM32的 FLASH 中,复位运行,串口会输出当前芯片的保护状态,可使用 KEY1 和 KEY2 切换。切换写保护状态时,芯片会自动复位,程序重新执行;切换读保护状态时,按键后需要重新给开发板上电复位,配置才会有效(断电时,串口与电脑的连接会断开,所以上电后注意重新打开串口调试助手),若是执行解除读保护过程,运行后芯片 FLASH 中自身的代码都会消失,所以要重新给开发板下载程序。

• RAM 版本:

若无 SRAM 调试程序的经验,请先学习前面的《SRAM 调试》章节。接上串口调试助手后,只能使用 MDK 的“Debug”按钮把程序下载到 STM32 的内部 SRAM 中,然后点击全速运行,可在串口查看调试输出。由于 SRAM 调试状态下,复位会使芯片程序乱飞,所以每次切换状态复位后,都要重新点击“Debug”按钮下载 SRAM 程序,再全速运行才能正常查看输出。

第 46 章 设置 FLASH 的读写保护及解除相关推荐

  1. 第51章 设置FLASH的读写保护及解除—零死角玩转STM32-F429系列

    第51章     设置FLASH的读写保护及解除 全套200集视频教程和1000页PDF教程请到秉火论坛下载:www.firebbs.cn 野火视频教程优酷观看网址:http://i.youku.co ...

  2. 第51章 设置FLASH的读写保护及解除—零死角玩转STM32-F429系列

    原文地址::https://www.cnblogs.com/firege/p/5806164.html 相关文章 1.用J-Flash去掉STM32写保护----http://download.csd ...

  3. 第51章 设置FLASH的读写保护及解除

    转载地址:https://www.cnblogs.com/firege/ 51.1 选项字节与读写保护 在实际发布的产品中,在STM32芯片的内部FLASH存储了控制程序,如果不作任何保护措施的话,可 ...

  4. 设置FLASH的读写保护及解除—零死角玩转STM32-F429系列

    第51章     设置FLASH的读写保护及解除 全套200集视频教程和1000页PDF教程请到秉火论坛下载:www.firebbs.cn 野火视频教程优酷观看网址:http://i.youku.co ...

  5. stm32对flash的读写保护与解除

    一.STM32对内部Flash的保护措施           所有STM32的芯片都提供对Flash的保护,防止对Flash的非法访问 - 写保护和读保护.          1.读保护即大家通常说的 ...

  6. flash写保护原理_老司机带路:LPC82x 存储器及读写保护 手到擒来!

    点击上方"单片大师"可以订阅哦 存储器,顾名思义就是用来存放东西的地方,那么对于一款 MCU 而言,在性能描述的时候,我们都会说 SRAM,Flash 的容量大小有多少.对于初学者 ...

  7. STM32HAL库-内部Flash在指定页读写保护示例

    概述 本篇文章介绍如何使用STM32HAL库,内部Flash在特定页读写保护示例. 硬件:STM32F103CBU6最小系统板 软件:Keil 5.29  + STM32CubeMX5.6.1 一.使 ...

  8. 如何解锁Flash读写保护

    如何解锁Flash读写保护 (wang@20160427 网页摘抄) 在编译下载的时候第一次遇到了这样的问题: Warning: Stack pointer is setup to incorrect ...

  9. 串口读写flash_老司机带路:LPC82x 存储器及读写保护 手到擒来!

    点击上方"单片大师"可以订阅哦 存储器,顾名思义就是用来存放东西的地方,那么对于一款 MCU 而言,在性能描述的时候,我们都会说 SRAM,Flash 的容量大小有多少.对于初学者 ...

最新文章

  1. 两地控制的项目要求_项目两地控制灯照明线路的安装.ppt
  2. 任正非最新讲话透露:华为在加快开发统一的人工智能平台
  3. js 改变change方法_JS 之设计模式
  4. 互联网金融下一个风口的或许在新农业领域?
  5. ios开发之使用多文件上传的简单封装最原始的
  6. MyBatis系列之浅谈SQL执行流程分析
  7. linux db2在线备份,DB2 pureScale在线备份恢复实例
  8. linux查看系统的版本信息失败,Linux - 查看系统的版本信息
  9. oracle常用的一些sql命令
  10. 使用XMLHttpRequest发送POST数据
  11. sql 同步2个表中的一个字段数据
  12. windows server 2008 R2 集成USB3.0驱动--成功实现
  13. latex linux 安装教程,Deepin安装LaTex,
  14. 雪球网基于沪深300的评论爬虫
  15. 360浏览器调试html5,360极速浏览器开发:调试指南
  16. js12---闭包,原型,继承
  17. 从零搭建Spring Boot脚手架(4):手写Mybatis通用Mapper
  18. 阿里云ACA、ACP和ACE认证考试有什么区别?考生应该如何选择?-阿里云开发者社区
  19. 诺基亚暗恋Android背后:WP增长是假象
  20. html制作满天星,新鲜满天星如何做干花,满天星干花制作4大方法

热门文章

  1. PayPal创始人之一迈克斯·雷夫奇谈创业传奇
  2. (原创)LEON3入门教程(四):基于AMBA APB总线的七段数码管IP核设计
  3. php 防止sql注入
  4. 技术博客2013年11月份头条记录
  5. MySQL学习小记(一)
  6. JuiceSSH:安卓平台免费好用的 SSH 客户端
  7. 云管平台中租户以及多租户概念简单说明
  8. DebeCMS环境搭建以及漏洞复现
  9. ZynqMP升级方案emmc
  10. 使用真机导致Androidstudio打印不出log