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

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

[复制链接]
STMCU小助手 发布时间:2021-11-20 23:00
Ⅰ、概述
: }' w* n! V+ ~关于数据的储存,我觉得编程的人基本上都会使用到,只是看你储存在哪里。STM32的芯片内部FLASH都是可以进行编程的,也就是说可以拿来储存数据。但是,很多做一些小应用程序开发的人都没有利用好这个功能,而是单独外接一个EEPROM或者FLASH,我觉得有些情况下(小数据、不常改动)这是对资源的一种极大浪费。7 C) {! W/ X; l8 F

' {1 L% l* z6 W2 p0 g. q/ I关于使用内部FLASH进行编程,网上也有很多人这么说:1、内部FLASH的读写次数有限;2、内部FLASH会破坏程序。这些说法确实存在一定道理,对于次数,10W次,我想这个次数除非你经常写FLASH,正常情况下你打不到这个值。对于破坏程序,如果你编程严谨,这个不是问题。综上,我觉得这些都不是担心的问题,只要你用心编好程,这样就能利用好资源。1 s6 ^) t: M  B

& H: e' S9 i. r3 @1 N举一个存在的例子,我三年前在STM32F1上面开发了两个产品(已经投入使用),储存的数据量一个差不多在6K左右,每使用一次,读写的次数差不多在5-10次左右,但是该产品至今还未因FLASH而出现过问题。所以说,利用好资源也是作为一位软件工程师需要考虑的。
; v! _- z, c1 Z. c8 y( ^5 f5 p# O% s- A/ N- ]
提示:为了安全起见,写的次数最好做一个预估,储存的地址最和程序存在一定的距离。
$ P6 q+ s! X7 [1 P3 ~  z  q% A
! K1 t3 U2 x* \+ e
$ Z7 U% V% {9 w% Q9 X. L# e: X! oⅡ、下载
% k7 J( K' W; r' o! z# m
; }0 f$ P! ~8 n  k9 |" [文章提供的“软件工程”都是在硬件板子上进行多次测试、并保证没问题才上传至360云盘,请放心下载测试,如有问题请检查一下你的板子是否有问题。/ ~3 i( \& w  t# M  Y8 q
1 e: |5 f! V4 c' f" i
ST标准外设库和参考手册、数据手册等都可以在ST官网下载,你也可以到我的360云盘下载。关于F0系列芯片的参考手册有多个版本(针对F0不同芯片),但有一个通用版本,就是“STM32F0x128参考手册V8(英文)2015-07”建议参考该手册,以后如果你换用一种型号芯片也方便了解。5 V; H: |. u) T. I% \

( D. E: X. U8 Q( R3 SⅢ、准备工作  n7 q$ V5 k% r! u- h
+ {1 X) q6 O9 o% H9 t. h* `
对于内部FLASH的编程,建议大家准备F0的参考手册和数据手册,方便查阅相关知识,没有的请到ST官网或到我360云盘下载。" U: I& l* z, c, P4 D/ {, B& s

# _+ h7 |' w- O$ z) K7 \2 i. P今天总结的软件工程是基于“TIM基本延时配置详细过程”修改而来,因此需要将该软件工程下载准备好。我每次都是提供整理好的软件工程供大家下载,但是,如果你是一位学习者,建议自己亲手一步一步操作:打开工程-> 新建文件(flash.c  flash.h) ->添加相关文件到工程中 ->添加源代码。/ l- x# B6 k8 T( o

& s; A, d7 U& ?Ⅳ、FLASH编程说明
2 {8 Q) E1 c  B" ]
% f* P. w$ a1 T: M) aSTM32F0系列芯片中页的大小都是规则的,也就是说都是1K或许2K大小(如图:F0_FLASH),学过其他系列芯片的人可能知道,在其他很多芯片中也有不是规则的,如F2、F4中基本都不是规则的(如图:F4_FLASH),有的一块16K、128K等不规则。这样的芯片对于今天提供的工程就不适用,今天提供工程适用于内部FLASH规则大小的芯片。8 }4 w5 z8 G. m! t. l
2 M3 v) u5 M' K
20160606234037003.png

, l4 h- a  |) N9 Q/ X6 _图:F0_FLASH( S; c3 W% V2 Q
6 g9 l) g( W1 a
20160606234052222.png
/ I. ^5 ~7 Z7 p" D( A" e
图:F4_FLASH
) \  \7 N/ O( d( @
$ C# r& G( ^5 x/ }Ⅴ、代码描述8 i. C5 B6 T. o6 _8 d/ ^
$ D/ D% z, P7 ~! E" H* F' {; Q5 e! b& k
工程概要说明: 提供工程的源代码主要就是两个接口,一个写,一个读。
# C7 ^2 y0 T7 _$ l$ i3 S  }3 Q0 y/ Q" C0 _  {
void FLASH_WriteNWord(uint16_t* pBuffer, uint32_t WriteAddr, uint16_t nWord);
, L& r$ |4 z' R* h' Q1 ]
: W# q: I0 A6 ^  T8 ^void FLASH_ReadNWord(uint16_t* pBuffer, uint32_t ReadAddr, uint16_t nWord);3 D3 W; H8 z! d, ]  ]

2 a. N- s5 l- `相信经常编程的人都明白函数接口的意思(我的命名规则还是算比较人性化的),就是和常见的访问外部FLASH一样,不会覆盖数据,我已经在实际工作中应用而且商业化了。8 x8 R5 W6 L; F4 Q: Q1 G

8 Z& ~3 O) L3 R主要在地址“ADDR”处写一个标志位,在地址“ADDR + 1”连续写一串数据。如果标志位已经是“写过”,则不会再次写入数据,只会读取数据,意思就是说数据只写一次,以后每次只是读取数据(就是保证掉电后数据会不会丢失)。每次读取数据,通过串口打印出以前写入的数据是否正确。! w" C2 G5 S' z( `0 W9 x

" |* d: A0 C/ h7 r# t; K- `4 ?  @* N提供的工程以简单为原则,详细中文注释,方便自己方便大家。, v7 U: P" @' }* \3 O! I9 d( `
7 L* Y: }! e9 L
①读函数接口
7 p4 t/ z. U& x% w$ b# k4 U! B, M6 _" Q# G
20160606234109409.png

5 E1 F: B! t  V0 p1 b该函数位于flash.c文件下面;; E; @. D) ~/ E! X% l+ c( o; k9 F" q5 g0 |

0 y* r' B1 J2 W# Y6 n这个函数接口比较简单,直接地址读数据。. R0 O1 ?, J$ @# g
8 n- J5 ~# y, i- p  G4 @; ~, j
注意:
* O$ @; U% \7 d( l
- \$ M  q  R5 n4 I! O: l0 N1 M/ {1 AA.参数pBuffer是数据缓冲区,是16位的,而不是8位的。(其实这里可以整理为8位的,由于时间有限,后期整理一下)。- }7 a8 D- y& }( n3 W! q3 h
$ \# _) k, X. }/ i% C/ _
B.参数长度也是16位的数量。- D. L4 J& u6 h; N9 P, A

& `- [' P5 ~; ?0 j  N# d/ KC.地址是内部FLASH地址,可别溢出了,也别和程序储存地址冲突。最好看看你的程序大小及芯片容量。
( c& t, p) S. D3 o4 h2 t; b% \( H$ {' Y4 F# H
5 `' W/ ]9 G) w% J1 d+ e8 ]
②写函数接口
* i- O' p" K2 }9 H, M% \
) k* Z9 Q- x! I. L7 [. b* J
20160606234116846.png

2 K1 Q+ e" y  ~* c2 b
20160606234124628.png

2 N" X$ {# _$ W% ?& ^( O. s
* Y. m& d* w" H: l: y 该函数位于flash.c文件下面;3 Y0 y7 {2 a+ L' S+ O
4 p4 U8 v  D. o7 E& f
这个函数接口FLASH_WriteNWord才是本文的重点,原因在于这里的写不会破坏其它数据(哪怕是临近地址),这个函数接口是比较现成的,也就是应用级的接口。经过我大量测试和项目开发,暂未发现bug。
! @6 q* e1 I9 z% e! W% r- w0 z9 r  w* l8 L
③重点7 k  O7 Q1 e* E; x& j

) r( G* _  j1 U9 U3 K. rA.页的大小:STM32F0因芯片型号差异请注意页的大小,我在程序中用一个宏来定义也的大小。
. b  x+ K) {9 G/ ?3 q9 [1 d) W2 W# ~  Y5 Z) i$ Q
Ⅵ、说明% s( l4 R7 }" B& L. N) e% [
% j7 B" Z; S8 V; v* c: v
或许你硬件芯片不是提供工程里面的芯片,但是STM32F0的芯片软件兼容性很好,可以适用于F0其他很多型号的芯片,甚至是F2、F4等芯片上(具体请看手册、或者亲自测试)。0 R( A; t/ A) z3 r* U

  A8 [/ ?. k& G( e本文章提供的软件工程是基于ST标准外设库为基础建立而成,而非使用STM32CubeMX建立工程。个人觉得使用ST的标准外设库适合与学习者,STM32CubeMX建立工程结构复杂,对于学习者,特别是初学者估计会头疼。5 \) K- @# n4 Z8 Q. q; X& J
/ }8 }" s+ o: L5 j0 ]4 K% m
今天的工程是基于工程“STM32F0xx_TIM基本延时配置详细过程”修改而来,以上实例总结仅供参考,若有不对之处,敬请谅解。/ x. [4 F% M( o4 V0 n8 I6 k' R

: M& Y6 [* t% Y( P0 c* L1 f- _- m- M1 l1 B
收藏 评论0 发布时间:2021-11-20 23:00

举报

0个回答

所属标签

相似分享

关于意法半导体
我们是谁
投资者关系
意法半导体可持续发展举措
创新和工艺
招聘信息
联系我们
联系ST分支机构
寻找销售人员和分销渠道
社区
媒体中心
活动与培训
隐私策略
隐私策略
Cookies管理
行使您的权利
关注我们
st-img 微信公众号
st-img 手机版