01. 概述
7 ]5 M6 f5 X9 f1 C' P系统配置控制器主要用于管理对可执行代码的存储区域的地址重映射、选择以太网 PHY 接口以及管理 GPIO 的外部中断线连接。+ C% @! }. i, R% d* S \
0 D! K7 l. K9 V3 O2 M6 I02. 相关类型
8 R$ O/ _, m8 f$ u- bSYSCFG_EXTI_Port_Sources! J! X t1 \' U b+ G
" n% Z3 ?- Q; i. g' m- /** @defgroup SYSCFG_EXTI_Port_Sources 1 I. k( x+ o0 c2 y8 j
- * @{. u+ m. e8 z- n- J% o
- */ 9 |3 H3 v0 ^+ x+ U4 a
- #define EXTI_PortSourceGPIOA ((uint8_t)0x00)
& ~. ]5 A6 J( V* G' f - #define EXTI_PortSourceGPIOB ((uint8_t)0x01)
0 |8 T; |- s% w5 ] - #define EXTI_PortSourceGPIOC ((uint8_t)0x02)% W- |# l$ N0 b* s8 v/ @
- #define EXTI_PortSourceGPIOD ((uint8_t)0x03)
- s. f7 b) t9 U1 _ - #define EXTI_PortSourceGPIOE ((uint8_t)0x04)# i- _% N* z' E: r) c& C
- #define EXTI_PortSourceGPIOF ((uint8_t)0x05)
I6 b; k6 w$ o6 } - #define EXTI_PortSourceGPIOG ((uint8_t)0x06)
" G; e" S1 W5 \8 T; a5 _ - #define EXTI_PortSourceGPIOH ((uint8_t)0x07)$ m3 o+ }" D3 u5 P& ~
- #define EXTI_PortSourceGPIOI ((uint8_t)0x08)% M; V" O; Y$ z: x: }: T
- #define EXTI_PortSourceGPIOJ ((uint8_t)0x09)) j0 @6 A% I4 {3 k" |
- #define EXTI_PortSourceGPIOK ((uint8_t)0x0A)6 X4 l" I# Z$ F0 Q2 g- W3 L( b, j1 p: [
0 o) U+ w: K8 S p p3 h. p- #define IS_EXTI_PORT_SOURCE(PORTSOURCE) (((PORTSOURCE) == EXTI_PortSourceGPIOA) || \3 h! P$ |' P# B; B
- ((PORTSOURCE) == EXTI_PortSourceGPIOB) || \. H2 E) k+ p3 t* ?1 }! S* d5 q
- ((PORTSOURCE) == EXTI_PortSourceGPIOC) || \
1 G7 F1 D! P/ D) c' {* T - ((PORTSOURCE) == EXTI_PortSourceGPIOD) || \1 u$ \5 S/ c2 E
- ((PORTSOURCE) == EXTI_PortSourceGPIOE) || \
' f6 t5 ~6 ^- e - ((PORTSOURCE) == EXTI_PortSourceGPIOF) || \
1 k# i) p7 D7 w- o0 a1 Q - ((PORTSOURCE) == EXTI_PortSourceGPIOG) || \/ W& b2 e: e8 ~* v. L4 ^
- ((PORTSOURCE) == EXTI_PortSourceGPIOH) || \
6 z q! [3 R6 q- u1 o9 T: y - ((PORTSOURCE) == EXTI_PortSourceGPIOI) || \
1 h/ N# t7 B, f( w - ((PORTSOURCE) == EXTI_PortSourceGPIOJ) || \
9 k" W5 p9 k* C* Z( u* E M" C - ((PORTSOURCE) == EXTI_PortSourceGPIOK))
复制代码 4 U& F6 k& F: T: s% D6 |2 U
SYSCFG_EXTI_Pin_Sources
7 N# y) N* n% H% E1 t u) `
' a& N3 [( t: s3 i' ~ g6 _- /** @defgroup SYSCFG_EXTI_Pin_Sources / ] P( s0 `0 @# G6 _
- * @{0 u, O* E/ _2 N+ P" {5 p* o
- */
8 p7 p4 ~1 O& l1 m - #define EXTI_PinSource0 ((uint8_t)0x00)
7 v* t1 h Y3 N4 A1 Q$ e# i - #define EXTI_PinSource1 ((uint8_t)0x01)4 P& ?2 d; ~0 C4 r \- `
- #define EXTI_PinSource2 ((uint8_t)0x02)+ \* }! O M5 Z e5 z
- #define EXTI_PinSource3 ((uint8_t)0x03)
3 M6 Q9 K4 s+ q8 D2 H - #define EXTI_PinSource4 ((uint8_t)0x04)+ r7 A& T3 W. o: N2 J6 q
- #define EXTI_PinSource5 ((uint8_t)0x05)% \- f6 `/ V: {! x7 P+ z. g
- #define EXTI_PinSource6 ((uint8_t)0x06)
& k) k U! I$ v5 c6 @8 F - #define EXTI_PinSource7 ((uint8_t)0x07)/ h; b4 T, x* c# ?" y
- #define EXTI_PinSource8 ((uint8_t)0x08)
' l( }& q2 R; k - #define EXTI_PinSource9 ((uint8_t)0x09)" }% F( i4 y3 ^' z5 Z
- #define EXTI_PinSource10 ((uint8_t)0x0A)0 E3 a+ w- A# c: W; \; z
- #define EXTI_PinSource11 ((uint8_t)0x0B)
& i% Q1 S+ W" G' y, P2 h) c - #define EXTI_PinSource12 ((uint8_t)0x0C)
3 D! J/ J' j! w3 h6 F( N+ x/ K - #define EXTI_PinSource13 ((uint8_t)0x0D) Y0 h" ]6 d" v
- #define EXTI_PinSource14 ((uint8_t)0x0E)* e& @% m6 M9 s4 n
- #define EXTI_PinSource15 ((uint8_t)0x0F)1 A# P& j. v+ K4 `* a& H- ~
- #define IS_EXTI_PIN_SOURCE(PINSOURCE) (((PINSOURCE) == EXTI_PinSource0) || \
/ v/ d$ B" i6 E8 H3 N: F - ((PINSOURCE) == EXTI_PinSource1) || \
! k7 k2 p! D& e( a* V$ T - ((PINSOURCE) == EXTI_PinSource2) || \ J4 l# N& X- x$ ^
- ((PINSOURCE) == EXTI_PinSource3) || \$ Q* Q5 d* y% \9 K) d
- ((PINSOURCE) == EXTI_PinSource4) || \
, L, |- F I3 R5 A+ G3 n8 \1 X% } - ((PINSOURCE) == EXTI_PinSource5) || \% ]) a2 k/ c, O. L( u
- ((PINSOURCE) == EXTI_PinSource6) || \
& g, q `- t- X, u1 L: E - ((PINSOURCE) == EXTI_PinSource7) || \1 u1 k& S+ T# s+ O! \, j& {7 W7 U
- ((PINSOURCE) == EXTI_PinSource8) || \! t* q: h5 u1 [) w/ Q0 |- Y: B
- ((PINSOURCE) == EXTI_PinSource9) || \% `0 X2 \6 F4 u# N& s6 u1 ~- ^
- ((PINSOURCE) == EXTI_PinSource10) || \) h$ T) [, f1 M$ K+ F0 ^# X
- ((PINSOURCE) == EXTI_PinSource11) || \0 F4 V9 }) O+ K* s
- ((PINSOURCE) == EXTI_PinSource12) || \
3 M. D& y& y3 u) g# v9 m - ((PINSOURCE) == EXTI_PinSource13) || \; A- n0 _8 z6 q( n- M+ P( v' a# \
- ((PINSOURCE) == EXTI_PinSource14) || \
- v. p% ^6 F3 r, g5 _" j) f - ((PINSOURCE) == EXTI_PinSource15))
复制代码
4 p6 c! c: g7 M/ n6 ~* ^( fSYSCFG_Memory_Remap_Config
$ z. H; s; L5 q n0 G
( m, O5 }! G% P" h' w6 Y- /** @defgroup SYSCFG_Memory_Remap_Config
3 C% C$ p+ f3 U+ U - * @{: N. y9 F- Z" p" ~5 W# Y
- */
/ |' m& X# p j# d/ |8 N' ~ - #define SYSCFG_MemoryRemap_Flash ((uint8_t)0x00)
0 h4 M9 j6 r ?! J+ c/ \9 k - #define SYSCFG_MemoryRemap_SystemFlash ((uint8_t)0x01)
/ ?% P: x) h6 n - #define SYSCFG_MemoryRemap_SRAM ((uint8_t)0x03)
/ I1 B) {2 b6 F+ F7 }. h - #define SYSCFG_MemoryRemap_SDRAM ((uint8_t)0x04)
复制代码
9 l" O, T- j, R1 O9 mSYSCFG_ETHERNET_Media_Interface8 [3 k2 D9 M4 g6 {% e
8 a3 y8 X& ]( k1 u6 r% u, J- & @5 ^1 o1 K' X* [0 G. w7 v3 {
- /** @defgroup SYSCFG_ETHERNET_Media_Interface
( F: C8 L& r0 { - * @{
: O A) _6 @ e - */ . u- x' |8 `1 x$ S9 @$ k {1 O
- #define SYSCFG_ETH_MediaInterface_MII ((uint32_t)0x00000000)
! |! t" f% a, U: M* o - #define SYSCFG_ETH_MediaInterface_RMII ((uint32_t)0x00000001)6 o" _' Q( h9 S4 f( w0 u! {3 {2 N
2 r1 J9 Q6 G" m4 n+ m/ k4 A- #define IS_SYSCFG_ETH_MEDIA_INTERFACE(INTERFACE) (((INTERFACE) == SYSCFG_ETH_MediaInterface_MII) || \
* C+ }) ^5 u' ] - ((INTERFACE) == SYSCFG_ETH_MediaInterface_RMII))
复制代码
! v/ v6 x7 P1 H) s j) v03. 相关函数1 a; r% E# g# h h. t. \
- /* Exported macro ------------------------------------------------------------*/- j+ P; m$ ?5 ?# `- S! ]! ?* v
- /* Exported functions --------------------------------------------------------*/ 2 e- B. @; b2 m# a, k2 }
- " w) L# P/ r7 R( ^3 L
- void SYSCFG_DeInit(void);. v6 R/ |, V3 u P
- void SYSCFG_MemoryRemapConfig(uint8_t SYSCFG_MemoryRemap);
8 [! l, R1 [/ e' F, N+ y+ d - void SYSCFG_MemorySwappingBank(FunctionalState NewState);+ p! m! i* y* n" T" f
- void SYSCFG_EXTILineConfig(uint8_t EXTI_PortSourceGPIOx, uint8_t EXTI_PinSourcex);/ E% Z5 E! V2 U: r) K( l, D
- void SYSCFG_ETH_MediaInterfaceConfig(uint32_t SYSCFG_ETH_MediaInterface);
, y8 y8 C, e3 K/ m7 s6 k - void SYSCFG_CompensationCellCmd(FunctionalState NewState);
( L# ~* `. |3 n/ a0 m( [ - FlagStatus SYSCFG_GetCompensationCellStatus(void);$ E P @! g& U
1 H* { s+ [, E1 ^ t0 l" w" m U- #if defined(STM32F410xx) || defined(STM32F412xG) || defined(STM32F413_423xx); {- ^3 s8 B9 L
- void SYSCFG_BreakConfig(uint32_t SYSCFG_Break);
3 D7 q C/ Q0 Q' N6 @( x - #endif /* STM32F410xx || STM32F412xG || STM32F413_423xx */# A2 w3 V6 G4 b; }2 Z
- u; f9 n6 ^$ q j7 C4 H( v; h1 x
9 ^9 g/ S: v* K8 D& B, [& M- #if defined(STM32F413_423xx)
6 q% j" A6 z) M3 O - void DFSDM_BitstreamClock_SourceSelection(uint32_t source);; `6 d6 _6 l0 x6 |; S9 ?
- void DFSDM_DisableDelayClock(uint32_t MCHDLY);
) D' d9 P% a0 G0 B - void DFSDM_EnableDelayClock(uint32_t MCHDLY);
8 a+ z* w- y u. y - void DFSDM_ClockIn_SourceSelection(uint32_t source);
( [3 F/ E) I) p+ t: M/ A m$ E - void DFSDM_ClockOut_SourceSelection(uint32_t source);
; ~8 {+ U# T2 s; y1 ~ k6 C6 | - void DFSDM_DataIn0_SourceSelection(uint32_t source);' n' F" l" X! l1 `* T0 n2 E0 T7 P
- void DFSDM_DataIn2_SourceSelection(uint32_t source);
3 V$ `$ v& M+ V1 A/ ~ b+ q- b' K - void DFSDM_DataIn4_SourceSelection(uint32_t source);& I0 {4 ]0 ] P( P
- void DFSDM_DataIn6_SourceSelection(uint32_t source);
1 O6 I. d+ A7 V8 G/ c3 a4 A - void DFSDM1_BitStreamClk_Config(uint32_t source);" Q9 \; G a3 b# N! P; t& b
- void DFSDM2_BitStreamClk_Config(uint32_t source);; U/ z1 u+ O5 N0 |' j* w+ X; R
- #endif /* STM32F413_423xx */
1 }( a/ H2 X9 D. v: v% R- i9 J
复制代码
' Z( y4 |/ m" v8 Z2 N04. 结构体封装: `% i4 ^- e1 U4 H* C
系统配置控制器结构体封装3 _+ p9 g1 A$ T6 _0 R6 {8 J
! z( ]9 J# l8 T- U3 n8 I
- /** # d; x& I4 a7 F$ r; D/ e
- * @brief System configuration controller
; O# s$ y; O/ U( } - */
+ K: r2 \+ r3 x" K4 I a
4 F0 }* d8 R- ~6 a- typedef struct% z( Y7 L6 L9 V/ c7 u
- {% l/ h. O# m$ @- U5 b( ~ }
- __IO uint32_t MEMRMP; /*!< SYSCFG memory remap register,$ q5 v$ |" E9 F" b
- Address offset: 0x00 */8 S2 |- ?0 w4 E' f9 a& N& w
- __IO uint32_t PMC; /*!< SYSCFG peripheral mode configuration register,
" G, G. Y* v+ p! b - Address offset: 0x04 */6 t6 F4 R* u- Y+ C- W( I% i7 U& ^3 X
- __IO uint32_t EXTICR[4]; /*!< SYSCFG external interrupt configuration registers,
9 N( W! G0 l( b5 V; S - Address offset: 0x08-0x14 */" q$ @+ g, w& o: i: a! |" a& B
- #if defined (STM32F410xx) || defined(STM32F412xG) || defined(STM32F413_423xx)
" L3 d, ]8 ^: P) [, _1 M2 O - uint32_t RESERVED; /*!< Reserved, 0x18 */
" G8 F' k) b7 m+ A! j& f- ` - __IO uint32_t CFGR2; /*!< Reserved, 0x1C */' R" I. L6 z& ]3 A
- __IO uint32_t CMPCR; /*!< SYSCFG Compensation cell control register,
1 D, v+ q6 U4 m - Address offset: 0x20 */
/ c0 _% R& G4 i( q; I1 f- }8 \ - uint32_t RESERVED1[2]; /*!< Reserved, 0x24-0x28 */! _8 k, v) q$ {' \
- __IO uint32_t CFGR; /*!< SYSCFG Configuration register,& J, L- M' N8 Y, z
- Address offset: 0x2C */
# z- d* s' J# _ - #else /* STM32F40_41xxx || STM32F427_437xx || STM32F429_439xx ||
5 N$ |7 C, A' I: E0 B; f; l: l - STM32F401xx || STM32F411xE || STM32F446xx || STM32F469_479xx */
+ X1 ?9 _0 p- ^8 m# ~9 | q - uint32_t RESERVED[2]; /*!< Reserved, 0x18-0x1C */
# v- s& m) h9 } - __IO uint32_t CMPCR; /*!< SYSCFG Compensation cell control register,
" B; a+ }' |7 _: B2 r1 j A - Address offset: 0x20 */4 a2 R6 Q) t* @5 s0 l" R) x- u
- #endif /* STM32F410xx || defined(STM32F412xG) || defined(STM32F413_423xx) */
{0 d. E h9 R9 \4 _8 f2 @ - #if defined(STM32F413_423xx)
7 i% k4 A \8 B - __IO uint32_t MCHDLYCR; /*!< SYSCFG multi-channel delay register,* [2 R$ \7 M3 H- {
- Address offset: 0x30 */2 A. U; C$ M. u' s' x
- #endif /* STM32F413_423xx */, Q% w' J( m! P3 _3 \: J
- } SYSCFG_TypeDef; ^0 ^7 u' l# N+ P
复制代码
1 Z$ j2 ~, h+ x$ i# b- i8 e
1 q3 z9 B; i8 I+ J |