你的浏览器版本过低,可能导致网站不能正常访问!
为了你能正常使用网站功能,请使用这些浏览器。

【经验分享】STM32F1x系列——Flash 模拟 EEPROM

[复制链接]
STMCU小助手 发布时间:2021-11-29 22:02
STM32F10x芯片本身没有集成EEPROM,替代方案是用片上Flash来模拟EEPROM。Flash与EEPROM的区别主要是:一、EEPROM可以按位擦写,而Flash只能按块(页)擦除;二、Flash的擦除寿命约1 万次,较EEPROM低一个量级。ST网站有个Flash模拟EEPROM的范例:AN2594: EEPROM emulation in STM32F10x microcontrollers(包括源码和文档)。范例在保存修改的数据时,以写入新数据来替代对原数据的修改,并使用两个页面轮流写入,单页写满后进行数据迁移,再一次性擦除旧页面。这个策略可以有效降低Flash擦除次数。9 y8 n, x( Z+ U
/ Y7 E0 i2 X! Z
  不过,范例代码只能保存固定大小的数据(16bits),虽然容易改成不同的固定大小,但实际用起来还是很不方便。我改写了一下,新的特性包括:0 E7 T- b9 f% N" u3 C

+ W9 L& }& [# i+ \% o+ v' i支持不同大小数据(字符数组、结构体等)的混合存储;1 D3 z) P+ H( U7 h
增加对数据的校验和(Checksum)检查。. Q& u. j- V) O7 ~4 H) F
  附件提供了源码。使用方法很简单,比如要保存一个字符数组 title 和一个 point 结构体:
3 [5 e1 P: K; M- z
  1. #include "eeprom.h"& ?+ S' b" v) q$ H
  2. , c3 |( d7 h6 K/ W) W5 e
  3. #define TITLE_SIZE    80
    8 K; f+ j+ U( l: b% Q  Q. z
  4. #define TITLE_KEY     11 p; S" e& a( A( B: I* ~
  5. #define POINT_KEY     23 f* @) `6 r, S2 O* U' ^" H
  6. 1 B% u. z2 G) @  P4 N
  7. typedef struct {' k: Z- f. L" c2 Z8 @# r+ t
  8.     float x;
    2 X3 a+ y# t7 |# p0 i
  9.     float y;
      c1 q% ]& a/ D  `% n. r
  10.     float z;
    4 i6 d* N# S/ d# I7 ?. ]
  11. } Point;
      D1 o0 G3 P- e+ ?1 s
  12. $ W! J4 _3 x& M- z/ Q
  13. char title[TITLE_SIZE] = "eeprom test string.";
    . B( J* N7 G& j" j( u6 c- |$ j
  14. Point point;
复制代码

$ w+ \! z' b6 n+ p" R执行必要的初始化操作后,就可以进行写入和读取:3 a7 e8 p4 n2 t5 Q4 [2 ^; ?! V; M1 w
  1. uint16_t result = 0;
    1 e+ ~5 p" \# X* f
  2. ( C2 }, {4 D5 T1 w
  3. FLASH_Unlock();
    , b, Q1 |5 Q* O
  4.   ~1 s1 u# Z: B5 f
  5. EE_Init();/ f5 N* s! R0 S  J
  6.   a% C$ F1 E) w1 e6 |. t6 ~& m
  7. result = memcpy_to_eeprom_with_checksum(TITLE_KEY, title, TITLE_SIZE);
    8 F( I" D5 C: w7 F+ |
  8. result = memcpy_to_eeprom_with_checksum(POINT_KEY, &point, sizeof(point));( |2 ^8 l# A7 X

  9. 6 O8 O1 O- H% j
  10. result = memcpy_from_eeprom_with_checksum(title, TITLE_KEY, TITLE_SIZE);
    : j: Y! u9 P- o* P" p
  11. result = memcpy_from_eeprom_with_checksum(&point, POINT_KEY, sizeof(point));
复制代码
7 n, t2 R# m, a; X
实现混合存储的办法,是给每个变量附加8字节的控制信息。因此,在存储小数据时会有较大的空间损耗,而在存储较大的数据结构时空间利用率更高(相对于范例)。代码是针对STM32F103VE的实现。不同芯片需要对应修改头文件中 EEPROM_START_ADDRESS 的定义:1 L  F) S" I9 }% L
  1. #define EEPROM_START_ADDRESS    ((uint32_t)0x0807F000)
复制代码

5 @( v6 B0 _/ a3 J
( e# P, U( \2 ?9 P5 k7 Y" X" r- q! n$ J
收藏 评论0 发布时间:2021-11-29 22:02

举报

0个回答
关于
我们是谁
投资者关系
意法半导体可持续发展举措
创新与技术
意法半导体官网
联系我们
联系ST分支机构
寻找销售人员和分销渠道
社区
媒体中心
活动与培训
隐私策略
隐私策略
Cookies管理
行使您的权利
官方最新发布
STM32Cube扩展软件包
意法半导体边缘AI套件
ST - 理想汽车豪华SUV案例
ST意法半导体智能家居案例
STM32 ARM Cortex 32位微控制器
关注我们
st-img 微信公众号
st-img 手机版