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

【经验分享】STM32F0xx_FLASH编程(片内)配置详细过程

[复制链接]
STMCU小助手 发布时间:2021-11-20 23:00
Ⅰ、概述% u6 d! c! N0 p
关于数据的储存,我觉得编程的人基本上都会使用到,只是看你储存在哪里。STM32的芯片内部FLASH都是可以进行编程的,也就是说可以拿来储存数据。但是,很多做一些小应用程序开发的人都没有利用好这个功能,而是单独外接一个EEPROM或者FLASH,我觉得有些情况下(小数据、不常改动)这是对资源的一种极大浪费。
& a6 U# j, B7 }* Z  y, S! q4 |' O& _- u1 T/ |( V
关于使用内部FLASH进行编程,网上也有很多人这么说:1、内部FLASH的读写次数有限;2、内部FLASH会破坏程序。这些说法确实存在一定道理,对于次数,10W次,我想这个次数除非你经常写FLASH,正常情况下你打不到这个值。对于破坏程序,如果你编程严谨,这个不是问题。综上,我觉得这些都不是担心的问题,只要你用心编好程,这样就能利用好资源。# p5 ~4 Z$ ?% w
, Q/ k) G+ x, I1 ~3 A
举一个存在的例子,我三年前在STM32F1上面开发了两个产品(已经投入使用),储存的数据量一个差不多在6K左右,每使用一次,读写的次数差不多在5-10次左右,但是该产品至今还未因FLASH而出现过问题。所以说,利用好资源也是作为一位软件工程师需要考虑的。& @9 g  l2 Z. L! r9 a

! ?! N, Q5 ~# g' x$ y! O- K提示:为了安全起见,写的次数最好做一个预估,储存的地址最和程序存在一定的距离。
" y5 b. ?+ R+ z8 y) B  [& ?' i  W. p6 ]$ ]0 I8 d
# m& h! I1 P3 I6 p
Ⅱ、下载
) F& @# \+ G: ?' S& d8 h8 S, U( b* {5 S3 G6 ~
文章提供的“软件工程”都是在硬件板子上进行多次测试、并保证没问题才上传至360云盘,请放心下载测试,如有问题请检查一下你的板子是否有问题。4 a# `2 y( z8 X: j

# u. ~- v6 ?. d: z! A# TST标准外设库和参考手册、数据手册等都可以在ST官网下载,你也可以到我的360云盘下载。关于F0系列芯片的参考手册有多个版本(针对F0不同芯片),但有一个通用版本,就是“STM32F0x128参考手册V8(英文)2015-07”建议参考该手册,以后如果你换用一种型号芯片也方便了解。9 t9 X% C2 X# S9 t) S

% E* |  @7 W  l! uⅢ、准备工作
5 n+ Y1 [5 ~3 F5 I$ v% B3 L% R* `0 F8 ]" a% p- v: n  o! _2 n' |
对于内部FLASH的编程,建议大家准备F0的参考手册和数据手册,方便查阅相关知识,没有的请到ST官网或到我360云盘下载。
6 X9 _" a/ V" n% p2 C3 `5 E
0 b2 A& o8 U  l7 C今天总结的软件工程是基于“TIM基本延时配置详细过程”修改而来,因此需要将该软件工程下载准备好。我每次都是提供整理好的软件工程供大家下载,但是,如果你是一位学习者,建议自己亲手一步一步操作:打开工程-> 新建文件(flash.c  flash.h) ->添加相关文件到工程中 ->添加源代码。
1 X9 }% \" s: K) v1 o2 k) Q
+ w) `. D5 R2 nⅣ、FLASH编程说明
% W# _. [$ z( \
9 u1 q+ ]+ U" R6 L$ HSTM32F0系列芯片中页的大小都是规则的,也就是说都是1K或许2K大小(如图:F0_FLASH),学过其他系列芯片的人可能知道,在其他很多芯片中也有不是规则的,如F2、F4中基本都不是规则的(如图:F4_FLASH),有的一块16K、128K等不规则。这样的芯片对于今天提供的工程就不适用,今天提供工程适用于内部FLASH规则大小的芯片。
0 @( L' e) L4 C  o" K9 @+ h; h
+ X' M, Z# L% }# s! ?
20160606234037003.png
  U  G3 J! I4 _# P
图:F0_FLASH  z7 `/ }5 V" W1 w9 P$ O7 y* L/ X

2 u$ w+ w( F  A4 O& v! @. P
20160606234052222.png
5 y6 i5 X% j& {1 i: l
图:F4_FLASH
- U  |8 Q+ S+ z" r$ Y0 @* w/ ]$ D# c' X9 q: `# S( {
Ⅴ、代码描述
% ?( r" Z! F. |. ~5 A9 [# s* n# @  b* }3 Z
工程概要说明: 提供工程的源代码主要就是两个接口,一个写,一个读。
9 ?  P- E* Q3 [: m& g7 a; N0 |9 @; m' @4 o5 J) p
void FLASH_WriteNWord(uint16_t* pBuffer, uint32_t WriteAddr, uint16_t nWord);
, T. Y. b* Y" E8 ]
* F$ K, U3 D  wvoid FLASH_ReadNWord(uint16_t* pBuffer, uint32_t ReadAddr, uint16_t nWord);
- F" D" z7 ?* i8 t) M
6 U+ F+ W* J# }; q4 f% U! _1 _" z相信经常编程的人都明白函数接口的意思(我的命名规则还是算比较人性化的),就是和常见的访问外部FLASH一样,不会覆盖数据,我已经在实际工作中应用而且商业化了。
" |& p1 ]/ f4 M6 S! n5 _5 W8 o7 Q' b5 F
主要在地址“ADDR”处写一个标志位,在地址“ADDR + 1”连续写一串数据。如果标志位已经是“写过”,则不会再次写入数据,只会读取数据,意思就是说数据只写一次,以后每次只是读取数据(就是保证掉电后数据会不会丢失)。每次读取数据,通过串口打印出以前写入的数据是否正确。7 O/ t# r1 D9 E8 Z0 ?& l" Q( U, w9 m
5 H1 s7 g7 T8 A' \) D
提供的工程以简单为原则,详细中文注释,方便自己方便大家。
( D, m* D$ ?; j( v; V2 s0 e: `+ V# x0 ]' u4 R) _6 d: L; G
①读函数接口
0 J8 V! I" W0 j3 ~; f0 R+ {# I. j. B" }. q- ?4 H
20160606234109409.png
9 @( n2 }9 b7 V4 x2 w4 B
该函数位于flash.c文件下面;( O7 t* m1 w: V6 D* L4 Y
) T& ~, q3 r+ Y& b
这个函数接口比较简单,直接地址读数据。
* M3 T/ g9 A2 C4 V. u( F1 J7 u5 J- \6 |9 F5 u& j, u
注意:9 r& z3 j, o; \* R8 M- j) J

: ]. o" a: w: |; i* }6 C* f9 V" FA.参数pBuffer是数据缓冲区,是16位的,而不是8位的。(其实这里可以整理为8位的,由于时间有限,后期整理一下)。% u# `  Y/ {3 ~. |

: C, m0 T( s& s# m% J7 H+ PB.参数长度也是16位的数量。
. V6 }% y! J7 U9 U
6 O9 u. m, g" q: PC.地址是内部FLASH地址,可别溢出了,也别和程序储存地址冲突。最好看看你的程序大小及芯片容量。( i2 J  ]/ Z  E' s* Z- H" \. a

7 n5 T2 v6 M* C+ ]) H7 S) O1 D) W) G* Q2 ^. V$ b
②写函数接口8 U6 I7 R$ I; p9 U
8 z/ f, E, H% I. l9 m' [
20160606234116846.png

' V5 Z- T: f& L  u) S0 u& Q
20160606234124628.png

1 _6 ^3 B* c" u- u5 E5 o4 [
( K2 K, x6 ]9 g 该函数位于flash.c文件下面;( `, U6 O: C7 t6 {- F

' j! E# l1 N5 A/ x7 \这个函数接口FLASH_WriteNWord才是本文的重点,原因在于这里的写不会破坏其它数据(哪怕是临近地址),这个函数接口是比较现成的,也就是应用级的接口。经过我大量测试和项目开发,暂未发现bug。
) J; M- \7 n0 [) `' E( L. R6 g% ]6 s# Z# A0 V! G
③重点# u0 \( ~. ^3 Q% P: _9 j# }7 a
; ~  A) n5 p6 H
A.页的大小:STM32F0因芯片型号差异请注意页的大小,我在程序中用一个宏来定义也的大小。
* l2 D& D) h8 X: p+ a) |1 N* N8 ~" P, S! ?0 z6 ~8 v0 R/ x
Ⅵ、说明
. ~9 c1 Z2 l3 b7 Q
1 q  f9 P0 [5 g$ c3 y' H# b或许你硬件芯片不是提供工程里面的芯片,但是STM32F0的芯片软件兼容性很好,可以适用于F0其他很多型号的芯片,甚至是F2、F4等芯片上(具体请看手册、或者亲自测试)。
' _% s7 `$ P, I8 \- T5 {% F/ Y1 P. F" G( r
本文章提供的软件工程是基于ST标准外设库为基础建立而成,而非使用STM32CubeMX建立工程。个人觉得使用ST的标准外设库适合与学习者,STM32CubeMX建立工程结构复杂,对于学习者,特别是初学者估计会头疼。
# l6 [+ G7 t. f! a4 H
5 U; Q# i  Y4 X今天的工程是基于工程“STM32F0xx_TIM基本延时配置详细过程”修改而来,以上实例总结仅供参考,若有不对之处,敬请谅解。3 c/ Q; L, K. F3 X! V; ?, s5 D; B
, j& K& J$ Q$ c

$ x# i1 {) l& R+ K! R: J8 y
收藏 评论0 发布时间:2021-11-20 23:00

举报

0个回答

所属标签

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