我的程序库01_HAL库文件的头文件结构


title: 我的程序库01_HAL库文件的头文件结构
tags: 编程,STM32,函数库,程序库
grammar_cjkRuby: true


防重复编译和C++冲突申明

其中#ifndef 是为了防止重复编译,cplusplus 是为了防止编译冲突
#ifndef __STM32F4xx_HAL_USART_H  //如果没有包含过头文件,则包含进去
#define __STM32F4xx_HAL_USART_H 

#ifdef __cplusplus  //如果编译器是C++,则下面的语句以C语言进行编译,这里是为了兼容C++调用
extern "C" { 
#endif

包含头文件

其中HAL_DEF文件包含了一些HAL要用到的标志数据结构枚举等

#include "stm32f4xx_hal_def.h"  
 HAL_OK       = 0x00U,
  HAL_ERROR    = 0x01U,
  HAL_BUSY     = 0x02U,
  HAL_TIMEOUT  = 0x03U

结构体的定义,包括如下几个结构体

 1. USART_InitTypeDef
 //   通信的初始化一般有,模式设置,数据速度,数据格式和时钟
 2. HAL_USART_StateTypeDef
   状态包括了:是否初始化过,发送和接收忙,以及错误和超时

模块的虚拟化结构体USART_HandleTypeDef

typedef struct
{
  USART_TypeDef                 *Instance;     //所有模块寄存器的地址都在这里定义
  USART_InitTypeDef             Init;             //初始化结构体
  
  uint8_t                       *pTxBuffPtr;      //发送的数据从哪里取
  uint16_t                      TxXferSize;       //发送数据的长度
  __IO uint16_t                 TxXferCount;     //发送数据计数
  
  uint8_t                       *pRxBuffPtr;      /./接收的数据从哪里取
  uint16_t                      RxXferSize;       /接收数据的长度
  __IO uint16_t                 RxXferCount;   //接收数据计数
  
  DMA_HandleTypeDef             *hdmatx;        //发送数据的DMA模块
  DMA_HandleTypeDef             *hdmarx;        //接收数据的DMA模块
  
  HAL_LockTypeDef                Lock;            //模块锁存,在进行初始化的时候不再使用
  __IO HAL_USART_StateTypeDef    State;     //通信状态,在上面的枚举体中
  __IO uint32_t                  ErrorCode;     //错误码

}USART_HandleTypeDef;

定义数据结构体要用的模块常量

其中错误码,标志,中断和标志,时钟使能这五个常量大部分的模块都会有,其他为特殊功能性的。
// 1. 错误码:
 //2. 数据长度:
// 3. 停止位
 //4. 校验
 //5. 模式:
 //6. 时钟使能:
 //7. 极性
 //8. 相位
 //9. 停止位
 //10. 响应
 //11. 标志位
 //12. 中断

定义一些简单的宏定义函数

  __HAL_USART_RESET_HANDLE_STATE //复位USART模块
 __HAL_USART_GET_FLAG //获取标志
 __HAL_USART_CLEAR_FLAG //清标志位
__HAL_USART_CLEAR_PEFLAG //清模块挂起
 __HAL_USART_CLEAR_FEFLAG//FE //清快速使能标志
 __HAL_USART_CLEAR_NEFLAG //清互补输出
 __HAL_USART_CLEAR_OREFLAG//清OVER溢出
 //中断相关函数
 __HAL_USART_ENABLE_IT // 中断使能
 __HAL_USART_DISABLE_IT //中断去使能
 __HAL_USART_GET_IT_SOURCE
 
 __HAL_USART_ONE_BIT_SAMPLE_ENABLE //一位采样模式使能和失能
 __HAL_USART_ENABLE //UART模块使能和失能

初始化和去初始化的函数

HAL_StatusTypeDef HAL_USART_Init(USART_HandleTypeDef *husart);
HAL_StatusTypeDef HAL_USART_DeInit(USART_HandleTypeDef *husart);
void HAL_USART_MspInit(USART_HandleTypeDef *husart);
void HAL_USART_MspDeInit(USART_HandleTypeDef *husart);
其中MspInit是用于HAL_USART_Init的调用,其中此函数为weak函数,如果需要进行修改,我们也可以自己定义。

模块的IO功能函数组

//发送和接收
HAL_USART_Transmit //发送
HAL_USART_Receive //接收
HAL_USART_TransmitReceive // 全双工下的数据通信

//中断
HAL_USART_Transmit_IT //发送中断
HAL_USART_Receive_IT // 接收中断
HAL_USART_TransmitReceive_IT //收发中断

//DMA相关
HAL_USART_Transmit_DMA
HAL_USART_Receive_DMA
HAL_USART_TransmitReceive_DMA //
HAL_USART_DMAPause //暂停
HAL_USART_DMAResume //重启
HAL_USART_DMAStop //停止

//终止函数
HAL_USART_Abort
HAL_USART_Abort_IT //终止和终止中断

//中断和回调函数,回调函数全是弱定义“ __weak”
HAL_USART_IRQHandler  //中断入口
HAL_USART_TxCpltCallback  //发送完成回调
HAL_USART_TxHalfCpltCallback //发送一半
HAL_USART_RxCpltCallback  //
HAL_USART_RxHalfCpltCallback
HAL_USART_TxRxCpltCallback   //双工发送接收完成
HAL_USART_ErrorCallback   //错误
HAL_USART_AbortCpltCallback //终止

//获取状态和错误状态标识
HAL_USART_GetState
HAL_USART_GetError

私有类型,私有变量和私有常量

这个是上面的IO函数要用到的私有参数,可以不关注
// Private types
//Private variables 
// Private constants 

你可能感兴趣的:(我的程序库01_HAL库文件的头文件结构)