Window s 主机端与自定义USB HID 设备通信详解 说明: - 以下结论都是基于 Window s XP 系统所得出的,不保证在其他系统的适用性
- 在此讨论的是 HID 自定义设备,对于标准设备,譬如 USB 鼠标和键盘,由于操作系统对其独占,许多操作未必能正确执行
1 . 所使用的典型 Window s 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_WRI