01. GPIO复用概述# j) m5 O2 C$ b
STM32F4 有很多的内置外设,这些外设的外部引脚都是与 GPIO 复用的。也就是说,一个 GPIO如果可以复用为内置外设的功能引脚,那么当这个 GPIO 作为内置外设使用的时候,就叫做复用。
# t1 {" Q$ p4 E6 I( N. L0 p n, S6 D d; i" R4 r" b3 G9 T
STM32F4 系列微控制器 IO 引脚通过一个复用器连接到内置外设或模块。该复用器一次只允许一个外设的复用功能(AF)连接到对应的 IO 口。这样可以确保共用同一个 IO 引脚的外设之间不会发生冲突。
8 f) K7 H, Z: n1 s/ S5 y( a- z5 h
每个 IO 引脚都有一个复用器,该复用器采用 16 路复用功能输入(AF0 到 AF15),可通过GPIOx_AFRL(针对引脚 0-7)和 GPIOx_AFRH(针对引脚 8-15)寄存器对这些输入进行配置,每四位控制一路复用- t( e( p- U, m
/ m% _2 f6 B6 ~9 Z( t9 z) r
1)完成复位后,所有 IO 都会连接到系统的复用功能 0(AF0)。
. u0 y. o& @: c; h9 R- ` R8 C2)外设的复用功能映射到 AF1 到 AF13。( W+ L" N/ h! T3 e9 _6 @
3)Cortex-M4 EVENTOUT 映射到 AF15。
( N1 a8 p% Q7 @6 l6 b3 Q
_+ ]& c) ` q O& }3 { \
1 X! O; m& \( j: N/ Q0 d5 L, f2 V, @8 y7 s+ F8 P9 f, t9 L' n. O) m
02. 寄存器描述" F: S; T/ [! A4 ?
探索者 STM32F407 开发板的原理图上 PC11 的原理图如图 所示:
. f! y& a2 I+ r1 b5 o9 ~
- z+ A p* v- W2 K0 ?/ R1 l
9 I, Z1 m" g) e# q4 K
4 P" D4 q# ?7 m5 \4 zPC11 可以作为 SPI3_MISO/U3_RX/U4_RX/SDIO_D3/DCMI_D4/I2S3ext_SD等复用功能输出,这么多复用功能,如果这些外设都开启了,那么对 STM32F1 来说,那就可能乱套了,外设之间可互相干扰,但是 STM32F4,由于有复用功能选择功能,可以让 PC11 仅连接到某个特定的外设,因此不存在互相干扰的情况。
1 R: x8 M, h: j. b/ J
: f5 X8 {" c: b9 M: T$ L. ]- q8 _GPIO 复用功能低位寄存器 (GPIOx_AFRL) (x = A…I)% q6 G$ h* b& m( D; t
GPIO alternate function low register
, R; G; R. ~. Y O偏移地址:0x20
' ~+ f) Y* [& r1 r复位值:0x0000 0000
; o! s! z& F' |8 w- b" x
7 s( o: j0 ^( R; p0 A* A
, s+ c& _9 p! r2 U0 @
2 {4 u' e" F" S; M( d0 MGPIO 复用功能高位寄存器 (GPIOx_AFRH) (x = A…I)0 v4 r$ I& \3 o4 k: q6 |$ _
GPIO alternate function high register Z, B, ?* ?" R0 l# ?
偏移地址:0x24
) H$ ?6 C6 I$ S1 w) O复位值:0x0000 0000) c6 H7 H* }7 X
, u" Y: o, t3 ^" n6 y2 a% ?. ]
4 P% [7 J) W: R& r5 v2 d8 i+ D" X# h% \
在微控制器完成复位后,所有 IO 口都会连接到系统复用功能 0(AF0)。这里大家需要注意,对于系统复用功能 AF0,我们将 IO 口连接到 AF0 之后,还要根据所用功能进行配置:
( U, d9 z4 [3 y9 v; q
+ `# Q- Z& B8 P" U1 i1.JTAG/SWD:在器件复位之后,会将这些功能引脚指定为专用引脚。也就是说,这些引脚在复位后默认就是 JTAG/SWD 功能。如果我们要作为 GPIO 来使用,就需要对对应的 IO口复用器进行配置。0 D! G& F2 v. R1 T/ n+ \
( F/ ^# z6 E' w* W3 N
2.RTC_REFIN:此引脚在系统复位之后要使用的话要配置为浮空输入模式。# D7 ~4 t5 h7 C. E9 `
, Y- y/ E( K+ e5 ^ @
3.MCO1 和 MCO2:这些引脚在系统复位之后要使用的话要配置为复用功能模式。
( T# { ~* M! B7 Q2 `4 |2 s7 ?8 |5 S \1 i/ W# M B
03. 类型) n& \7 }, x# Y; ^9 K/ P3 H2 g
复用功能相关宏% s7 J, p- G- S
& u! g5 V9 Y& y" g, B0 B- /** ! r- C2 w9 F, H( @
- * @brief AF 0 selection
5 c* S7 Z9 W# h/ M6 ] - */
# M2 j' K6 U9 V M: y8 H9 C# B - #define GPIO_AF_RTC_50Hz ((uint8_t)0x00) /* RTC_50Hz Alternate Function mapping */
, W, S9 _0 h5 S3 P% e9 m5 P( H/ ` - #define GPIO_AF_MCO ((uint8_t)0x00) /* MCO (MCO1 and MCO2) Alternate Function mapping */
+ x+ x5 u* ^) K) u0 I3 ] - #define GPIO_AF_TAMPER ((uint8_t)0x00) /* TAMPER (TAMPER_1 and TAMPER_2) Alternate Function mapping */( Y. c" t* q. d: a1 V* ?5 i
- #define GPIO_AF_SWJ ((uint8_t)0x00) /* SWJ (SWD and JTAG) Alternate Function mapping */
+ l2 d1 N1 B8 ]8 u3 z - #define GPIO_AF_TRACE ((uint8_t)0x00) /* TRACE Alternate Function mapping */- I0 x, S7 b; `+ u n
- #if defined(STM32F446xx)
3 t; Q7 b8 D3 k; T; _ - #define GPIO_AF0_TIM2 ((uint8_t)0x00) /* TIM2 Alternate Function mapping */
9 n# q& e; _+ ^$ d8 R2 \. ^: d - #endif /* STM32F446xx *// G& l' }$ [* P S6 ~0 u, A% r
5 z$ y J5 u/ H" u# O( Q3 l5 J y- /**
9 i( H0 \7 c% F* X* Y. V$ B - * @brief AF 1 selection ' B [4 A: s4 ?: P; E6 R
- */ $ Z% I, ^- h. b5 n& }; H) Y
- #define GPIO_AF_TIM1 ((uint8_t)0x01) /* TIM1 Alternate Function mapping */
5 Y" n; }; b& A) c1 M# R - #define GPIO_AF_TIM2 ((uint8_t)0x01) /* TIM2 Alternate Function mapping */
3 x# }! T# f) J9 m: ? - #if defined(STM32F410xx) || defined(STM32F413_423xx)
7 r& X, c/ g/ n: b- }3 y# T' F - #define GPIO_AF_LPTIM ((uint8_t)0x01) /* LPTIM Alternate Function mapping */
0 \# x5 z) q; M u: g2 J8 |. f. E - #endif /* STM32F410xx || STM32F413_423xx */
$ w# `3 n% c) Y - /** . b) ^: _$ C7 c6 S/ @- z
- * @brief AF 2 selection
2 [- d& ^8 N( B6 m* t( p5 u - */ ! i" C$ Z" c4 s* W) m3 `
- #define GPIO_AF_TIM3 ((uint8_t)0x02) /* TIM3 Alternate Function mapping */
8 d0 }* ` N c+ |6 E - #define GPIO_AF_TIM4 ((uint8_t)0x02) /* TIM4 Alternate Function mapping */
r5 q6 z$ ^! B$ @2 F. j- G - #define GPIO_AF_TIM5 ((uint8_t)0x02) /* TIM5 Alternate Function mapping */ r5 W/ H% I' @$ R
- ! A# v" u; O- l- N
- /** 6 X. t; U5 \$ u( e" {1 a& {4 q
- * @brief AF 3 selection $ B" V( L* s* m& O4 [% {/ O
- */ i: G. |/ ]3 z; h. n0 ?2 j
- #define GPIO_AF_TIM8 ((uint8_t)0x03) /* TIM8 Alternate Function mapping */
" f( m6 i4 o" b: B$ D - #define GPIO_AF_TIM9 ((uint8_t)0x03) /* TIM9 Alternate Function mapping */' N# o8 N4 H& H+ G7 }
- #define GPIO_AF_TIM10 ((uint8_t)0x03) /* TIM10 Alternate Function mapping */" m' H! a7 m6 u/ D0 |1 o. e) k
- #define GPIO_AF_TIM11 ((uint8_t)0x03) /* TIM11 Alternate Function mapping */
1 I* G+ ~& E( b3 _0 l - #if defined(STM32F446xx)
) M6 j, T" @3 r4 h6 R1 R - #define GPIO_AF3_CEC ((uint8_t)0x03) /* CEC Alternate Function mapping */8 @' G6 `* l8 U, w8 {1 y
- #endif /* STM32F446xx */$ T9 C" d/ G5 ?. r+ _
- #if defined(STM32F413_423xx)4 {: ~0 q# j3 l$ n$ z7 {* m
- #define GPIO_AF3_DFSDM2 ((uint8_t)0x03) /* DFSDM2 Alternate Function mapping */
* w' L9 z% D8 E) y4 x0 e* _ - #endif /* STM32F413_423xx */
' |" r! y. R# D7 f r - /**
c) }& o( z1 v G% M7 H+ ^ - * @brief AF 4 selection
+ F r5 p/ G2 m3 }3 A: d H! a3 q; I - */
' D* \* q- w. U% w( s - #define GPIO_AF_I2C1 ((uint8_t)0x04) /* I2C1 Alternate Function mapping */8 s9 j* o2 Q" ~% U
- #define GPIO_AF_I2C2 ((uint8_t)0x04) /* I2C2 Alternate Function mapping */- t8 d t3 q/ i8 L
- #define GPIO_AF_I2C3 ((uint8_t)0x04) /* I2C3 Alternate Function mapping */' c' h% r" D% u [( ]
- #if defined(STM32F446xx) [1 v6 N0 J S7 m2 p* o9 \, P
- #define GPIO_AF4_CEC ((uint8_t)0x04) /* CEC Alternate Function mapping *// V7 s& N( z- `4 x+ S1 \
- #endif /* STM32F446xx */
) a& J* l1 ] T0 ~. C! o - #if defined(STM32F410xx) || defined(STM32F412xG) || defined(STM32F413_423xx) || defined(STM32F446xx)# S! m5 H- M& k3 i7 M1 F8 h
- #define GPIO_AF_FMPI2C ((uint8_t)0x04) /* FMPI2C Alternate Function mapping */; p( ^& b: x4 r
- #endif /* STM32F410xx || STM32F446xx */
# W# x! t' p- g
4 o- }, e6 Q2 h- /**
7 A7 \( p% X: G" i+ L6 \& R2 v; l) | - * @brief AF 5 selection , K' j+ n5 Z, U9 d
- */ 7 V; R4 I# S" N- x x; k; _
- #define GPIO_AF_SPI1 ((uint8_t)0x05) /* SPI1/I2S1 Alternate Function mapping */
; S- U7 C' n8 L. { d - #define GPIO_AF_SPI2 ((uint8_t)0x05) /* SPI2/I2S2 Alternate Function mapping */
. u9 |3 a4 g+ u4 G - #define GPIO_AF5_SPI3 ((uint8_t)0x05) /* SPI3/I2S3 Alternate Function mapping (Only for STM32F411xE and STM32F413_423xx Devices) */
) ]! X# {/ l9 P; `) e - #define GPIO_AF_SPI4 ((uint8_t)0x05) /* SPI4/I2S4 Alternate Function mapping */
[; f* t, m: S - #define GPIO_AF_SPI5 ((uint8_t)0x05) /* SPI5 Alternate Function mapping */
7 T$ ]8 S; n3 B% g! F - #define GPIO_AF_SPI6 ((uint8_t)0x05) /* SPI6 Alternate Function mapping */0 |2 @: P* ^1 u7 K! p
- * {) T A& U' g; F; v1 b" I; P
- /**
, x- d7 K, |8 R1 E4 R! t- a - * @brief AF 6 selection & o# \! K+ j: Z2 h7 j# R
- */
2 a6 I8 [% d3 u- c: Z" O( k - #define GPIO_AF_SPI3 ((uint8_t)0x06) /* SPI3/I2S3 Alternate Function mapping */
7 ]7 |5 m9 K: ?, ^- D# w - #define GPIO_AF6_SPI1 ((uint8_t)0x06) /* SPI1 Alternate Function mapping (Only for STM32F410xx Devices) */
/ X6 V3 A* S4 p" [ t% e* S3 F; @ - #define GPIO_AF6_SPI2 ((uint8_t)0x06) /* SPI2 Alternate Function mapping (Only for STM32F410xx/STM32F411xE Devices) */
% k$ u4 h. ]2 L, Z - #define GPIO_AF6_SPI4 ((uint8_t)0x06) /* SPI4 Alternate Function mapping (Only for STM32F411xE Devices) */
4 I( q! l7 u- Z6 [- g& _" l* E - #define GPIO_AF6_SPI5 ((uint8_t)0x06) /* SPI5 Alternate Function mapping (Only for STM32F410xx/STM32F411xE Devices) */
, A- L7 }, p1 t2 Z* t - #define GPIO_AF_SAI1 ((uint8_t)0x06) /* SAI1 Alternate Function mapping */
: R4 Y9 _3 t* ~4 U6 E7 s( f8 T - #define GPIO_AF_I2S2ext ((uint8_t)0x06) /* I2S2ext_SD Alternate Function mapping (only for STM32F412xG and STM32F413_423xx Devices) */
7 O% b* P" ]! q# q - #if defined(STM32F412xG) || defined(STM32F413_423xx)2 n5 ^7 ^( F7 Z; w, j
- #define GPIO_AF6_DFSDM1 ((uint8_t)0x06) /* DFSDM1 Alternate Function mapping */4 d3 ~* r5 g8 x. Y* x N
- #endif /* STM32F412xG || STM32F413_423xx */* r1 U+ G, j8 ~' F3 h: n; |
- #if defined(STM32F413_423xx)
2 C, Z. ]* h; A! t; s9 W - #define GPIO_AF6_DFSDM2 ((uint8_t)0x06) /* DFSDM2 Alternate Function mapping */
) U w6 i" o* H, g& J8 O |5 p: } - #endif /* STM32F413_423xx */
a! Z; X" G* c) B" W' y) C4 c - ( R1 u" M" y: H4 o7 ~
- /** * J& X$ Z r2 Q; g2 p- I
- * @brief AF 7 selection 8 L3 _0 c- X$ ^9 Y& z9 ^
- */ $ p1 Q/ j- f$ v1 o9 Y
- #define GPIO_AF_USART1 ((uint8_t)0x07) /* USART1 Alternate Function mapping */$ M- M$ X, X9 x1 ]1 _3 U
- #define GPIO_AF_USART2 ((uint8_t)0x07) /* USART2 Alternate Function mapping */% u& ~' ^. f) W# l, g6 h# v
- #define GPIO_AF_USART3 ((uint8_t)0x07) /* USART3 Alternate Function mapping */
9 b2 \7 G9 e1 H$ b, P - #define GPIO_AF7_SPI3 ((uint8_t)0x07) /* SPI3/I2S3ext Alternate Function mapping */6 A4 Q2 r3 B8 u* g1 b: |
- #if defined(STM32F413_423xx)0 K" e( e* r. |
- #define GPIO_AF7_DFSDM2 ((uint8_t)0x07) /* DFSDM2 Alternate Function mapping */+ o) R' @( G3 l9 ~) ^
- #define GPIO_AF7_SAI1 ((uint8_t)0x07) /* SAI1 Alternate Function mapping */7 G1 ]% ?, k$ e
- #endif /* STM32F413_423xx */
! ^. P6 H# r! { J
+ P2 B2 G: w% _* v. W& [) q- /** 2 Z: t* f- x* A6 s2 c8 N
- * @brief AF 7 selection Legacy ) ~" _/ E: H. X" A
- */
2 T) s7 \. M1 ?: h3 ~) g1 l8 @8 ] - #define GPIO_AF_I2S3ext GPIO_AF7_SPI3
/ l4 N' @/ ]0 V4 {6 ?( P, X
, d7 ~# ?% C5 X2 d- /** 1 R# N& `, ~, P
- * @brief AF 8 selection $ K4 h( B$ \( Q+ }
- */
% [0 I( l% g6 |) S) ^% u: @ - #define GPIO_AF_UART4 ((uint8_t)0x08) /* UART4 Alternate Function mapping */
0 o! N8 w3 I+ S2 X3 X- G3 E - #define GPIO_AF_UART5 ((uint8_t)0x08) /* UART5 Alternate Function mapping */
r6 h5 T- z5 i) `1 u! A+ h7 T - #define GPIO_AF_USART6 ((uint8_t)0x08) /* USART6 Alternate Function mapping */
6 w+ q/ L% A* g5 N - #define GPIO_AF_UART7 ((uint8_t)0x08) /* UART7 Alternate Function mapping */9 m1 e9 k% d( b ]5 ^" u
- #define GPIO_AF_UART8 ((uint8_t)0x08) /* UART8 Alternate Function mapping */! d. _$ j3 h. g! ]- R# i
- #if defined(STM32F412xG) || defined(STM32F413_423xx)' O& \2 B R }+ R) ?1 N' ], z0 @5 X
- #define GPIO_AF8_USART3 ((uint8_t)0x08) /* USART3 Alternate Function mapping */
/ J* N* `2 ]7 k8 a; O - #define GPIO_AF8_DFSDM1 ((uint8_t)0x08) /* DFSDM Alternate Function mapping */
7 ]3 u) U2 E' X7 A0 I* N - #define GPIO_AF8_CAN1 ((uint8_t)0x08) /* CAN1 Alternate Function mapping */
* ~( r5 L- I$ A+ C/ y- G0 M) e w - #endif /* STM32F412xG || STM32F413_423xx */! k/ e, B. ^9 Z2 K2 v0 u' P! I
- #if defined(STM32F446xx)
# K- H2 H( _! b2 K5 q( f - #define GPIO_AF8_SAI2 ((uint8_t)0x08) /* SAI2 Alternate Function mapping */' ~: B9 l' J6 g$ S1 S. }* j
- #define GPIO_AF_SPDIF ((uint8_t)0x08) /* SPDIF Alternate Function mapping */7 J o$ |7 k; x4 O' U2 |# w
- #endif /* STM32F446xx */
! L) C; \( K) l+ y - " e3 Q! y [) N9 G/ F" d
- /** 1 m* G- A, |2 x& ~) ~ u
- * @brief AF 9 selection
5 \: d6 h+ d; V0 w7 U5 K* \ - */
2 q$ I. P2 u( | - #define GPIO_AF_CAN1 ((uint8_t)0x09) /* CAN1 Alternate Function mapping */
% B, k J; m. N; Y, Z7 b7 M - #define GPIO_AF_CAN2 ((uint8_t)0x09) /* CAN2 Alternate Function mapping */
9 T7 P! u0 ]# j0 L$ D - #define GPIO_AF_TIM12 ((uint8_t)0x09) /* TIM12 Alternate Function mapping */; m5 e4 }" f @5 Z
- #define GPIO_AF_TIM13 ((uint8_t)0x09) /* TIM13 Alternate Function mapping */
& I) T* q, h: P5 j - #define GPIO_AF_TIM14 ((uint8_t)0x09) /* TIM14 Alternate Function mapping */2 D# |: y) a' D* q; B
- #define GPIO_AF9_I2C2 ((uint8_t)0x09) /* I2C2 Alternate Function mapping (Only for STM32F401xx/STM32F410xx/STM32F411xE/STM32F412xG/STM32F413_423xx Devices) */2 w& l" s: c5 W0 U
- #define GPIO_AF9_I2C3 ((uint8_t)0x09) /* I2C3 Alternate Function mapping (Only for STM32F401xx/STM32F411xE/STM32F412xG and STM32F413_423xx Devices) */( X# q# S" l' Q/ E V* d8 D
- #if defined(STM32F446xx)
7 S& H' m7 R3 B% B5 { - #define GPIO_AF9_SAI2 ((uint8_t)0x09) /* SAI2 Alternate Function mapping */" @) l4 M4 P3 \3 n
- #endif /* STM32F446xx */
2 U ?6 R2 D7 y! V - #define GPIO_AF9_LTDC ((uint8_t)0x09) /* LTDC Alternate Function mapping */
- J3 k. l/ b, K6 i - #if defined(STM32F412xG) || defined(STM32F413_423xx) || defined(STM32F446xx) || defined(STM32F469_479xx)
]1 F4 z1 V4 `8 E - #define GPIO_AF9_QUADSPI ((uint8_t)0x09) /* QuadSPI Alternate Function mapping */' O, Z2 s" m9 C
- #endif /* STM32F412xG || STM32F413_423xx || STM32F446xx || STM32F469_479xx */+ X" X( T; p% Q, ~; x' R; [
- #if defined(STM32F410xx) || defined(STM32F412xG) || defined(STM32F413_423xx)
2 T$ t: i, h2 X% ^ ^/ X8 a - #define GPIO_AF9_FMPI2C ((uint8_t)0x09) /* FMPI2C Alternate Function mapping (Only for STM32F410xx Devices) */
/ U, H+ @# Q# ^. K+ A - #endif /* STM32F410xx || STM32F412xG || STM32F413_423xx */
8 A8 u; `' I* Q# J0 c4 M/ I
4 M+ \$ M; b2 I5 G- /** ! B' f, l/ T5 Y3 {1 e. Q* D5 F' o% C
- * @brief AF 10 selection
S4 z, G# _( l+ p! u1 M - */
4 }9 V a5 P* N( l8 Y4 M0 P( P - #define GPIO_AF_OTG_FS ((uint8_t)0xA) /* OTG_FS Alternate Function mapping */5 w5 D7 \$ O0 i" {& z
- #define GPIO_AF_OTG_HS ((uint8_t)0xA) /* OTG_HS Alternate Function mapping */& z# a& k0 h3 M7 E% v/ T
- #if defined(STM32F446xx): [! b: J5 v, D/ J/ Z! O
- #define GPIO_AF10_SAI2 ((uint8_t)0x0A) /* SAI2 Alternate Function mapping */( ^; `7 s2 E' K' a
- #endif /* STM32F446xx */2 i) y7 \4 D# F+ P2 y
- #if defined(STM32F412xG) || defined(STM32F413_423xx) || defined(STM32F446xx) || defined(STM32F469_479xx)7 M& Q) y9 ~ [6 M
- #define GPIO_AF10_QUADSPI ((uint8_t)0x0A) /* QuadSPI Alternate Function mapping */
( I; C; \* p1 x - #endif /* STM32F412xG || STM32F413_423xx || STM32F446xx || STM32F469_479xx */, L& c: c- c) K" Z1 H+ `1 C( k
- #if defined(STM32F412xG) || defined(STM32F413_423xx)# s0 [! a6 f& V$ T% q0 m% P: j4 s
- #define GPIO_AF10_FMC ((uint8_t)0xA) /* FMC Alternate Function mapping */# T% j* S" L( i; h
- #define GPIO_AF10_DFSDM1 ((uint8_t)0xA) /* DFSDM Alternate Function mapping */
/ A5 L3 o- ~! E" y! {& G - #endif /* STM32F412xG || STM32F413_423xx */
) B* F- B; X& h8 z9 a: e% k$ U* C - #if defined(STM32F413_423xx)
7 I3 M! |' `' F1 K( B$ d - #define GPIO_AF10_DFSDM2 ((uint8_t)0x0A) /* DFSDM2 Alternate Function mapping */; c. j, ?6 s% b8 O* E0 I/ V3 X
- #define GPIO_AF10_SAI1 ((uint8_t)0x0A) /* SAI1 Alternate Function mapping */
/ ?4 [ ]% t; }" @3 ~! T - #endif /* STM32F413_423xx */
5 Z+ j! B, T1 x( r' }0 v2 O4 H% j - /**
& g( q2 H8 ?3 S/ B+ D" }: U7 [$ Q - * @brief AF 11 selection " l, n4 x. O8 d O: m
- */
$ ? K$ Y- {0 S6 I! f - #define GPIO_AF_ETH ((uint8_t)0x0B) /* ETHERNET Alternate Function mapping */
" L" ?+ f% _! C T* ?" v( K3 p0 b - #if defined(STM32F413_423xx)
" H' I9 K- t- V6 f- h - #define GPIO_AF11_UART4 ((uint8_t)0x0B) /* UART4 Alternate Function mapping */
7 r, }5 _6 z8 ]" d - #define GPIO_AF11_UART5 ((uint8_t)0x0B) /* UART5 Alternate Function mapping */
5 i# c& H) B! J/ n - #define GPIO_AF11_UART9 ((uint8_t)0x0B) /* UART9 Alternate Function mapping */3 L' E/ E k+ W3 ?4 G! L
- #define GPIO_AF11_UART10 ((uint8_t)0x0B) /* UART10 Alternate Function mapping */% K5 p* d' o# \8 y/ {
- #define GPIO_AF11_CAN3 ((uint8_t)0x0B) /* CAN3 Alternate Function mapping */9 G9 Q2 o- ~) I
- #endif /* STM32F413_423xx */
8 v' \' P9 a) ?, ~, B - 3 X% \6 i6 `* g0 x) N( n' X
- /** " U4 B; c" f7 H; `' l( S. ]
- * @brief AF 12 selection 6 d5 u! E; E/ g
- */ - N, e h% \6 B9 V
- #if defined(STM32F40_41xxx) || defined(STM32F412xG) || defined(STM32F413_423xx)
8 h, ? k$ p7 V6 g - #define GPIO_AF_FSMC ((uint8_t)0xC) /* FSMC Alternate Function mapping */; e: N5 P8 f/ L; |, l: L
- #endif /* STM32F40_41xxx || STM32F412xG || STM32F413_423xx */
]% @+ F0 u: }7 P6 _4 W3 O7 g; A - - H2 i0 b: Q Y( x! C, m6 P& s
- #if defined(STM32F427_437xx) || defined(STM32F429_439xx) || defined(STM32F446xx) || defined(STM32F469_479xx)
7 h" W# G5 n" q3 V# M: d - #define GPIO_AF_FMC ((uint8_t)0xC) /* FMC Alternate Function mapping */
* }' O- T6 t5 f0 H7 y- q2 D - #endif /* STM32F427_437xx || STM32F429_439xx || STM32F446xx || STM32F469_479xx */+ U+ O* m6 Z8 C7 r0 H2 \2 U$ Z% R
- , J& }. b t X1 x
- #define GPIO_AF_OTG_HS_FS ((uint8_t)0xC) /* OTG HS configured in FS, Alternate Function mapping */# i9 F/ r9 A* W; D7 ^
- #define GPIO_AF_SDIO ((uint8_t)0xC) /* SDIO Alternate Function mapping */* G1 e _& Y# N, e* F6 Q( e: o9 {" ^+ m
- 9 n- v* i& X& ^1 x$ M3 w5 ~
- /**
: V) F$ }3 i5 v - * @brief AF 13 selection : F9 Q8 |) y) N9 f; k
- */ 4 b: j+ R/ [9 ]# n6 g6 O3 h# ~
- #define GPIO_AF_DCMI ((uint8_t)0x0D) /* DCMI Alternate Function mapping */
7 y6 x, |% R* W' [3 F - #if defined(STM32F469_479xx)7 [3 n6 r; {$ ?% ^6 b4 I8 F( ?
- #define GPIO_AF_DSI ((uint8_t)0x0D) /* DSI Alternate Function mapping */
: o8 ]; R' U" ~+ v% _+ ] - #endif /* STM32F469_479xx */2 y3 U& @8 v' X7 ]. }6 F
- /** ) i6 _8 ?( g9 A' t4 g6 Y8 A
- * @brief AF 14 selection
) |5 G" U# ]4 w% J# L - */
# Z( |( r1 S2 V2 @& \6 Q. T( b - #define GPIO_AF_LTDC ((uint8_t)0x0E) /* LCD-TFT Alternate Function mapping *// n! M! A# ?' O% K# j5 c
- #if defined(STM32F413_423xx)8 x5 S: F0 O, X4 Y! D; H, j
- #define GPIO_AF14_RNG ((uint8_t)0x0E) /* RNG Alternate Function mapping */ E( L& h% {- @
- #endif /* STM32F413_423xx */' P4 B; a: B) [" Y R6 I- b: R {) _
- . D( I# M Y- v( y
- /**
( j/ e! T" M9 o/ C - * @brief AF 15 selection 7 u+ L) W/ ?1 U/ A9 s6 _4 b
- */
7 V% O/ [" [9 j9 `8 j8 ]2 w$ g - #define GPIO_AF_EVENTOUT ((uint8_t)0x0F) /* EVENTOUT Alternate Function mapping */
2 i1 o! ^2 \3 K! G- B* R
! Q3 s' q: q7 Z0 o: K7 ?0 g- #define IS_GPIO_AF(AF) (((AF) == GPIO_AF_RTC_50Hz) || ((AF) == GPIO_AF_TIM14) || \
) x/ C1 p. b5 I1 r - ((AF) == GPIO_AF_MCO) || ((AF) == GPIO_AF_TAMPER) || \$ D( v; r+ S9 P# f
- ((AF) == GPIO_AF_SWJ) || ((AF) == GPIO_AF_TRACE) || \+ A: T. Q4 U+ M0 R( V& O0 L' [6 e
- ((AF) == GPIO_AF_TIM1) || ((AF) == GPIO_AF_TIM2) || \
9 z7 N0 ?. ~1 }7 E - ((AF) == GPIO_AF_TIM3) || ((AF) == GPIO_AF_TIM4) || \
3 `' h# g. h, M5 f - ((AF) == GPIO_AF_TIM5) || ((AF) == GPIO_AF_TIM8) || \
! |+ I4 b5 q p9 _ - ((AF) == GPIO_AF_I2C1) || ((AF) == GPIO_AF_I2C2) || \
7 Y4 M. ?9 T, {0 Q8 q) m - ((AF) == GPIO_AF_I2C3) || ((AF) == GPIO_AF_SPI1) || \
& s. m. L% {! K# H F - ((AF) == GPIO_AF_SPI2) || ((AF) == GPIO_AF_TIM13) || \; [5 h9 [4 e* M% m8 }3 q1 }2 e
- ((AF) == GPIO_AF_SPI3) || ((AF) == GPIO_AF_TIM14) || \; N0 T( w, F4 x% b# g: D% e
- ((AF) == GPIO_AF_USART1) || ((AF) == GPIO_AF_USART2) || \
* t0 o( m, W9 C- l - ((AF) == GPIO_AF_USART3) || ((AF) == GPIO_AF_UART4) || \
9 u9 H* D) r7 t7 J8 J( u9 M - ((AF) == GPIO_AF_UART5) || ((AF) == GPIO_AF_USART6) || \
2 R* y: |$ S3 B" ] - ((AF) == GPIO_AF_CAN1) || ((AF) == GPIO_AF_CAN2) || \
; v$ x$ v. `' F7 b( Z) K/ E! |" }6 o - ((AF) == GPIO_AF_OTG_FS) || ((AF) == GPIO_AF_OTG_HS) || \# {9 D" c: K! U4 @( Y6 n, \" C
- ((AF) == GPIO_AF_ETH) || ((AF) == GPIO_AF_OTG_HS_FS) || \; W! R; _( G, A. V/ c- B
- ((AF) == GPIO_AF_SDIO) || ((AF) == GPIO_AF_DCMI) || \, d4 O( R" V* `7 g' {
- ((AF) == GPIO_AF_EVENTOUT) || ((AF) == GPIO_AF_FSMC)), D* b7 }% L! T! v1 M4 F, E {
- #endif /* STM32F40_41xxx */
复制代码 ) i0 U+ W" `+ q( f* ?0 `' N
04. 函数
9 o7 r7 d( g. T' [1 m sGPIO复用功能函数
$ ^& T% b# _; A- \$ n( S
8 d; m, P. ~* D4 q: R! I- /* GPIO Alternate functions configuration function ****************************/
% Q$ H1 O- A9 I% C$ o# ]+ {: {* j" F - void GPIO_PinAFConfig(GPIO_TypeDef* GPIOx, uint16_t GPIO_PinSource, uint8_t GPIO_AF);
复制代码
- @0 \; t9 d; ~( [- ^# e7 q05. 参考示例" P- R: g4 R) v1 W; _" B7 n
串口配置
$ y' D( a% y) _: D2 `, H* b8 c' S: k
- /*GPIOA9 与 GPIOA10 初始化*/
' V- \0 E# E% u6 c - GPIO_InitStructure.GPIO_Pin = GPIO_Pin_9 | GPIO_Pin_10;
5 O/ F0 N% N( G& _* M, D - GPIO_InitStructure.GPIO_Mode = GPIO_Mode_AF;// 复用功能/ D& C: |: c2 v- ^6 X
- GPIO_InitStructure.GPIO_Speed = GPIO_Speed_50MHz;//速度 50MHz
( M3 z& s6 Z f( g2 q P - GPIO_InitStructure.GPIO_OType = GPIO_OType_PP; //推挽复用输出
( t0 ~8 b* |6 w6 ?) C4 P - GPIO_InitStructure.GPIO_PuPd = GPIO_PuPd_UP; //上拉1 {: N6 \, J9 ?; t" A& d
- GPIO_Init(GPIOA,&GPIO_InitStructure); //初始化 PA9,PA10+ B; L! g7 O' d
- 1 q8 i7 f" }$ U# `( f9 |" ]
- /*PA9 连接 AF7,复用为 USART1_TX */
' `, K& b8 O0 v, `1 \7 J - GPIO_PinAFConfig(GPIOA,GPIO_PinSource9,GPIO_AF_USART1);; f/ _( P; i' _+ X
- /* PA10 连接 AF7,复用为 USART1_RX*/
6 w) E+ r$ A) T* [6 q - GPIO_PinAFConfig(GPIOA,GPIO_PinSource10,GPIO_AF_USART1);
复制代码 5 s0 x# x* Z- h
: Z) O, Y6 T" S' X i# M6 E" f$ q; W4 \; E5 D( _7 B% r
|