【IoT】STM32 Flash 均衡保存算法

简介: flash操作

在实际应用中,经常需要在程序运行过程中保存或读取一些数据,这些数据在工作中经常会变化,而且掉电后也不能丢失,所以需要及时地进行存储,存储这些数据常用的存储器是 EEPROM。

STM32 虽然本身不带 EEPROM,但是它支持自编程技术,可以利用内部 FLASH 来模拟 EEPROM,这样不仅简化了设计,而且降低了成本。

FLASH 的擦写次数是有限的,一般是 10W 次, FLASH 单个存储单元bit只能从1变为0,而不能从0变成1。

想要变成1,只能 page 擦除,这里的 page 表示一个擦除单位,擦除过程就是把 page 所有的位都写1,这种硬件特性决定需要一种比较高效的写 flash 算法。

总不能一次更改数值时擦除整一大片 FLASH。

1、均值保存算法

处理方法是将 1024 字节按 16 字节大小分成 64 等份,按后面格式存储参数地址:

划分:0x10*n +0x00 +0x01 +0x02 ... +0x0E +0x0F

内容: flag data1 data2 ... data14 data15 check_sum

check_sum=(flag+data1+data2+...+data15)&0xFF

flag 为 0xA5 表示当前 16 个字节为正在使用的记录,为其它值表示当前 16 字节已经丢弃。

这种保存方法是使用空间来换取擦写次数。

2、具体实现

1)定义 FLASH 页大小,储存数据大小:

define FLASH_PAGE 1024

define FLASH_DATAPACK 16

2)定义一个储存结构体

typedef struct {
u32 Addr;            // 地址为 flash 一页的首地址
u8 Read;            // 读地址的计数
u8 Write;           // 写地址的计数
u8 ReadBuff[FLASH_DATAPACK];  // 读取缓存区
u8 WriteBuff[FLASH_DATAPACK]; // 写入缓存区
} EEPROMTypeDef;
// FLASH 写函数
void FlashWrite( EEPROMTypeDef *Flash_16 )
{
u8 Flag;

while_1:

// 获取标志位
Flag = (vu8)(Flash_16->Addr + (Flash_16->Write) * FLASH_DATAPACK);

if(Flash_16->Write < 64 && Flag == 0xff) // 如果地址在一页内且内容空白

{

HT_Flash_ByteWrite(Flash_16->WriteBuff, Flash_16->Addr + (Flash_16->Write++) * FLASH_DATAPACK,        FLASH_DATAPACK);

}
else if ( Flash_16->Write < 64 && Flag != 0xff ) // 如果地址在一页内却有数据存储
{

Flash_16->Write++;

goto while_1;

}
else if(Flash_16->Write >= 64 ) // 如果地址不在一页内
{

Flash_16->Write = 63;

}
}

// FLASH 读函数
void FlashRead(EEPROMTypeDef *Flash_16)
{
u8 Flag;

while_1:

// 获取标志位
Flag = (vu8)(Flash_16->Addr + (Flash_16->Read) * FLASH_DATAPACK);

if( Flash_16->Read < 64 && Flag == 0xA5 ) // 如果地址在一页之内且数据有效
{

HT_Flash_ByteRead(Flash_16->ReadBuff, Flash_16->Addr + (Flash_16->Read) * FLASH_DATAPACK, FLASH_DATAPACK);  

  HT_Flash_ByteWrite(00, Flash_16->Addr + (Flash_16->Read++) * FLASH_DATAPACK, 1); // 标记数据无效
}
else if(Flash_16->Read < 64 && Flag != 0xA5) // 如果地址在一页之内但数据无效

  if(Flag != 0xff)

{                   
  Flash_16->Read++;
  
  goto while_1;
}

}

else if(Flash_16->Read >= 64) // 如果地址不在一页之内
{

Flash_16->Read = 0;

Flash_16->Write = 0;

HT_Flash_PageErase(Flash_16->Addr); // 页擦除

}

卫朋

人人都是产品经理受邀专栏作家,CSDN 嵌入式领域新星创作者、资深技术博主。2020 年 8 月开始写产品相关内容,截至目前,人人都是产品经理单渠道阅读 56 万+,鸟哥笔记单渠道阅读200 万+,CSDN 单渠道阅读 210 万+,51CTO单渠道阅读 180 万+。

卫朋入围2021/2022年人人都是产品经理平台年度作者,光环国际学习社区首批原创者、知识合作伙伴,商业新知 2021 年度产品十佳创作者,腾讯调研云2022年达人榜第三名。

文章被人人都是产品经理、CSDN、华为云、运营派、产品壹佰、鸟哥笔记、光环国际、商业新知、腾讯调研云等头部垂直类媒体转载。文章见仁见智,各位看官可策略性选择对于自己有用的部分。

相关文章
|
7天前
|
机器学习/深度学习 自然语言处理 算法
m基于深度学习的OFDM+QPSK链路信道估计和均衡算法误码率matlab仿真,对比LS,MMSE及LMMSE传统算法
**摘要:** 升级版MATLAB仿真对比了深度学习与LS、MMSE、LMMSE的OFDM信道估计算法,新增自动样本生成、复杂度分析及抗频偏性能评估。深度学习在无线通信中,尤其在OFDM的信道估计问题上展现潜力,解决了传统方法的局限。程序涉及信道估计器设计,深度学习模型通过学习导频信息估计信道响应,适应频域变化。核心代码展示了信号处理流程,包括编码、调制、信道模拟、降噪、信道估计和解调。
29 8
|
16天前
|
存储 数据安全/隐私保护 芯片
【STM32】详解嵌入式中FLASH闪存的特性和代码示例
【STM32】详解嵌入式中FLASH闪存的特性和代码示例
|
9月前
|
存储 芯片 内存技术
STM32速成笔记(十二)—Flash闪存
本文简单介绍了什么是Flash。针对STM32F1的Flash做了详细介绍,介绍了操作Flash的步骤,并且给出了程序设计。最后,介绍了一些注意事项。
68 0
STM32速成笔记(十二)—Flash闪存
|
算法
基于瑞丽多径信道的无线通信信道均衡算法matlab仿真,对比MMSE,ZF-DFE,MMSE-DFE
基于瑞丽多径信道的无线通信信道均衡算法matlab仿真,对比MMSE,ZF-DFE,MMSE-DFE
213 6
|
存储 关系型数据库 编译器
STM32学习笔记:读写内部Flash(介绍+附代码)
STM32学习笔记:读写内部Flash(介绍+附代码)
304 0
|
算法
基于QPSK调制和CoSaMP算法的信道估计均衡算法matlab仿真
基于QPSK调制和CoSaMP算法的信道估计均衡算法matlab仿真
122 0
|
存储 内存技术
STM32内部flash详解(1)(下)
STM32内部flash详解(1)
|
存储 缓存 关系型数据库
STM32内部flash详解(1)(上)
STM32内部flash详解(1)
|
机器学习/深度学习 算法
m基于深度学习的OFDM信道估计和均衡算法误码率matlab仿真,对比了LS,MMSE以及LMMSE等传统的信道估计算法
m基于深度学习的OFDM信道估计和均衡算法误码率matlab仿真,对比了LS,MMSE以及LMMSE等传统的信道估计算法
381 0
m基于深度学习的OFDM信道估计和均衡算法误码率matlab仿真,对比了LS,MMSE以及LMMSE等传统的信道估计算法
|
算法
m瑞利信道下对比ZF-SIC,MMSE-SIC,MRC三种均衡算法的误码率matlab仿真
m瑞利信道下对比ZF-SIC,MMSE-SIC,MRC三种均衡算法的误码率matlab仿真
233 0
m瑞利信道下对比ZF-SIC,MMSE-SIC,MRC三种均衡算法的误码率matlab仿真