首页 | 新闻 | 新品 | 文库 | 方案 | 视频 | 下载 | 商城 | 开发板 | 数据中心 | 座谈新版 | 培训 | 工具 | 博客 | 论坛 | 百科 | GEC | 活动 | 主题月 | 电子展
返回列表 回复 发帖

Windows主机端与自定义USB HID设备通信详解

Windows主机端与自定义USB HID设备通信详解

Windows主机端与自定义USB HID设备通信详解

说明:
-
以下结论都是基于 Windows XP 系统所得出的,不保证在其他系统的适用性。
-
在此讨论的是 HID 自定义设备,对于标准设备,譬如 USB 鼠标和键盘,由于操作系统对其独占,许多操作未必能正确执行。

1
所使用的典型 Windows API
CreateFile
ReadFile
WriteFile
以下函数是 DDK 的内容:
HidD_SetFeature
HidD_GetFeature
HidD_SetOutputReport
HidD_GetInputReport
其中, CreateFile 用于打开设备; ReadFile HidD_GetFeature HidD_GetInputReport 用于设备到主机方向的数据通信; WriteFile HidD_SetFeature HidD_SetOutputReport 用于主机到设备方向的数据通信。鉴于实际应用,后文主要讨论 CreateFile WriteFile ReadFile HidD_SetFeature 四个函数,明白了这四个函数,其它的可以类推之。

2
几个常见错误
       当使用以上 API 时,如果操作失败,调用 GetLastError() 会得到以下常见错误:
       6           句柄无效
       23         数据错误(循环冗余码检查)
       87         参数错误
       1784      用户提供的 buffer 无效
       后文将会详细说明这些错误情况。

3.
主机端设备枚举程序流程


4.
函数使用说明
CreateFile(devDetail->DevicePath,                                         // 设备路径
               GENERIC_READ | GENERIC_WRITE,                    // 访问方式
               FILE_SHARE_READ | FILE_SHARE_WRITE,         // 共享模式
               NULL,
               OPEN_EXISTING,                                           // 文件不存在时,返回失败
               FILE_FLAG_OVERLAPPED,                                 // 以重叠(异步)模式打开
               NULL);

在这里, CreateFile 用于打开 HID 设备,其中设备路径通过函数 SetupDiGetInterfaceDeviceDetail 取得。 CreateFile 有以下几点需要注意:
继承事业,薪火相传
返回列表