STM32利用IAP模拟EEPROM
79 浏览量
更新于2024-09-01
收藏 74KB PDF 举报
"STM32微控制器通过利用其内置的IAP(在应用编程)功能,可以模拟EEPROM,以解决其自身不带EEPROM的问题。这种方法允许开发者使用FLASH的一部分作为非易失性存储,存储小量需要在电源断开后仍能保留的数据。"
STM32中的FLASH模拟EEPROM是一个巧妙的技术,它利用了STM32芯片的特性来扩展功能。STM32系列微控制器的FLASH存储器分为几个部分,包括主存储器、信息块和闪存存储器接口寄存器。
1. 主存储器是主要的程序存储区域,用于存放执行代码和常量数据。根据不同的STM32型号,主存储器的大小和结构有所差异。例如,STM32F103ZET6这款大容量产品,其主存储器被划分为256个页面,每个页面大小为2K字节。较小容量的产品则每页只有1K字节。
2. 信息块包含启动程序代码和用户选择字节。启动程序代码用于串口下载代码,而用户选择字节则常用于配置保护选项,如写保护和读保护。
3. 闪存存储器接口寄存器是控制整个闪存模块的关键,它负责生成读写操作所需的控制信号,并与CPU的AHB接口交互,确保数据的正确传输。
在读取操作中,STM32的内置闪存可以直接在通用地址空间被CPU寻址,但因为CPU速度较快,可能需要考虑Flash等待时间。例如,当CPU主频为72MHz时,由于STM32F103的Flash最大访问速度限制在24MHz,因此需要设置2个等待周期,这通过修改FLASH_ACR寄存器来完成。
STM32官方固件库提供了对Flash操作的支持,包括锁定和解锁函数。在对Flash进行写操作前,通常需要调用解锁函数来解除保护,然后才能安全地写入或擦除数据。写入操作完成后,再锁定Flash以防止意外修改。这些函数在`stm32f10x_flash.c`和`stm32f10x_flash.h`文件中定义。
通过这种方法模拟EEPROM,开发者可以有效地利用STM32的Flash资源,实现类似EEPROM的持久存储功能,同时避免了外部添加额外硬件的成本和复杂性。然而,需要注意的是,虽然Flash可以模拟EEPROM,但其擦写次数有限,因此在设计时应考虑到这一点,合理分配和管理存储空间,以延长Flash的使用寿命。
462 浏览量
2952 浏览量
103 浏览量
577 浏览量
174 浏览量
145 浏览量
2022-07-14 上传
2022-07-14 上传
weixin_38691669
- 粉丝: 3
- 资源: 906
最新资源
- 测试一下
- 倒霉熊图标下载
- SETFSB.zip
- marathon_3:免费的智力马拉松HTML-学院
- BlenderGEResourceKit:Blender游戏引擎的即用型组件集合
- winsdksetup.zip
- Aikatsu LGTM-crx插件
- dsm-htpc-群集
- simple-password-manager:Flutter制作的简单密码管理应用
- 精美蝴蝶图标下载
- 电信设备-带身份核验的物联网移动终端及人证合一核验方法.zip
- 初级java笔试题-cs-study:https://github.com/jwasham/coding-interview-universi
- MinGW压缩包省去繁琐的官网下载
- SYIPAGeneratedScript:make a ipa by script——使用脚本生成ipa包
- VTS Testing Version 2-crx插件
- 帮手