当前位置: 首页 > news >正文

STM32——Flash闪存

以上部分,主存储器:程序存储器;

启动程序代码:系统存储器;

用户选择字节:选项字节

以下是闪存的管理员,用于擦除和读写的地址

C8T6一共64K,主存储器为64页

以下是整体框图:

FLASH的整体流程:

1、解锁+加锁

通过键寄存器对FLASH进行解锁(先用KEY1解锁,再用KEY2解锁),上一步完成后,要尽快加锁:加锁的时候在LOCK位写1即可锁住

2、使用指针访问存储器

读取寄存器地址为0X08000000的内容,将其强制转换为16位的指针类型,前一个*表示:指针取内容,将该地址下的内容取出(不需要解锁那一步,写才需要)

__IO用了define定义为变量,当编译器没有优化的时候,这个可加可不加,但是当编译器优化时,为防止有些必须代码被优化掉,可在其前加__IO,防止被优化

3、全擦除过程

在程序中,并没有判断LOCK位是否为1的过程,直接执行解锁功能

也不会去读出并验证所有页的数据

此时的信息块(系统存储器+选项字节)不受影响

闪存页擦除

4、写编程

如果需要写入很多数据就不断调用写入程序即可

5、选项字节的擦除(了解)

6、选项字节写入(了解)

7、器件电子签名(了解)

代码部分:

首先是编写MyFlash文件,包含写编程、擦除和读的程序;

之后再建立一个实现参数读写和存储管理功能的Store,其中建立一个数组用于放置掉电不丢失的数据,调用函数自动备份到Flash中;

之后在主函数通过写入数据调用store的数组,并备份到Flash中,实现任意读写参数,掉电不丢失功能

1、MyFlash

读取函数(32位、16位、8位)

全擦除函数

页擦除函数:

编程字节:

2、store模块

(1)先定义一个SRAM数组,用于管理FLASH最后一页数据,实现参数的任意读写和保存,需要备份再统一转到闪存中

512:16位2字节正好对应闪存一页1024字节

(2)判断闪存是否是第一次初始化

判断该页地址下的第一个半字是否是A5A5——不是,则表明第一次初始化,先进行页擦除——在该页的第一个半字处写入A5A5——将剩余的字节均写为0

(2)上电后将闪存的数据全都转移到SRAM中,保证掉电数据不丢失(闪存——SRAM的数据转移)

(3)SRAM——闪存的数据转换函数

(4)清除所有数据函数(先将SRAM的数据清零——再将数据从SRAM转移到闪存)

主函数:除了初始化各类函数外,主要实现按键1按下数据增加

按键2按下数据全部清0

数据掉电不丢失且复位也不会改变

实验结果如下:

FLASH

读取芯片ID:

直接在main中编写:

显示结果:

STM32江科大老师的视频完结!

http://www.lryc.cn/news/431791.html

相关文章:

  • python科学计算:NumPy 数组的高级操作
  • 【补-网络安全】日常运维(二)终端端口占用排查
  • 设计模式之适配器模式:软件世界的桥梁建筑师
  • Java 入门指南:Java 并发编程 —— Fork/Join 框架 实现任务的拆分与合并
  • token过期时间分平台(web和app)设置方法
  • [000-01-008].Seata案例应用
  • 超详细!!!electron-vite-vue开发桌面应用之创建新窗口以及主进程和子进程的通信监听(十二)
  • java编辑器——IntelliJ IDEA
  • 经验笔记:SSL证书
  • 设计模式之装饰器模式:让对象功能扩展更优雅的艺术
  • Anchor Alignment Metric来优化目标检测的标签分配和损失函数。
  • C++---由优先级队列认识仿函数
  • Client访问Server访问慢的原因
  • 用RPC Performance Inspector 优化你的区块链
  • linux如何查看内存条是ddr几代
  • LeetCode 3153.所有数对中数位差之和:计数
  • Spring Boot 整合 Sentinel 实现流量控制
  • Elasticsearch倒排索引
  • 速盾:ddos常用防御方法是什么?
  • 二分算法入门(简单题)
  • 在使用React Hooks中,如何避免状态更新时的性能问题?
  • Pytest插件pytest-selenium-让自动化测试更简洁
  • 视觉语言模型(VLMs)知多少?
  • 重新修改 Qt 项目的 Kit 配置
  • 【Spring Boot 3】【Web】自定义响应状态码
  • Locksupport凭证的底层原理
  • Elasticsearch 再次开源
  • 对称密码学
  • 正则表达式优化建议
  • Oracle RAC关于多节点访问同一个数据的过程