
标准库函数对每个外设都建立了一个初始化结构体,比如 USART_InitTypeDef,结构体成员用于$ L) I" z+ a9 `5 y3 Z3 @ 设置外设工作参数,并由外设初始化配置函数,比如 USART_Init() 调用,这些设定参数将会设置 外设相应的寄存器,达到配置外设工作环境的目的。/ l5 x. \4 U3 z2 C/ j, ] 初始化结构体定义在 stm32f4xx_usart.h 文件中,初始化库函数定义在 stm32f4xx_usart.c 文件中.$ }/ N$ I1 m8 G$ _9 ? USART 初始化结构体5 \3 ^3 V- u- n" t 参考正点原子和野火手册
USART_BaudRate:波特率设置。一般设置为 2400、9600、19200、115200。标准库函数会根据) U; z {9 m3 S 设定值计算得到 USARTDIV 值,并设置 USART_BRR 寄存器值。8 |, \# [. J8 O3 E9 z USART_WordLength:数据帧字长,可选 8 位或 9 位。它设定 USART_CR1 寄存器的 M 位的值。) y6 e# F2 r, t' |$ H 如果没有使能奇偶校验控制,一般使用 8 数据位;如果使能了奇偶校验则一般设置为 9 数据位。% h B0 N$ p2 H( o; {. n: U$ W + a( X: I# d# b6 t' }; { USART_StopBits:停止位设置,可选 0.5 个、1 个、1.5 个和 2 个停止位,它设定 USART_CR2 寄存器的 STOP[1:0] 位的值,一般我们选择 1 个停止位。 USART_Parity:奇偶校验控制选择,可选 USART_Parity_No(无校验)、USART_Parity_Even(偶 校验) 以及 USART_Parity_Odd(奇校验),它设定 USART_CR1 寄存器的 PCE 位和 PS 位的值。 6 D. W9 u* g% [2 k @ USART_Mode:USART 模式选择,有 USART_Mode_Rx 和 USART_Mode_Tx,允许使用逻辑或 运算选择两个,它设定 USART_CR1 寄存器的 RE 位和 TE 位。( Y- C3 u+ V6 g# p) c ! b+ O9 h3 r% h7 v s( ]/ J USART_HardwareFlowControl:硬件流控制选择,只有在硬件流控制模式才有效,可选有使能 RTS、使能 CTS、 同时使能 RTS 和 CTS、不使能硬件流。 3 R9 m4 B3 C( t1 ` USART 时钟初始化结构体# y& g1 z% u8 s
1) USART_Clock:同步模式下 SCLK 引脚上时钟输出使能控制,可选禁止时钟输出(USART_Clock_Disable) 或开启时钟输出 (USART_Clock_Enable);如果使用同步模式发送,一般都需要开启时钟。它设定 USART_CR2 寄存器的 CLKEN 位的值。7 Q9 R/ O( z# T& V- E USART_CPOL:同步模式下 SCLK 引脚上输出时钟极性设置,可设置在空闲时 SCLK 引脚为低电平 (USART_CPOL_Low) 或高电平 (USART_CPOL_High)。它设定 USART_CR2 寄存器的 CPOL位的值。5 M) u; w2 T) _- t USART_CPHA:同步模式下 SCLK 引脚上输出时钟相位设置,可设置在时钟第一个变化沿捕获数据 (USART_CPHA_1Edge) 或在时钟第二个变化沿捕获数据。它设定 USART_CR2 寄存器的CPHA 位的值。USART_CPHA 与 USART_CPOL 配合使用可以获得多种模式时钟关系。$ h% L+ Z; s7 g4 k USART_LastBit:选择在发送最后一个数据位的时候时钟脉冲是否在 SCLK 引脚输出,可以是不输出脉冲 (USART_LastBit_Disable)、输出脉冲 (USART_LastBit_Enable)。它设定 USART_CR2 寄存器的 LBCL 位的值。 & B9 ]& m( \/ t6 s" q8 T . |) c: l1 M; i4 |% P |