A65 STM32_HAL库函数 之 USART通用驱动 -- A -- 所有函数的介绍及使用

A65 STM32_HAL库函数 之 USART通用驱动 -- A -- 所有函数的介绍及使用

  • [1 该驱动函数预览](#1 该驱动函数预览)
      • [1.1 HAL_USART_Init](#1.1 HAL_USART_Init)
      • [1.2 HAL_USART_DeInit](#1.2 HAL_USART_DeInit)
      • [1.3 HAL_USART_MspInit](#1.3 HAL_USART_MspInit)
      • [1.4 HAL_USART_MspDeInit](#1.4 HAL_USART_MspDeInit)
      • [1.5 HAL_USART_Transmit](#1.5 HAL_USART_Transmit)
      • [1.6 HAL_USART_Receive](#1.6 HAL_USART_Receive)
      • [1.7 HAL_USART_TransmitReceive](#1.7 HAL_USART_TransmitReceive)
      • [1.8 HAL_USART_Transmit_IT](#1.8 HAL_USART_Transmit_IT)
      • [1.9 HAL_USART_Receive_IT](#1.9 HAL_USART_Receive_IT)
      • [1.10 HAL_USART_TransmitReceive_IT](#1.10 HAL_USART_TransmitReceive_IT)
      • [1.11 HAL_USART_Transmit_DMA](#1.11 HAL_USART_Transmit_DMA)
      • [1.12 HAL_USART_Receive_DMA](#1.12 HAL_USART_Receive_DMA)
      • [1.13 HAL_USART_TransmitReceive_DMA](#1.13 HAL_USART_TransmitReceive_DMA)
      • [1.14 HAL_USART_DMAPause](#1.14 HAL_USART_DMAPause)
  • 该文档修改记录:
  • 总结

1 该驱动函数预览

序号 函数名 描述
1 HAL_USART_Init() 初始化USART。
2 HAL_USART_DeInit() 反初始化USART。
3 HAL_USART_MspInit() 初始化USART的底层硬件资源。
4 HAL_USART_MspDeInit() 反初始化USART的底层硬件资源。
5 HAL_USART_Transmit() 发送USART数据。
6 HAL_USART_Receive() 接收USART数据。
7 HAL_USART_TransmitReceive() 发送并接收USART数据。
8 HAL_USART_Transmit_IT() 使用中断发送USART数据。
9 HAL_USART_Receive_IT() 使用中断接收USART数据。
10 HAL_USART_TransmitReceive_IT() 使用中断发送并接收USART数据。
11 HAL_USART_Transmit_DMA() 使用DMA发送USART数据。
12 HAL_USART_Receive_DMA() 使用DMA接收USART数据。
13 HAL_USART_TransmitReceive_DMA() 使用DMA发送并接收USART数据。
14 HAL_USART_DMAPause() 暂停USART的DMA传输。
15 HAL_USART_DMAResume() 恢复USART的DMA传输。
16 HAL_USART_DMAStop() 停止USART的DMA传输。
17 HAL_USART_Abort() 中止USART的传输。
18 HAL_USART_Abort_IT() 使用中断中止USART的传输。
19 HAL_USART_IRQHandler() USART中断处理函数。
20 HAL_USART_TxCpltCallback() USART发送完成回调函数。
21 HAL_USART_TxHalfCpltCallback() USART半发送完成回调函数。
22 HAL_USART_RxCpltCallback() USART接收完成回调函数。
23 HAL_USART_RxHalfCpltCallback() USART半接收完成回调函数。
24 HAL_USART_TxRxCpltCallback() USART发送接收完成回调函数。
25 HAL_USART_ErrorCallback() USART错误回调函数。
26 HAL_USART_AbortCpltCallback() USART中止完成回调函数。
27 HAL_USART_GetState() 获取USART状态。
28 HAL_USART_GetError() 获取USART错误状态。

1.1 HAL_USART_Init

函数名 HAL_USART_Init
函数原形 HAL_StatusTypeDef HAL_USART_Init(USART_HandleTypeDef *husart)
功能描述 初始化USART外设
输入参数 husart:USART句柄结构体指针
输出参数
返回值 HAL_StatusTypeDef:函数执行状态
先决条件
被调用函数
案例 ```c
USART_HandleTypeDef husart;
HAL_StatusTypeDef status = HAL_USART_Init(&husart);
```

1.2 HAL_USART_DeInit

函数名 HAL_USART_DeInit
函数原形 HAL_StatusTypeDef HAL_USART_DeInit(USART_HandleTypeDef *husart)
功能描述 复位USART外设
输入参数 husart:USART句柄结构体指针
输出参数
返回值 HAL_StatusTypeDef:函数执行状态
先决条件
被调用函数
案例 ```c
USART_HandleTypeDef husart;
HAL_StatusTypeDef status = HAL_USART_DeInit(&husart);
```

1.3 HAL_USART_MspInit

函数名 HAL_USART_MspInit
函数原形 void HAL_USART_MspInit(USART_HandleTypeDef *husart)
功能描述 初始化USART外设的GPIO和时钟
输入参数 husart:USART句柄结构体指针
输出参数
返回值
先决条件
被调用函数
案例 ```c
USART_HandleTypeDef husart;
HAL_USART_MspInit(&husart);
```

1.4 HAL_USART_MspDeInit

函数名 HAL_USART_MspDeInit
函数原形 void HAL_USART_MspDeInit(USART_HandleTypeDef *husart)
功能描述 复位USART外设的GPIO和时钟
输入参数 husart:USART句柄结构体指针
输出参数
返回值
先决条件
被调用函数
案例 ```c
USART_HandleTypeDef husart;
HAL_USART_MspDeInit(&husart);
```

1.5 HAL_USART_Transmit

函数名 HAL_USART_Transmit
函数原形 HAL_StatusTypeDef HAL_USART_Transmit(USART_HandleTypeDef *husart, uint8_t *pData, uint16_t Size, uint32_t Timeout)
功能描述 发送数据到USART外设
输入参数 husart:USART句柄结构体指针
pData:要发送的数据缓冲区指针
Size:要发送的数据大小
Timeout:发送超时时间(毫秒)
输出参数
返回值 HAL_StatusTypeDef:函数执行状态
先决条件
被调用函数
案例 ```c
USART_HandleTypeDef husart;
uint8_t data[] = {0x01, 0x02, 0x03};
HAL_StatusTypeDef status = HAL_USART_Transmit(&husart, data, sizeof(data), 1000);
```

1.6 HAL_USART_Receive

函数名 HAL_USART_Receive
函数原形 HAL_StatusTypeDef HAL_USART_Receive(USART_HandleTypeDef *husart, uint8_t *pData, uint16_t Size, uint32_t Timeout)
功能描述 从USART外设接收数据
输入参数 husart:USART句柄结构体指

针 |

| | pData:接收数据的缓冲区指针 |

| | Size:要接收的数据大小 |

| | Timeout:接收超时时间(毫秒) |

| 输出参数 | 无 |

| 返回值 | HAL_StatusTypeDef:函数执行状态 |

| 先决条件 | 无 |

| 被调用函数 | 无 |

| 案例 | c | | | USART_HandleTypeDef husart; | | | uint8_t data[10]; | | | HAL_StatusTypeDef status = HAL_USART_Receive(&husart, data, sizeof(data), 1000); | | |


1.7 HAL_USART_TransmitReceive

函数名 HAL_USART_TransmitReceive
函数原形 HAL_StatusTypeDef HAL_USART_TransmitReceive(USART_HandleTypeDef *husart, uint8_t *pTxData, uint8_t *pRxData, uint16_t Size, uint32_t Timeout)
功能描述 发送和接收数据到USART外设
输入参数 husart:USART句柄结构体指针
pTxData:要发送的数据缓冲区指针
pRxData:接收数据的缓冲区指针
Size:要发送和接收的数据大小
Timeout:发送和接收超时时间(毫秒)
输出参数
返回值 HAL_StatusTypeDef:函数执行状态
先决条件
被调用函数
案例 ```c
USART_HandleTypeDef husart;
uint8_t tx_data[] = {0x01, 0x02, 0x03};
uint8_t rx_data[3];
HAL_StatusTypeDef status = HAL_USART_TransmitReceive(&husart, tx_data, rx_data, sizeof(tx_data), 1000);
```

1.8 HAL_USART_Transmit_IT

函数名 HAL_USART_Transmit_IT
函数原形 HAL_StatusTypeDef HAL_USART_Transmit_IT(USART_HandleTypeDef *husart, uint8_t *pData, uint16_t Size)
功能描述 使用中断方式发送数据到USART外设
输入参数 husart:USART句柄结构体指针
pData:要发送的数据缓冲区指针
Size:要发送的数据大小
输出参数
返回值 HAL_StatusTypeDef:函数执行状态
先决条件
被调用函数
案例 ```c
USART_HandleTypeDef husart;
uint8_t data[] = {0x01, 0x02, 0x03};
HAL_StatusTypeDef status = HAL_USART_Transmit_IT(&husart, data, sizeof(data));
```

1.9 HAL_USART_Receive_IT

函数名 HAL_USART_Receive_IT
函数原形 HAL_StatusTypeDef HAL_USART_Receive_IT(USART_HandleTypeDef *husart, uint8_t *pData, uint16_t Size)
功能描述 使用中断方式从USART外设接收数据
输入参数 husart:USART句柄结构体指针
pData:接收数据的缓冲区指针
Size:要接收的数据大小
输出参数
返回值 HAL_StatusTypeDef:函数执行状态
先决条件
被调用函数
案例 ```c
USART_HandleTypeDef husart;
uint8_t data[10];
HAL_StatusTypeDef status = HAL_USART_Receive_IT(&husart, data, sizeof(data));
```

1.10 HAL_USART_TransmitReceive_IT

函数名 HAL_USART_TransmitReceive_IT
函数原形 HAL_StatusTypeDef HAL_USART_TransmitReceive_IT(USART_HandleTypeDef *husart, uint8_t *pTx

Data, uint8_t *pRxData, uint16_t Size) |

| 功能描述 | 使用中断方式发送和接收数据到USART外设 |

| 输入参数 | husart:USART句柄结构体指针 |

| | pTxData:要发送的数据缓冲区指针 |

| | pRxData:接收数据的缓冲区指针 |

| | Size:要发送和接收的数据大小 |

| 输出参数 | 无 |

| 返回值 | HAL_StatusTypeDef:函数执行状态 |

| 先决条件 | 无 |

| 被调用函数 | 无 |

| 案例 | c | | | USART_HandleTypeDef husart; | | | uint8_t tx_data[] = {0x01, 0x02, 0x03}; | | | uint8_t rx_data[3]; | | | HAL_StatusTypeDef status = HAL_USART_TransmitReceive_IT(&husart, tx_data, rx_data, sizeof(tx_data)); | | |


1.11 HAL_USART_Transmit_DMA

函数名 HAL_USART_Transmit_DMA
函数原形 HAL_StatusTypeDef HAL_USART_Transmit_DMA(USART_HandleTypeDef *husart, uint8_t *pData, uint16_t Size)
功能描述 使用DMA方式发送数据到USART外设
输入参数 husart:USART句柄结构体指针
pData:要发送的数据缓冲区指针
Size:要发送的数据大小
输出参数
返回值 HAL_StatusTypeDef:函数执行状态
先决条件
被调用函数
案例 ```c
USART_HandleTypeDef husart;
uint8_t data[] = {0x01, 0x02, 0x03};
HAL_StatusTypeDef status = HAL_USART_Transmit_DMA(&husart, data, sizeof(data));
```

1.12 HAL_USART_Receive_DMA

函数名 HAL_USART_Receive_DMA
函数原形 HAL_StatusTypeDef HAL_USART_Receive_DMA(USART_HandleTypeDef *husart, uint8_t *pData, uint16_t Size)
功能描述 使用DMA方式从USART外设接收数据
输入参数 husart:USART句柄结构体指针
pData:接收数据的缓冲区指针
Size:要接收的数据大小
输出参数
返回值 HAL_StatusTypeDef:函数执行状态
先决条件
被调用函数
案例 ```c
USART_HandleTypeDef husart;
uint8_t data[10];
HAL_StatusTypeDef status = HAL_USART_Receive_DMA(&husart, data, sizeof(data));
```

1.13 HAL_USART_TransmitReceive_DMA

函数名 HAL_USART_TransmitReceive_DMA
函数原形 HAL_StatusTypeDef HAL_USART_TransmitReceive_DMA(USART_HandleTypeDef *husart, uint8_t *pTxData, uint8_t *pRxData, uint16_t Size)
功能描述 使用DMA方式发送和接收数据到USART外设
输入参数 husart:USART句柄结构体指针
pTxData:要发送的数据缓冲区指针
pRxData:接收数据的缓冲区指针
Size:要发送和接收的数据大小
输出参数
返回值 HAL_StatusTypeDef:函数执行状态
先决条件
被调用函数
案例 ```c
USART_HandleTypeDef husart;
uint8_t tx_data[] = {0x01, 0x02, 0x03};
uint8_t rx_data[3];
HAL_StatusTypeDef status

= HAL_USART_TransmitReceive_DMA(&husart, tx_data, rx_data, sizeof(tx_data)); |

| ``` |


1.14 HAL_USART_DMAPause

函数名 HAL_USART_DMAPause
函数原形 HAL_StatusTypeDef HAL_USART_DMAPause(USART_HandleTypeDef *husart)
功能描述 暂停USART外设的DMA传输
输入参数 husart:USART句柄结构体指针
输出参数
返回值 HAL_StatusTypeDef:函数执行状态
先决条件
被调用函数
案例 ```c
USART_HandleTypeDef husart;
HAL_StatusTypeDef status = HAL_USART_DMAPause(&husart);
```

该文档修改记录:

修改时间 修改说明
2024年4月30日 第一次发布,介绍了该博客驱动所有函数的介绍及使用

总结

以上就是该博客驱动所有函数的介绍及使用的内容。
有不明白的地方欢迎留言;有建议欢迎留言,我后面编写文档好改进。
创作不容,如果文档对您有帮助,记得给个赞。

相关推荐
代码游侠5 小时前
学习笔记——设备树基础
linux·运维·开发语言·单片机·算法
xuxg20057 小时前
4G 模组 AT 命令解析框架课程正式发布
stm32·嵌入式·at命令解析框架
CODECOLLECT8 小时前
京元 I62D Windows PDA 技术拆解:Windows 10 IoT 兼容 + 硬解码模块,如何降低工业软件迁移成本?
stm32·单片机·嵌入式硬件
BackCatK Chen9 小时前
STM32+FreeRTOS:嵌入式开发的黄金搭档,未来十年就靠它了!
stm32·单片机·嵌入式硬件·freertos·低功耗·rtdbs·工业控制
全栈游侠12 小时前
STM32F103XX 02-电源与备份寄存器
stm32·单片机·嵌入式硬件
Lsir10110_12 小时前
【Linux】中断 —— 操作系统的运行基石
linux·运维·嵌入式硬件
深圳市九鼎创展科技14 小时前
瑞芯微 RK3399 开发板 X3399 评测:高性能 ARM 平台的多面手
linux·arm开发·人工智能·单片机·嵌入式硬件·边缘计算
辰哥单片机设计14 小时前
STM32项目分享:车辆防盗报警系统
stm32·单片机·嵌入式硬件
風清掦15 小时前
【江科大STM32学习笔记-05】EXTI外部中断11
笔记·stm32·学习
小龙报15 小时前
【51单片机】从 0 到 1 玩转 51 蜂鸣器:分清有源无源,轻松驱动它奏响新年旋律
c语言·数据结构·c++·stm32·单片机·嵌入式硬件·51单片机