stm32作为现在嵌入式物联网单片机行业中经常要用多的技术,相信大家都有所接触,今天这篇就给大家详细的分析下有关于stm32的出口,还不是很清楚的朋友要注意看看了哦,在最后还会为大家分享有些关于stm32的视频资料便于学习参考。
什么是串口
UART : Universal Asynchronous Receiver/Transmitter 通用异步收发器
USART : Universal Synchronous Asynchronous Receiver/Transmitter 通用同步/异步收发器
一种是常用也是最简单的串行数据传输协议。数据线只需要两根就可以实现全双工。
Tx: 发送数据线
Rx: 接收数据线
A B
TX -----------> Rx
Rx <------------Tx
全双工: 两个设备可以同时发送和接收
串行数据: 发送只一根线,一次只能发送一bit. 一bit接着一bit发送和接收。
模块通信: 上位机 下位机
通信一般需要两个设备,我们把这两个设备,人为叫做上位机, 下位机。
上位机: 把处理性能强的机子,上位机。数据大部分处理都在上位机完成。
下位机: 把数据采集的终端,处理性能单一的机子,下位机。
串口只有一根发送数据线,假如 A要发送一个字符数据 10101010 给B
A -------- ---------
-------- ------- ...
高电平周期是多长?即使是不发送数据Tx线上也有一个电平状态,接收方
它怎么知道你是在发送呢?....
UART数据如何传输?
UART protocol 串口协议。
串口发送和接收数据是以帧为单位. Frame
1帧(Frame)= 1 start bit(起始位) 5-9bits数据位 0/1bit 校验位 stop bits(0.5, 1,1,5,2)
起始位: 一个周期的低电平
数据位: 5-9bits数据位,具体是多少bits,需要双方协商。并且传送是先传送LSB(最低位) … MSB
校验位:
0 bit :没有校验位
1 bit :校验位. “赖子” X
D0 D1 D2 … Dn X
奇校验:要保证传输的1为奇数
D0 D1 D2 … Dn X 要保证这一串数据中1的个数为奇数
1 0 1 0 1 0 1 0 X(1)
1 0 1 0 1 0 1 1 X(0)
偶校验:要保存传输的1为偶数
停止位: 高电平
0.5 个停止位。 半个周期的高电平
1 个停止位
1.5 个停止位
2 个停止位
Baudrate(波特率): 传输速率。
决定 时间周期。
115200 bps: bits per second
物理层标准 the physical layer standards
TTL level UART : TTL电平串口
RS-232:
RS-422:
RS-485:
TTL level UART:
逻辑低电平(0) 0V
逻辑高电平(1) 5V/3.3V
RS-232: 适合较长距离传输
逻辑低电平(0) 3v~ 15V
逻辑高电平(1) -3v~-15v
TTL UART RS-232 RS-422 RS-485
电平 1 3.3V/5V 1 -5V ~ -15V /- 2v /- 1.5v
0 0V 0 5V ~ 15V
信号 单端信号 单端信号 差分信号 差分信号
传输长度 < 2m <15m <1200m <1200m
不同标准的串口,引脚也不一样。TX/Rx是一定存在的。
TTL
RX
TX
GND
VCC
STM32F4xx 串口控制器
TX
RX
硬件流控:
RTS: Request To Send 请求发送信号
终端告诉对方可以向我传输数据啦。
CTS: Clear To Send 清除发送信号
对方告知终端,我要向你发送数据啦
RTS -------> CTS(对方)
CTS <------- RTS(对方)
标志位:
TXE: Transmit data Register Empty
发送数据寄存器为空。
不代表上一次数据已经发送完成啦,因为数据有可能还在 shifter里面
但是此时您可以向TDR写数据啦。
TC : Transmit Complete
发送完成。
发送移位寄存器中的数据已经发送到Tx引脚上面去了。
RXNE: Read Data register Not Empty
接收数据寄存器不为空。意思是你可以读数据啦。
STM32F4xx串口代码流程
(1) GPIO口配置
串口的TX/RX 引脚是由GPIO口来复用的。
a. 使能GPIO分组的时钟
RCC_AHB1PeriphClockCmd
b. 配置GPIO口的功能 GPIO_Init
c. 选择具体的复用功能
GPIO_PinAFConfig
(2) usart配置
a. 使能usart时钟
b. USART_Init
USART_Init(USART_TypeDef * USARTx, USART_InitTypeDef * USART_InitStruct);
typedef struct
{
uint32_t USART_BaudRate; // 波特率
uint16_t USART_WordLength; //传输字长 ,如下两个任选其一:
USART_WordLength_8b
USART_WordLength_9b
在STM32中:传输字长=数据位数 检验位数
uint16_t USART_StopBits; //停止位数,如下 :
USART_StopBits_1 1bit停止位
USART_StopBits_1_5 1.5bit停止位
USART_StopBits_2 2 bits停止位
USART_StopBits_0_5 0.5bit停止位
uint16_t USART_Parity; //校验方式,如下:
USART_Parity_No 无校验
USART_Parity_Odd 奇校验
USART_Parity_Even 偶校验
uint16_t USART_Mode; //串口模式, 如下:可以组合
USART_Mode_Tx 发送模式
USART_Mode_Rx 接收模式
USART_Mode_Tx | USART_Mode_Rx 发送和接收模式
uint16_t USART_HardwareFlowControl; //硬件流控
USART_HardwareFlowControl_None 无硬件流控
USART_HardwareFlowControl_RTS RTS 请求发送。你可以接收对方的数据。
USART_HardwareFlowControl_CTS CTS 清除发送,你可以发数据给对方。
USART_HardwareFlowControl_RTS_CTS RTS_CTS 发送和接收都用流控
} USART_InitTypeDef;
(3) 中断的配置
USART_ITConfig <- 配置串品的中断
在STM32中一个USART只对应一个中断通道,但是引起串口中断的
事件有很多,比如:
TXE -> 发送寄存器为空,可以引起串口中断
TC -> 发送完成,可以引起串口中断
RXNE -> 接收寄存器不为空,可以引起串口中断
……
只不过,这些事件需要"中断控制位使能"
USART_ITConfig(USART1, USART_IT_RXNE,ENABLE);
USART_ITConfig就是用来把一个串口的XX事件,配置成是否引起串口中断的
在串口中断函数里面,就需要判断是哪个串口事件,引起了中断!!!
NVIC_Init()
(4) 使能串口
USART_Cmd
接收(中断函数)
USART1_IRQHanlder()
{
if (USART_GetITStatus(USART1, USART_IT_RXNE) != RESET)
{
//有数据可读啦
data = USART_ReceiveData(USART1); //读取接收到的数据
}
//清除USART1的中断标志
USART_GetITStatus
}
USART_GetITStatus用来获取串口的xx事件标志位
发送数据
USART_SendData(USART1, 0x55);
while (USART_GetFlagStatus(USRAT1, USART_FLAG_TXE) == RESET); //等待发送结束