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

【经验分享】STM32F103系列(八):初识STM2标准库

[复制链接]
STMCU小助手 发布时间:2021-11-30 22:34
1、CMSIS标准及库层次关系
. X5 m5 T9 n2 D- g- n1 x基于Context系列芯片采用的内核都是相同的,区别主要为核外的片上外设的差异,而这些差异却导致软件在同内核、不同外设的芯片上移植困难。
* w" d. E! f3 `6 I' k8 X/ f为了解决不同的芯片厂商生产的Context微控制器软件的兼容性问题,ARM与芯片厂商建立了CMSIS标准(Context Micro Controller Software Interface Standard)。
5 F! R/ k. @' s; n% T4 H& q所谓CMSIS标准,实际是新建了一个软件抽象层,见图1-1
8 O% A/ y/ S+ X7 m4 G. K0 M, _9 ^
20200507120021750.jpg

. c, g  U1 F3 W* ]; k# @/ c
5 C7 v; f% K0 U% E2 {" P0 M5 tCMSIS标准中最主要的是CMSIS核心层,它包括以下两部分。
& ]+ c  Z! @+ `; ]" ]7 l
4 Z) L  R/ A8 C6 I·内核函数层:其中包含用于访问内核寄存器的名称、地址定义,主要由ARM公司提供。
7 X' }5 u' V$ U  V$ s% U5 _# }·设备外设访问层:提供了片上的核外外设的地址和中断定义,主要由芯片生产商提供。% o  a1 q4 y% [/ A2 |7 D9 A: G
) x: B$ W1 {2 c1 d7 B& Q4 n1 E
可见CMSIS层位于硬件层与操作系统或用户层之间,提供了与芯片生产商无关的硬件抽象层,可以为接口外设、实时操作系统提供简单的处理器软件接口,屏蔽了硬件差异,这对软件的移植是有极大好处的。STM32的库就是按照CMSIS标准建立的。
* N( T  p0 }+ `1 }+ ]* c- B4 R- R0 Y, J5 @; }, Z' d4 ]
2 库目录、文件简介+ D) w$ ~6 @: t! K" Z
STM32标准库可以从官网获得,也可以直接从论坛中的配套资料得到。本书讲解的例程全部采用3.5.0库文件。以下内容请打开STM32标准库文件配合阅读。
6 x+ L2 M/ i. ?+ S1 h
( O2 h: J5 M" I; B( {+ [# I解压库文件后进入其目录STM32F10x_Std Periph_Lib_V3.5.0\,软件库各文件夹的内容说明见图1-2。& T( Y3 \/ v+ F7 M! D2 S( t
& M3 s& N, D6 X* h
20200507120717512.jpg

$ N) w" ~; M5 B* @0 e
图1-2 ST标准库

2 b; r9 G+ ?$ H
% A' N( S% \0 Q5 ?: g6 G, d·Libraries:文件夹下是驱动库的源代码及启动文件,这个文件夹非常重要,我们要使用的固件库就在这个文件夹里面。) w4 w' T$ c' y/ a( }' b( Q
·Project:文件夹下是用驱动库写的例子和工程模板,其中那些为每个外设写好的例程对我们非常有用,在学习的时候可以参考这里面的例程,非常全面,简直就是穷尽了外设的所有功能。8 n9 b3 r, {* h7 Y* r$ ~* I
·Utilities:包含了基于ST官方实验板的例程,不需要用到,略过即可。
! Y$ i1 Y, K4 }3 }3 g" l! ^! G' }·stm32f10x_stdperiph_lib_um.chm:库帮助文档,这个很有用,不喜欢直接看源码的用户可以在这里查询每个外设的函数说明,非常详细。这是一个已经编译好的HTML文件,主要讲述如何使用驱动库来编写自己的应用程序。说得形象一点,这个HTML就是告诉我们:ST公司已经为你写好了每个外设的驱动了,想知道如何运用这些例子就来向我求救吧。但是,这个帮助文档是英文的,这对很多英文不好的朋友来说是一个很大的障碍。但这里要告诉大家,英文仅仅是一种工具,绝对不能让它成为我们学习的障碍。
% [# O$ c+ x8 t1 k& G3 P7 N1 w# W
9 w! H7 e- ~! T( a4 ]: Z! O4 O9 ^在使用库开发时,我们需要把libraries目录下的库函数文件添加到工程中,并查阅库帮助文档来了解ST提供的库函数,这个文档说明了每一个库函数的使用方法。3 i* l6 V/ }. x$ Q' y
4 v% L: a  ?' X# c5 ?
进入Libraries文件夹,可以看到关于内核与外设的库文件分别存放在CMSIS和STM32F10x_Std Periph_Driver文件夹中。* \* _3 o+ V: U
7 N8 N* |8 V6 U1 H2 B% Z% {, z
1.CMSIS文件夹
' D) ~$ Z3 Y* a5 XSTM32F10x_Std Periph_Lib_V3.5.0\Libraries\CMSIS\文件夹展开内容见图1-3。
: n6 q# F/ H4 o# v1 d: D* E/ I. L* ~& L# K  t! J
20200507120744306.jpg

, r* |4 N- \& S9 g8 a0 L
图1-3 CMSIS文件夹内容
5 R/ n" T7 H& J4 M  U
4 L" [) P3 y: Q" u
! C2 S8 m: I+ O# k; \% G4 ]
其中带阴影的文件是我们需要用到的内容,下面我们一一讲解这几个文件的作用。, E% s1 T. u5 q5 o1 |9 x

$ `9 P* J% w, W2 k(1)内核相关文件
4 g" |- C  v, m8 w0 M- [在Core Support文件夹中有core_cm3.c和core_cm3.h两个文件。core_cm3.h头文件里面实现了内核的寄存器映射,对应外设头文件stm32f10x.h,区别就是一个针对内核的外设,一个针对片上(内核之外)的外设。core_cm3.c文件实现了操作内核外部寄存器的函数,用得比较少。# l+ E( J. L6 c' ~; M

) x! D6 v4 F: I& [& L  J  y0 r我们还需要了解的是core_cm3.h头文件中包含了stdint.h这个头文件,这是一个ANSI C文件,是独立于处理器之外的,就像我们熟知的C语言头文件stdio.h文件一样。它位于RVMDK这个软件的安装目录下,主要作用是提供一些类型定义,见代码清单9-1。
$ P$ M% B- d' s6 x% b' ~' r代码清单9-1 stdint.h文件中的类型定义
/ w' p; P5 P* D' v
  1.     1 /* exact-width signed integer types */
      h0 l. u* U3 [6 m! u, U6 m
  2.     2 lt@span b=1>typedef   signed7 H$ k! c0 n, I+ }5 c' `' y) k
  3.     char int8_t;
    * m6 e4 f1 D- N) c) _9 H9 a
  4.     3 typedef   signed short     int int16_t;
    , D+ T* `; [, \
  5.     4 typedef   signed            int int32_t;- ]$ ?& f" a  X4 \: @+ U* w
  6.     5 typedef   signed        __int64 int64_t;
    5 \. K+ P, K5 d1 y+ J( L4 A
  7.     6
    $ R- K1 T/ H8 f) H
  8.     7 /* exact-width unsigned integer types */
    $ d* L8 ~# T& X9 Q$ w; ~
  9.     8 typedef unsigned           char uint8_t;
    7 v4 n4 y+ J6 N: Y! ?( G  J
  10.     9 typedef unsigned short     int uint16_t;0 G, d+ a4 B, |% K+ e, u/ d
  11.    10 typedef unsigned            int uint32_t;
    $ W/ s& n2 |/ B; \. L% ?2 t
  12.    11 typedef unsigned        __int64 uint64_t;
复制代码

( U( _) l; M. A$ F( P2 L这些新类型定义屏蔽了在不同芯片平台时,出现的诸如int的大小是16位,还是32位的差异。所以在我们以后的程序中,都将使用新类型,如uint8_t 、uint16_t等。6 W$ [0 [- H. f$ G
$ O- z9 y2 c: y
在稍旧版的程序中还经常会出现如u8、u16、u32这样的类型,分别表示无符号的8位、16位、32位整型。初学者碰到这样的旧类型会感觉一头雾水,它们定义的位置在STM32f10x.h文件中。建议在以后的新程序中尽量使用uint8_t 、uint16_t类型的定义。
# T3 ]% C3 j/ A3 u. u
; o+ d2 _. D7 ?(2)启动文件
8 C. {7 S: V, V1 L9 r  w启动文件放在startup/arm这个文件夹下面,这里面启动文件有很多个,不同型号的单片机用的启动文件不一样,有关每个启动文件的详细说明见表1-1。) d4 f& n' i& a& h; u
表1-1 各启动文件匹配的芯片类型4 Q1 z+ _5 A$ `0 |& {* C6 j
6 e9 H* `$ O5 |0 z8 G! |7 t/ J$ k2 I
20200507120849621.jpg

+ H6 C  L2 A: n0 Z7 T1 r/ ~  Y
; I0 `& i; ]; O6 ]6 Y# r. ^8 [我们开发板中用的STM32F103VET6或者STM32F103ZET6中的Flash都是512k,属于基本型的大容量产品,启动文件统一选择startup_stm32f10x_hd.s。
9 i, k& g. K3 ]. @
1 _, O8 H1 K& _& F8 P+ r9 Y(3)Stm32f10x.h
) F4 u8 g" ?+ i1 `1 z3 W这个头文件实现了片上外设的所以寄存器的映射,是一个非常重要的头文件,在内核中与之相对应的头文件是core_cm3.h。; s) X+ W; k& T3 b5 }

! }- T3 Q$ r1 j0 A# k% e(4)system_stm32f10x.c  O9 i9 `$ B" i) m4 w
system_stm32f10x.c文件实现了STM32的时钟配置,操作的是片上的RCC这个外设。系统在上电之后,首先会执行由汇编编写的启动文件,启动文件中的复位函数中调用的System Init函数就在这个文件里面定义。调用完之后,系统的时钟就被初始化成72M。如果后面我们需要重新配置系统时钟,我们就可以参考这个函数重写。为了维持库的完整性,我们不会直接在这个文件里面修改时钟配置函数。2 F- ~2 J! v: a# @0 r
; j8 @3 X' c5 j% V' k
3.STM32F10x_Std Periph_Driver文件夹5 ~0 E& Z* P$ C8 _9 D
libraries目录下的STM32F10x_Std Periph_Driver文件夹见图1-4。
( ]/ D9 j8 v) q/ g图1-4 外设驱动, u- |9 O. g* }- y5 h0 K; ^/ Z
+ Z5 Z& J7 R( K3 h
20200507121543617.jpg
2 r. X$ R. B9 A( V  |  k. }; ]# |
: O, y) C9 v% [
STM32F10x_Std Periph_Driver文件夹下有inc(include的缩写)与src(source的缩写)这两个文件夹,这里的文件属于CMSIS之外的、芯片片上的外设部分。src里面是每个设备外设的驱动源程序,inc则是相对应的外设头文件。src及inc文件夹是ST标准库的主要内容,不少人甚至认为ST标准库就是指这些文件,可见其重要性。
0 f1 g# \2 ]4 `4 h9 A$ B* i  u2 n$ L3 x( g$ _' m: h
在src和inc文件夹里的就是ST公司针对每个STM32外设而编写的库函数文件,每个外设对应一个.c和.h后缀的文件。我们把这类外设文件统称为stm32f10x_ppp.c或stm32f10x_ppp.h文件,ppp表示外设名称。如在上一章中我们自建的stm32f10x_gpio.c及stm32f10x_gpio.h文件,就属于这一类。) o  h7 _, b% }& s: E6 M

  O. I2 ^9 E$ ~3 [! p  W% ^) z& N如针对模数转换(ADC)外设,在src文件夹下有一个stm32f10x_adc.c源文件,在inc文件夹下有一个stm32f10x_adc.h头文件,若我们开发的工程中用到了STM32内部的ADC,则至少要把这两个文件包含到工程里,见图1-5。5 G* p. I7 l- b/ [& d8 |6 H' s- j
) c0 f1 Z- ]4 V
2020050712145141.jpg

$ k$ ?2 ]  [) _" U: y$ K5 L* I* B- {) V- |& U0 N" B$ x" y8 e
图1-5 驱动的源文件及头文件
1 P- v# X  k' S% r  H# @, v+ Q% k# w  k# K3 k8 `
这两个文件夹中,还有一个很特别的misc.c文件,这个文件提供了外设对内核中的NVIC(中断向量控制器)的访问函数,在配置中断时,必须把这个文件添加到工程中。% E' I% t! x& @0 j& }* D

; A/ Y3 E5 @* \3 I9 j( a8 R3.stm32f10x_it.c、stm32f10x_conf.h和system_stm32f10x.c文件
9 f2 I& E6 c: H在文件目录STM32F10x_Std Periph_Lib_V3.5.0\Project\STM32F10x_Std Periph_Template下,存放了官方的一个库工程模板,在用库建立一个完整的工程时,还需要添加这个目录下的stm32f10x_it.c、stm32f10x_conf.h和system_stm32f10x.c这4个文件。
3 |& p4 |- w6 U
1 J& D1 z) J' F- N. o. v& O$ [" ~(1)stm32f10x_it.c
$ J1 _9 \( q3 i这个文件是专门用来编写中断服务函数的,在我们修改前,这个文件已经定义了一些系统异常(特殊中断)的接口,其他普通中断服务函数由我们自己添加。但是我们怎么知道这些中断服务函数的接口如何写呢?是不是可以自定义呢?答案当然不是,这些都可以在汇编启动文件中找到,在学**断和启动文件的时候会详细介绍。
! u5 v' ?" ^% _) [+ Q3 P2 e: v( Q, s0 F, J4 @8 b
(2)system_stm32f10x.c
" m; K8 z7 q0 i1 X这个文件包含了STM32芯片上电后初始化系统时钟、扩展外部存储器用的函数,例如我们前两章提到供启动文件调用的System Init函数,用于上电后初始化时钟,该函数的定义就存储在system_stm32f10x.c文件中。STM32F103系列的芯片,调用库的这个System Init函数后,系统时钟被初始化为72MHz,如需要可以修改这个文件的内容,设置成自己所需的时钟频率。但鉴于保持库的完整性,我们在做系统时钟配置的时候会另外重写时钟配置函数。
( X( i+ @1 h+ h2 H
& k6 i& l* r! a0 @( v4 K1 Z(3)stm32f10x_conf.h
% [7 D) S& N+ A) Q. k这个文件被包含进stm32f10x.h文件。当使用固件库编程的时候,如果需要某个外设的驱动库,就需要包含该外设的头文件:stm32f10x_ppp.h。包含一个还好,如果用了多个外设,就需要包含多个头文件,这不仅影响代码美观,而且也不好管理。现我们用一个头文件stm32f10x_conf.h把这些外设的头文件都包含在里面,让这个配置头文件统一管理这些外设的头文件,我们在应用程序中只需要包含这个配置头文件即可。我们又知道这个头文件在stm32f10x.h的最后被包含,所以最终我们只需要包含stm32f10x.h这个头文件即可,非常方便。Stm32f10x_conf.h见代码清单9-2。默认情况下是所有头文件都被包含,没有被注释掉。也可以把不要的都注释掉,只留下需要使用的即可。; Q6 W( a3 ^4 y7 v1 R3 Y

9 B1 f4 m8 P: F& F! h2 f代码清单1-2 stm32f10x_conf.h文件配置软件库
2 [: N5 }) l4 G+ j$ a5 Y" K6 Y( h
  1.    1 #include“stm32f10x_adc.h”
    , m5 V7 \: L; v: R. o
  2.    2 #include“stm32f10x_bkp.h”
    3 |. X. H* G% {9 N
  3.    3 #include“stm32f10x_can.h”- Z4 J) z7 w. P6 ^! @
  4.    4 #include“stm32f10x_cec.h”( L; q6 s, x; q
  5.    5 #include“stm32f10x_crc.h”
    5 p0 m  h' X, B8 H" F. l4 M
  6.    6 #include“stm32f10x_dac.h”8 x, g6 A" r* _
  7.    7 #include“stm32f10x_dbgmcu.h”- L& Y' }* _. q" p( {" Z6 k. a
  8.    8 #include“stm32f10x_dma.h”1 Y9 h- ^4 n5 x" |3 _7 u
  9.    9 #include“stm32f10x_exti.h”
    , O# x* I, @0 G6 s# ^7 [
  10.   10 #include“stm32f10x_flash.h”
    7 q% f' `+ K* n" d
  11.   11 #include“stm32f10x_fsmc.h”. U" O) g: y: ^, `5 F
  12.   12 #include“stm32f10x_gpio.h”5 u: U8 B. \* o7 v
  13.   13 #include“stm32f10x_i2c.h”
    6 j3 f: l+ U  ]1 U3 q
  14.   14 #include“stm32f10x_iwdg.h”
    , I* _0 ?  }' W9 W. b
  15.   15 #include“stm32f10x_pwr.h”
    " Q* C0 J- P! X) A! ]
  16.   16 #include“stm32f10x_rcc.h”3 _' l- H' U& j4 k
  17.   17 #include“stm32f10x_rtc.h”4 j; }: i5 `3 I2 i" Z
  18.   18 #include“stm32f10x_sdio.h”
    : X3 k5 l, Z0 r+ s6 z+ h4 }* H
  19.   19 #include“stm32f10x_spi.h”$ I9 J/ w: G. Q5 D# M2 K( u- F6 ?
  20.   20 #include“stm32f10x_tim.h”
    7 e/ y7 X* H( d6 I% g3 o
  21.   21 #include“stm32f10x_usart.h”: H0 Q. J5 U  ~0 k1 m1 }) J
  22.   22 #include“stm32f10x_wwdg.h”8 ]* L+ q+ a) c" f$ @9 o. v$ \
  23.   23 #include“misc.h”
复制代码
1 E$ t& Q' t7 g3 L9 y1 K
stm32f10x_conf.h这个文件还可配置是否使用“断言”编译选项,见代码清单1-3。$ E8 u$ G" l+ F+ p' O4 b
9 z4 Y9 P. ?- j2 j+ \
代码清单1-3 断言配置, ?" P6 I, f- v6 K, s. F
  1.    1 #ifdef  USE_FULL_ASSERT$ e) E/ p; z5 Q0 l3 o% @& P9 m* \
  2.    2 /**2 w! o1 B7 Q+ i0 M
  3.    3     * @brief  The assert_param macro is used for  parameters check.
    ! J& G* s. D7 v- g+ O
  4.    4     * @param  expr: If expr is false, it calls assert_failed function
    ; i1 B0 r4 m6 q9 t2 \; k
  5.    5     *   which reports the name of the source file and the source2 k0 i6 z  o3 A' M
  6.    6     *   line number of the call that failed.6 X- g% L! G, n2 R
  7.    7     *   If expr is true, it returns no value.8 k8 w# u% j, s# a1 K6 @
  8.    8     * @retval None( r, G% |) ?! J+ s/ [0 H3 r
  9.    9     */
    0 A: F$ q! t1 P: G' [
  10.   10 #define assert_param(expr) ((expr) ? (void)0 : assert_failed((uint8_t
    ( \3 M$ [% I" l+ [4 I' s
  11.   11 *)__FILE__, __LINE__))7 n( a3 t2 l# [3 \8 P- x
  12.   12 /* Exported functions ---------------------------------- */3 [- w# Z* C, [# e9 L
  13.   13 void assert_failed(uint8_t* file, uint32_t line);
    / y0 N: ~; m8 L' k3 T. U/ X
  14.   14 #else
    - f7 l; y/ G$ v; ]; k
  15.   15 #define assert_param(expr) ((void)0)6 [- I2 n2 s! m
  16.   16 #endif /* USE_FULL_ASSERT */
复制代码

: c- Y  G# P, ^) F在ST标准库的函数中,一般会包含输入参数检查,即上述代码中的assert_param宏,当参数不符合要求时,会调用assert_failed函数,这个函数默认是空的。
5 Y' ?" V8 c9 b' H  V5 \. o7 S
9 i: N3 c# s5 ?实际开发中使用断言时,先通过定义USE_FULL_ASSERT宏来使能断言,然后定义assert_failed函数,通常会让它调用printf函数输出错误说明。使能断言后,程序运行时会检查函数的输入参数,当软件经过测试可发布时,会取消USE_FULL_ASSERT宏来去掉断言功能,使程序全速运行。4 N5 a; S& h- d

8 v  l7 i  W& X. G; c, S4 f9 |4 库各文件间的关系

! ~8 ?8 J8 z7 L$ d前面简单介绍了各个库文件的作用,库文件直接包含进工程即可,丝毫不用修改,而有的文件就要我们在使用的时候根据具体的需要进行配置。接下来从整体上把握一下各个文件在库工程中的层次或关系,这些文件对应到CMSIS标准架构上,见图1-6。( }& w! r" y; X- b  b( [# ^3 B. A
3 Y$ ^) l# [2 Y0 s& w
20200507121415550.jpg
1 K. B7 O" F4 E; p
图1-6 库各文件关系

4 j! E$ Q2 g/ Z) n( w: d- F" ], b# }) I
图1-6描述了STM32库各文件之间的调用关系,在实际使用库开发工程的过程中,我们把位于CMSIS层的文件包含进工程,除了特殊系统时钟需要修改system_stm32f10x.c,其他文件丝毫不用修改,也不建议修改。, N# t; @9 c( \3 i6 Q" R

6 b5 w, ?  U$ t& ]0 b9 a对于位于用户层的几个文件,就是我们在使用库的时候,针对不同的应用对库文件进行增删(用条件编译的方法增删)和改动的文件。" p% }* q: G9 D
0 ^) i9 `% K# d( {6 ]4 Q
5 使用帮助文档
1 r% N9 {3 z  k( g4 X俗话说,授之以鱼不如授之以渔。官方资料是所有关于STM32知识的源头,所以本节介绍如何使用官方资料。官方的帮助手册是最好的教程,几乎包含了所有在开发过程中会遇到的问题。这些资料可以到秉火论坛下载。
$ |. Y+ g9 }0 A5 L1 e
( ^0 s, n8 E! Y9 m; n4.1 常用官方资料) ?1 C3 k6 A% z( @( t/ o+ P$ ]
1.《STM32F10X-中文参考手册》) y4 |2 |, O  G
这个手册全方位介绍了STM32芯片的各种片上外设,它把STM32的时钟、存储器架构,以及各种外设、寄存器都描述得清清楚楚。当我们对STM32的外设感到困惑时,可查阅这个手册。以直接配置寄存器方式开发的话,查阅这个文档寄存器部分的频率会相当高,但这样开发效率太低了。+ O0 Q3 r* U9 _) i& y) c) c

3 G+ a9 E& d  b2 e2.《STM32规格书》
0 i; j0 ~% O) X3 t2 _1 K+ T9 n- _) K本文档相当于STM32的数据手册,包含了STM32芯片所有的引脚功能说明,以及存储器架构、芯片外设架构说明。后面我们使用STM32其他外设时,常常需要查找这个文档,了解外设对应到STM32的哪个GPIO引脚。
0 w! m, C; I6 r; |8 M# V
+ U+ C( ^) w7 s3.《Cortex-M3内核编程手册》. {& d& s/ ^1 `7 o8 y: n2 V# W
本手册由ST公司提供,主要讲解STM32内核寄存器相关的说明,例如系统定时器、NVIC等核外设的寄存器。这部分的内容是对《STM32F10X-中文参考手册》没涉及的内核部分的补充。相对来说,本文档虽然介绍了内核寄存器,但不如以下两个文档详细,要了解内核时,可作为以下两个手册的配合资料使用。4 l  c" g& ?4 P" A, _

4 x4 R4 h" B- R8 E2 I4.《Cortex-M3权威指南》
5 x( v6 j* {% H: ]$ O; g这个手册是由ARM公司提供的,它详细讲解了Cortex内核的架构和特性,要深入了解Cortex-M内核,这是首选,是经典中的经典。这个手册已被翻译成中文,出版发行,我们配套的资料里面提供中文版的电子版。
1 h, I; W; T/ K1 I1 d5 u
7 [; z  a- Z0 o  x8 ~9 m9 E+ H5.《stm32f10x_stdperiph_lib_um.chm》( f+ x& g; n9 O5 n& J  Z& ^4 e
这个就是本章提到的库的帮助文档,在使用库函数时,我们最好通过查阅此文件来了解标准库提供了哪些外设、函数原型或库函数的调用的方法,也可以直接阅读源码里面的函数说明。* d. b8 y" [# c, ^' [* i! I

% h# }! b, }! q3 @  k3 Z! o9.2.2 初识库函数
% L( }1 _: w7 G. z, n所谓库函数,就是STM32的库文件中为我们编写好驱动外设的函数接口,只要调用这些库函数,就可以对STM32进行配置,达到控制的目的。我们可以不知道库函数是如何实现的,但调用函数时必须知道函数的功能、可传入的参数及其意义和函数的返回值。0 m  {% W5 P4 @& @) F
有读者可能会问:那么多函数我怎么记呀?回答是:会查就行了,哪个人记得了那么多。所以学会查阅库帮助文档是很有必要的。
, E0 Z  v3 J% K+ \# {( o9 c打开库帮助文档《stm32f10x_stdperiph_lib_um.chm》,见图1-7。+ H; q1 g0 n( P) l  D& P  F

  ^$ }3 a' w# @7 R' I
20200507121345363.jpg
# C: J, W; O1 _: K; f
图1-7 库帮

" B# S: f2 g5 J0 e' v' i5 E
助文档

8 N1 N) |1 E3 D4 N1 X/ t5 ^. Y层层打开文档的目录标签Modules\STM32F10x_Std Periph_Driver\,可看到STM32F10x_Std Periph_Driver标签下有很多外设驱动文件的名字:MISC、ADC、BKP、CAN等。
7 n! E5 O4 w5 c# J9 \8 G9 n0 y, L5 t/ V" W# B- m2 G, p
我们试着查看GPIO的“位设置函数GPIO_Set Bits”,打开标签Modules\STM32F10x_Std Periph_Driver\GPIO\Functions\GPIO_Set Bits,见图1-8。+ B  |# H( X2 d1 n% S& ]

) S. t- W9 K0 A
20200507121305863.jpg

8 M4 \6 G' D# c0 N, b. v
图1-8 库帮助文档的函数说明

7 j1 E) M. Q2 r! h+ Y" _4 a3 d; O: C; ^7 A' M: C
利用这个文档,我们即使不去看它的具体源代码,也知道怎么利用它了。7 `( y$ n+ r+ W
$ u9 l4 w2 s4 m. p" D8 V  |
如GPIO_Set Bits,函数的原型为void GPIO_Set Bits(GPIO_Type Def * GPIOx , uint16_t GPIO_Pin)。它的功能是:输入一个类型为GPIO_Type Def的指针GPIOx参数,选定要控制的GPIO端口;输入GPIO_Pin_x宏,其中x指端口的引脚号,指定要控制的引脚。8 A% V# }1 r3 y9 n) o1 r# N
其中输入的参数GPIOx为ST标准库中定义的自定义数据类型,这两个传入参数均为结构体指针。初学时,我们并不知道像GPIO_Type Def这样的类型是什么意思,单击函数原型中带下划线的GPIO_Type Def就可以查看这个类型的声明了。
( u- A1 }9 K# @! X* h  q" q- q0 C8 Y% |/ m9 y
就这样初步了解一下库函数,就可以发现STM32的库写得很优美。每个函数和数据类型都符合见名知义的原则,当然,这样的名称写起来特别长,而且对于中国人来说要输入这么长的英文,很容易出错,所以在开发软件的时候,在用到库函数的地方,直接把库帮助文档中的函数名称复制并粘贴到工程文件中就可以了。而且,配合MDK软件的代码自动补全功能,可以减少输入量。
6 `( c. J3 z2 g7 J1 w) ?3 X# T7 F5 l! @+ E! E" D
有的用户觉得使用库文档麻烦,也可以直接查阅STM32标准库的源码,库帮助文档的说明都是根据源码生成的,所以直接看源码也可以了解函数功能。) Y) l2 V/ }4 e2 {8 a( Q: Y

! T8 V9 D2 y3 K! ]; z8 U. q. X6 F( M( e1 ]

2 ^. r. P' r* d$ A
收藏 1 评论0 发布时间:2021-11-30 22:34

举报

0个回答

所属标签

相似分享

官网相关资源

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