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

Firmware Lib在EK_STM32F上的学习体会(FLASH/GPIO)

[复制链接]
qazwsx-19104 发布时间:2008-9-3 19:11
Exemple 1, w" _7 A, X3 J8 n/ x5 l

1 g* O# b$ v" R/ P( |3 U本例展示了如何对STM32的FLASH写入数据。8 K) F" n/ E  }1 V7 c

" L( o# n# F# Z% M6 q' l+ `" K在RESET以后,FLASH存储器的写/擦控制器(Flash memory Program/Erase Controller)是被锁住的,为了能够写入数据,首先要求对控制器解锁(FLASH_Unlock())。
4 r5 V# Z. [1 J& V7 U! M- F
7 {/ ?8 O' i1 F在写入数据前,程序首先擦除所有要编辑的页面。擦除程序首先计算需要的页面数目,然后通过不断调用FLASH_ErasePage函数进行逐页擦除。之后,程序不断调用FLASH_ProgramWord函数对FLASH写入数据。待整个过程完成以后,检查FLASH中的数据是否已被正确写入,检查结果放在变量MemoryProgramStatus中。! V1 C6 v# Z3 r8 R5 ]( ]3 e

; @0 A! f+ y; F' O% {Exemple 1
6 ]% A, C3 L- @2 \% K+ e
( X0 j3 j* V9 F* K' G# |本例展示了如何开启/关闭STM32 FLASH存储器的写保护功能。
/ q, O9 l/ G! }( u
1 s# |: v- v6 b: ?# U" W打开写保护功能:0 d: a: T7 w) m) r6 N
在程序中,取消“#define WriteProtection_Enable”前的注释符号,即可打开写保护功能。想要对一系列页面进行写保护的话,用户可以调用FLASH_EnableWriteProtection函数,通过设置该函数的参数,我们可以对任意页面进行写保护。在本例中,我们想要对24 — 31这八个页面进行保护,因此,参数为"FLASH_WRProt_Pages24to27 | FLASH_WRProt_Pages28to31"。5 k; A5 X5 |" Z5 {" L

* ^& j7 V$ x) v3 r) @+ ?为了对载入新的option byte 值,需要对系统进行复位,因此,我们调用函数 NVIC_GenerateSystemReset()。$ G  K& w7 K1 g# ]) n) O
  |( v) ^* U  R7 [/ j. r9 p
关闭写保护功能:
) [2 m5 A. m5 l- K) n1 z在程序中,取消“##define WriteProtection_Disable”前的注释符号,即可关闭写保护功能。为了关闭写保护,用户必须擦除小信息模块(small information block)。此操作可以通过调用函数FLASH_EraseOptionBytes来实现。: J% ~! v8 K) B
) w# r9 F# E6 B7 o/ o: r
同样的,为了对载入新的option byte 值,需要对系统进行复位,因此,我们调用函数 NVIC_GenerateSystemReset()。
( |4 c: ?, V  ^7 Q& r' q) @& r+ ~4 M3 s0 F" }2 Y( R, l
在本例中,程序将对被保护页面进行一次擦-写的操作,并在最后检查操作的完成情况,并把检查结果放在变量MemoryProgramStatus中。显然,如果打开了写保护功能,那么结果将是FAILED,如果没有,结果将是PASSED。! \; q  y* g3 ~. D. u& x3 Y. h
& V' Y5 M# G9 O/ z( f
Exemple 1% X$ R* |! k' q2 f) q" X
, Y, z. F2 I1 _2 d- V
本例展示了如何通过设置GPIO BSRR寄存器(Port bit set/reset registe)和GPIO BRR寄存器 (Port bit reset register)来翻转IO的状态。
- x% w4 Q# f, i: N- v7 V7 F4 u  v: O" g* ], M  W' y
通过设置这两个寄存器,我们可以利用单比特操作(single atomic write access)来改变一个或者几个IO端口的状态。/ F2 {( ?5 X) q

& r- v9 ]1 I( g; x* k( W这个例子原本应用于STM32评估板(STM3210B-EVAL),为了使本例能在EKSTM32F上运行,我们应当把使用端口PC.06 – PC.09改为使用PC.04 – PC.07。/ y/ b3 N; J6 X

( }  Y( Z& G8 q1 QExemple 2$ L5 m" W3 U: d9 Q8 l% s% c* w1 g

  b( o9 y6 s* z本例展示了如何把JTAG专用管脚设置为标准的GPIO。
" ?; F5 l, @( X" k/ B
! t* V, G9 m: n1 P首先,关闭SWJ-DP,把SWJ-DP管脚设置为标准的push-pull输出。然后,循环地改变PA.13(JTMS/SWDAT), PA.14(JTCK/SWCLK), PA.15(JTDI), PB.03(JTDO) 和PB.04(JTRST)这五个管脚的状态。使与之相连的LED闪耀。在EKSTM32F板上,不存在这样的五个LED,要观察效果的话,需要自己连上去。
) A; v! E6 \! R; @, Y( X+ r, ]) `6 X# l  Q+ r
注意,一旦JTAG管脚被用作它用,将无法再使用debug工具。为了避免这个问题,程序将检查PB.09上的数据,它与一个按钮相连,当输入为低电平时,JTAG专用管脚被设为标准的IO。当输入为高电平时,这些管脚仍然用作JTAG。+ N5 t9 R4 \5 H8 P0 |, Q

- U4 J4 E) x% N# o出处:barboon
收藏 评论2 发布时间:2008-9-3 19:11

举报

2个回答
nokoyu-113155 回答时间:2009-6-10 16:38:40

RE:Firmware Lib在EK_STM32F上的学习体会(FLASH/GPIO)

heishadow-13786 回答时间:2010-11-9 18:44:40

RE:Firmware Lib在EK_STM32F上的学习体会(FLASH/GPIO)

!

所属标签

关于
我们是谁
投资者关系
意法半导体可持续发展举措
创新与技术
意法半导体官网
联系我们
联系ST分支机构
寻找销售人员和分销渠道
社区
媒体中心
活动与培训
隐私策略
隐私策略
Cookies管理
行使您的权利
官方最新发布
STM32N6 AI生态系统
STM32MCU,MPU高性能GUI
ST ACEPACK电源模块
意法半导体生物传感器
STM32Cube扩展软件包
关注我们
st-img 微信公众号
st-img 手机版