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

【nucleo板开发日志】ST标准外设库是如何把数据写入寄存器

[复制链接]
平淡~简单 发布时间:2014-9-26 12:11
nucleo开发板接到手好久了,就简单体验了一下mbed开发环境,的确很好玩。但是也没有仔细的研究,以前对STM32的标准外设库做了一点研究,这次贴上来,给新手做一些参考。就当是我的开发日志了,忙过这一段好好的,研究一下mbed的开发。(顺便提一下,忙着考研复习,所以可能得三个月不能玩STM32了)。废话不多说,上干货。( B' Z: u  R" f; r# d
主要讲解一下,他的标准外设库是如何进行操作,把我们设置的一些参数,写入对应的寄存器地址当中。
- v/ O6 w4 P6 _. Q这里以void GPIO_SetBits(GPIO_TypeDef* GPIOx, uint16_t GPIO_Pin)函数为例:这个函数的第一个参数是STM32的端口值,第二个参数是端口的引脚。也就是把对应的端口引脚的位置1
; P( D- F' E( O1 a第一个参数是一个结构体类型,用keil的定位查找功能可以找到宏定义#define GPIOF   ((GPIO_TypeDef *)  GPIOF_BASE),这句代码把GPIOF_BASE强制转换成了一个结构体,而这个结构体GPIO_TypeDef里面的参数,就是端口的寄存器。如下图所示 1.png - A9 t0 i  y- \9 ]
通过查找技术参考手册,这些变量的命名和寄存器的名字是一样的,方便使用。其中不可操作的位,被定义成保留的位。
- _2 B: ]. N* F在STM32F30x.h里面可以找到下面的一些宏定义,1 f7 x3 }: w7 H# r1 n  T
#define GPIOA               ((GPIO_TypeDef *) GPIOA_BASE)
, z- e8 W2 ~7 K! Q6 x( f#define GPIOB               ((GPIO_TypeDef *) GPIOB_BASE). r4 x7 M" q6 d. d% }$ X
#define GPIOC               ((GPIO_TypeDef *) GPIOC_BASE)+ C/ `: _3 o+ U- M
#define GPIOD               ((GPIO_TypeDef *) GPIOD_BASE)1 K4 R7 o2 f- _0 s- J
#define GPIOE               ((GPIO_TypeDef *) GPIOE_BASE)
! H/ z* V- ~% m; z5 f# j#define GPIOF               ((GPIO_TypeDef *) GPIOF_BASE)
6 ]8 `( r1 t5 T( k  X! @在这里它强制把GPIOx_BASE转换成了GPIO_TypeDef结构体的形式。 然后查找GPIOx_BASE可以看到。+ a. s. r) z, w8 h$ `0 O5 n
/*!< AHB2 peripherals */
. b' [* W$ f  t8 z#define GPIOA_BASE            (AHB2PERIPH_BASE + 0x0000)6 Y( t' A' W5 k
#define GPIOB_BASE            (AHB2PERIPH_BASE + 0x0400)
9 r1 v% X9 V- E( n#define GPIOC_BASE            (AHB2PERIPH_BASE + 0x0800); r4 N. D, @' g7 X1 R) e4 v) P8 Y
#define GPIOD_BASE            (AHB2PERIPH_BASE + 0x0C00). s6 O/ V2 f8 @: A$ f9 t& K6 I- }$ n
#define GPIOE_BASE            (AHB2PERIPH_BASE + 0x1000)
( ]7 \  I, [- W8 U#define GPIOF_BASE            (AHB2PERIPH_BASE + 0x1400)
9 i. G/ [, @5 J2 j2 `* L# L根据不同的型号的,他们的定义稍有不同,不过都类似,这里GPIO是挂在AHB2总线上的。
/ i2 F9 n/ @, K! f  Z4 H& ?/ V继续查找AHB2PERIPH_BASE可知1 b" f6 b& m( N  c
 #define AHB2PERIPH_BASE       (PERIPH_BASE + 0x08000000)
' [/ f$ P& U; C. E! I" |#define PERIPH_BASE           ((uint32_t)0x40000000)% ^' J1 C" e; e6 N9 e
通过计算可以得到5 u0 M1 m9 D" B3 b, B" b
GPIOA_BASE=0x40000000 + 0x08000000 + 0x0000=0x48000000
- }  \* w6 K/ B2 `通过查找数据手册,如下图所示6 u: W0 ]% `0 @6 x
2.png 7 A5 n- n1 ^* G$ F) S  D
可以知道就是GPIOA的寄存器基地址,其它也都和这个一样。在最上面把这个基地址强制转换成了GPIO的结构体类型的地址,这样就可以通过操作结构体里面的成员,把数据写入对应的寄存器。
9 a; g( x6 R+ J4 c, F- K1 R9 r再说一个小的知识点,对堆栈的设置,在启动函数里面如下图所示:
2 b% k- P9 g8 K* b 3.png
; h6 Z# }( `+ h/ y3 E2 w! ?在这地方限制了堆stack的大小为0x400,栈的大小Heap的为0x200,如果你要在子函数中开辟较大的空间或者需要较大的数组时,相应的需要扩大这两个值。
+ p( W& f2 n& @$ @2 l1 V好了,就写这么多吧,希望对于新手能够有帮助。" b+ v; W0 J3 c, ~/ t1 e0 B
以后有机会要多参加ST社区的活动。再次支持一下ST社区,刚才看到M7出来了,很期待,希望ST有更好的芯片出来。% n9 n* _; m! w/ G! n7 j
 
收藏 评论1 发布时间:2014-9-26 12:11

举报

1个回答
沐紫 回答时间:2014-9-26 13:10:08

RE:【nucleo板开发日志】ST标准外设库是如何把数据写入寄存器

灰常谢谢楼主的支持~

所属标签

相似分享

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