2024年4月2日发(作者:)

可编辑

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_GetInpu

tReport 用于设备到主机方向的数据通信; WriteFile 、HidD_SetFeature 、 HidD_Set

OutputReport 用于主机到设备方向的数据通信。鉴于实际应用,后文主要讨论 CreateFil

e , WriteFile , ReadFile , HidD_SetFeature 四个函数,明白了这四个函数,其

它的可以类推之。

2

几个常见错误

当使用以上 API 时,如果操作失败,调用 GetLastError() 会得到以下常

见错误:

6 : 句柄无效

23 : 数据错误(循环冗余码检查)

87 : 参数错误

1784 : 用户提供的 buffer 无效

后文将会详细说明这些错误情况。

3.

主机端设备枚举程序流程

精品文档,欢迎下载

可编辑

4.

函数使用说明

CreateFile(devDetail->DevicePat

h,

// 设备路径

GENERIC_READ | GENERIC_WRIT

E, // 访问方式

FILE_SHARE_READ | FILE_SHARE_WRITE, /

/ 共享模式

NULL,

OPEN_EXISTIN

精品文档,欢迎下载