STM32之内部闪存(FLASH)

一、内部Flash原理与应用

  • 背景说明

程序是由指令+数据组成,一般产品都会选择把程序/固件进行固化,一般是选择把程序或者固件存储到非易失性存储设备,例如存储到Flash中,因为Flash的制作工艺简单,成本低,容量大。

  • 基本概念

存储器指的是若干个存储单元的集合,每个存储单元(1字节)都可以存储8bit二进制数,为了方便的操作存储单元,就为每个存储单元都分配了地址,就可以通过寻址来访问存储单元。由于计算机的处理的数据量较大,并且运算速度都很快,就要求存储器的容量更大,并且存取数据的速度更快。

  • 存储类型

一般存储器根据存取方式可以分为两类:ROM (只读存储器) or RAM(随机访问存储器),也可以根据掉电是否会丢失的特性分为两类:非易失性存储设备 or 易失性存储设备。主要研究的就是ROM。

  1. ROM 只读存储器
  1. PROM 可编程只读存储器
  1. EPROM 可擦除可编程只读存储器
  1. EEPROM 电可擦除可编程只读存储器
  1. Flash 快闪存储器
  • 内存分布

可以先掌握MCU内置的512KB大小的Flash的操作,注意:falsh的特点是掉电不丢失,但是Flash内部存储空间是分为若干个扇区的,并且扇区内部的存储单元在进行写入之前,必须要先进行擦除动作,并且擦除是不能针对某个存储单元,而是某个扇区或者整片空间。

目前STM32F407ZET6这颗MCU内部有512KB的Flash,分为8个扇区,扇区0 ~ 扇区7,并且扇区的寻址范围是0x0800 0000 ~ 0x0807 FFFF。

  • 工作原理

提示:一般存储IC都具有写保护机制,一般通过硬件管脚实现写保护,一般是低电平有效,但是MCU内部的Flash也具有写保护机制,是通过软件实现的,所以在对Flash进行编程/擦除的时候,需要先解除Flash的写保护。

  • 访问流程
  1. 擦除
  1. 编程
  • 程序设计

如果用户打算对Flash空间进行编程或者擦除,对应的流程可以参考帮助手册以及文件注释

  • 结果验证

练习:利用DHT11温湿度传感器获取室内的温湿度数据,每隔5获取1次,并记录获取温湿度的时间,进行格式化的转换,格式为"2025/04/10 16:51:30 temp=28#humi=50\r\n",要求把每次获取的数据写入到MCU内部的扇区中。

要求数据的上限是100条记录,如果数据到达100条,则在PC端输出"内存已满",然后要求用户可以通过2个机械按键KEY0和KEY3,当按下KEY0的时候输出所有记录,当按下KEY3的时候清空记录。

相关推荐
senijusene10 分钟前
i.MX6ULL 裸机 ECSPI 驱动开发详解:
arm开发·驱动开发·嵌入式硬件
Tomhex29 分钟前
ARMv7与Cortex-M3关系解析
stm32
傻童:CPU1 小时前
stm32程序的启动过程
stm32
JaneHan_2 小时前
STM32CubeMX+HAL+Keil5 PWM呼吸灯
c语言·stm32·单片机
Ww.xh3 小时前
STM32嵌入AI模型全流程指南
stm32
Ww.xh3 小时前
STM32嵌入AI模型实战指南
stm32
傻童:CPU3 小时前
板级支持包的构建
stm32
进击的小头3 小时前
第7篇:嵌入式芯片运算核心:ALU_MAC_FPU的工作原理与性能差异
单片机·嵌入式硬件
振南的单片机世界3 小时前
RS485组网:一问一答,多个从机不打架
单片机·嵌入式硬件
开源盛世!!3 小时前
4.9-4.11
单片机·嵌入式硬件