A18 STM32_HAL库函数 之 HCD通用驱动程序 -- A-- 所有函数的介绍及使用

本文详细介绍了STM32HAL库中的HCD通用驱动程序,包括初始化、端点配置、停止、中断处理等关键函数的使用方法和功能描述,适用于STM32开发者进行相关项目开发。
摘要由CSDN通过智能技术生成

1 该驱动函数预览

序号函数名描述
1HAL_HCD_Init()初始化USB主机控制器设备。
2HAL_HCD_HC_Init()初始化USB主机控制器的通道。
3HAL_HCD_HC_Halt()停止USB主机控制器的通道。
4HAL_HCD_DeInit()反初始化USB主机控制器设备。
5HAL_HCD_MspInit()初始化MCU外设相关的USB主机控制器引脚或资源。
6HAL_HCD_MspDeInit()反初始化MCU外设相关的USB主机控制器引脚或资源。
7HAL_HCD_HC_SubmitRequest()提交USB主机控制器的通道请求。
8HAL_HCD_IRQHandler()USB主机控制器中断处理程序。
9HAL_HCD_SOF_Callback()USB主机控制器帧同步回调函数。
10HAL_HCD_Connect_Callback()USB主机控制器连接回调函数。
11HAL_HCD_Disconnect_Callback()USB主机控制器断开连接回调函数。
12HAL_HCD_HC_NotifyURBChange_Callback()USB主机控制器通道URB状态改变回调函数。
13HAL_HCD_Start()启动USB主机控制器设备。
14HAL_HCD_Stop()停止USB主机控制器设备。
15HAL_HCD_ResetPort()重置USB主机控制器端口。
16HAL_HCD_GetState()获取USB主机控制器设备状态。
17HAL_HCD_HC_GetURBState()获取USB主机控制器通道URB状态。
18HAL_HCD_HC_GetXferCount()获取USB主机控制器通道传输计数。
19HAL_HCD_HC_GetState()获取USB主机控制器通道状态。
20HAL_HCD_GetCurrentFrame()获取USB主机控制器当前帧数。
21HAL_HCD_GetCurrentSpeed()获取USB主机控制器当前速度。

使用模板:

#include "stm32f4xx_hal.h"

int main(void) {
    // HAL初始化
    HAL_Init();
    
    // 初始化MCU外设相关的USB主机控制器引脚或资源
    HAL_HCD_MspInit();
    
    // 初始化USB主机控制器设备
    HAL_HCD_Init();
    
    // 进行其他操作...
    
    // 启动USB主机控制器设备
    HAL_HCD_Start();
    
    // 提交USB主机控制器的通道请求
    HAL_HCD_HC_SubmitRequest();
    
    // USB主机控制器中断处理程序
    HAL_HCD_IRQHandler();
    
    // 获取USB主机控制器设备状态
    uint32_t hcdState = HAL_HCD_GetState();
    
    // 停止USB主机控制器设备
    HAL_HCD_Stop();
    
    // 反初始化USB主机控制器设备
    HAL_HCD_DeInit();
    
    // 反初始化MCU外设相关的USB主机控制器引脚或资源
    HAL_HCD_MspDeInit();
    
    return 0;
}

1.1 HAL_HCD_Init

函数名HAL_HCD_Init
函数原形HAL_StatusTypeDef HAL_HCD_Init(HCD_HandleTypeDef *hhcd)
功能描述初始化 USB 主机控制器(HCD)
输入参数hhcd:HCD 句柄,指向一个 HCD_HandleTypeDef 结构体
输出参数
返回值HAL_StatusTypeDef:初始化结果,可以是 HAL_OK 或 HAL_ERROR
先决条件
被调用函数

1.2 HAL_HCD_HC_Init

函数名HAL_HCD_HC_Init
函数原形HAL_StatusTypeDef HAL_HCD_HC_Init(HCD_HandleTypeDef *hhcd, uint8_t hc_num, uint8_t epnum, uint8_t direction, uint8_t ep_type, uint8_t token, uint8_t ep_kind, uint8_t speed)
功能描述初始化 USB 主机控制器(HCD)的端点
输入参数 1hhcd:HCD 句柄,指向一个 HCD_HandleTypeDef 结构体
输入参数 2hc_num:端点编号
输入参数 3epnum:端点地址
输入参数 4direction:数据传输方向(IN 或 OUT)
输入参数 5ep_type:端点类型(控制、等等)
输入参数 6token:端点传输类型(SETUP、IN、OUT)
输入参数 7ep_kind:端点类型(CONTROL、BULK、等等)
输入参数 8speed:端点的速度(HS、FS、等等)
输出参数
返回值HAL_StatusTypeDef:初始化结果,可以是 HAL_OK 或 HAL_ERROR
先决条件
被调用函数

1.3 HAL_HCD_HC_Halt

函数名HAL_HCD_HC_Halt
函数原形HAL_StatusTypeDef HAL_HCD_HC_Halt(HCD_HandleTypeDef *hhcd, uint8_t hc_num)
功能描述停止 USB 主机控制器(HCD)的端点传输
输入参数 1hhcd:HCD 句柄,指向一个 HCD_HandleTypeDef 结构体
输入参数 2hc_num:端点编号
输出参数
返回值HAL_StatusTypeDef:停止结果,可以是 HAL_OK 或 HAL_ERROR
先决条件
被调用函数

1.4 HAL_HCD_DeInit

函数名HAL_HCD_DeInit
函数原形HAL_StatusTypeDef HAL_HCD_DeInit(HCD_HandleTypeDef *hhcd)
功能描述反初始化 USB 主机控制器(HCD)
输入参数hhcd:HCD 句柄,指向一个 HCD_HandleTypeDef 结构体
输出参数
返回值HAL_StatusTypeDef:反初始化结果,可以是 HAL_OK 或 HAL_ERROR
先决条件
被调用函数

1.5 HAL_HCD_MspInit

函数名HAL_HCD_MspInit
函数原形void HAL_HCD_MspInit(HCD_HandleTypeDef *hhcd)
功能描述初始化 USB 主机控制器(HCD)的外设
输入参数hhcd:HCD 句柄,指向一个 HCD_HandleTypeDef 结构体
输出参数
返回值
先决条件
被调用函数

1.6 HAL_HCD_MspDeInit

函数名HAL_HCD_MspDeInit
函数原形void HAL_HCD_MspDeInit(HCD_HandleTypeDef *hhcd)
功能描述反初始化 USB 主机控制器(HCD)的外设
输入参数hhcd:HCD 句柄,指向一个 HCD_HandleTypeDef 结构体
输出参数
返回值
先决条件
被调用函数

1.7 HAL_HCD_HC_SubmitRequest

函数名HAL_HCD_HC_SubmitRequest
函数原形HAL_StatusTypeDef HAL_HCD_HC_SubmitRequest(HCD_HandleTypeDef *hhcd, uint8_t hc_num, uint8_t direction, uint8_t ep_type, uint8_t token, uint8_t *pbuff, uint16_t length, uint8_t do_ping)
功能描述提交一个新的 USB 主机控制器(HCD)端点请求
输入参数 1hhcd:HCD 句柄,指向一个 HCD_HandleTypeDef 结构体
输入参数 2hc_num:端点编号
输入参数 3direction:数据传输方向(IN 或 OUT)
输入参数 4ep_type:端点类型(控制、等等)
输入参数 5token:端点传输类型(SETUP、IN、OUT)
输入参数 6pbuff:数据缓冲区
输入参数 7length:数据长度
输入参数 8do_ping:是否执行 ping 操作
输出参数
返回值HAL_StatusTypeDef:提交结果,可以是 HAL_OK 或 HAL_ERROR
先决条件
被调用函数

1.8 HAL_HCD_IRQHandler

函数名HAL_HCD_IRQHandler
函数原形void HAL_HCD_IRQHandler(HCD_HandleTypeDef *hhcd)
功能描述USB 主机控制器(HCD)中断处理函数
输入参数hhcd:HCD 句柄,指向一个 HCD_HandleTypeDef 结构体
输出参数
返回值
先决条件
被调用函数

1.9 HAL_HCD_SOF_Callback

函数名HAL_HCD_SOF_Callback
函数原形void HAL_HCD_SOF_Callback(HCD_HandleTypeDef *hhcd)
功能描述USB 主机控制器(HCD)SOF(起始帧)中断回调函数
输入参数hhcd:HCD 句柄,指向一个 HCD_HandleTypeDef 结构体
输出参数
返回值
先决条件
被调用函数

1.10 HAL_HCD_Connect_Callback

函数名HAL_HCD_Connect_Callback
函数原形void HAL_HCD_Connect_Callback(HCD_HandleTypeDef *hhcd)
功能描述USB 主机控制器(HCD)连接中断回调函数
输入参数hhcd:HCD 句柄,指向一个 HCD_HandleTypeDef 结构体
输出参数
返回值
先决条件
被调用函数

该文档修改记录:

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

总结

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

  • 10
    点赞
  • 9
    收藏
    觉得还不错? 一键收藏
  • 打赏
    打赏
  • 0
    评论
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包

打赏作者

常驻客栈

你的鼓励将是我创作的最大动力

¥1 ¥2 ¥4 ¥6 ¥10 ¥20
扫码支付:¥1
获取中
扫码支付

您的余额不足,请更换扫码支付或充值

打赏作者

实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值