USB HID 协议入门
转载请注明来源:cuixiaolei的技术博客
USB HID设备类的应用场合
USB HID类是USB设备的一个标准设备类,包括的设备非常多。HID类设备定义它属于人机交互操作的设备,用于控制计算机操作的一些方面,如USB鼠标、USB键盘、USB游戏操纵杆等。但HID设备类不一定要有人机接口,只要符合HID类别规范的设备都是HID设备。
USB HID设备的一个好处就是操作系统自带了HID类的驱动程序,而用户无需去开发驱动程序,只要使用API系统调用即可完成通信。
USB HID设备类的通信管道
所有的HID设备通过USB的控制管道(默认管道,即端点0)和中断管道(端点1或端点2)与主机进行通信。
管道 要求 说明
控制(端点0) 必须 传输USB描述符、类请求代码以及供查询的消息数据
中断输入 必须 传输从设备到主机的输入数据
中断输出 可选 传输从主机到设备的输出数据
注:USB主机为PC,USB设备如鼠标等。
控制管道主要用于下面3个方面
- 接收/响应USB主机的控制请求以及相关的类数据
- 在USB主机查询时传输数据(如响应Get_Report请求等)
- 接收USB主机的数据
中断管道主要用于下面两个方面
- USB主机接收USB设备的异步传输数据
- USB主机发送有实时性要求的数据给USB设备
从USB主机到USB设备的中断输出数据传输是可选的,当不支持中断输出数据时,USB主机通过控制管道将数据传输给USB设备。
与USB HID设备有关的描述符
HID设备的描述符除了5个USB的标准描述符(设备描述符、配置描述符、接口描述符、端点描述符、字符串描述符)外,还包括三个HID设备类特定的描述符:HID描述符、报告描述符、实体描述符。
除了HID的三个特定描述符组成对HID设备的解释外,5个标准描述符中与HID设备有关的部分有:
- 设备描述符中:bDeviceClass, bDeviceSubClass, bDeviceProtocol三个值必须为0
- 接口描述符中:bInterfaceClass的值必须时0x03, bInterfaceSubClass的值为0或1, 为1表示HID设备是一个启动设备(Boot Device, 一般对PC机有意义,意思是BIOS启动时能识别您使用的HID设备,切只有标准鼠标或者键盘才能称为Boot Device),为0表示HID设备是操作系统启动厚才能识别使用的设备。bInterfaceProtocol的取值含义如下:
bInterfaceProtocol的取值(十进制) 含义
0 NONE
1 键盘
2 鼠标
3-255 保留
下面分别对3个HID设备类特定描述符进行说明:
1.HID描述符
HID描述符关联于接口描述符,因而如果一个设备只有一个接口描述符,则无论它有几个端点描述符,HID设备只有一个HID描述符。HID设备描述符主要描述HID规范的版本号, HID通信所使用的额外描述符, 报表描述符的长度等。下表为HID描述符的结构。
偏移量 域 大小 值 描述
0 bLength 1 数字 此描述符的长度,以字节为单位
1 bDescriptorType 1 常量 描述符种类(此处0X21为HID类)
2 bcdHID 2 数字 HID规范版本号(BCD码),采用4个16进制的BCD格式编码,如版本1.0,0x0100,版本1.1,0x10110
4 bCountryCode 1 数字 硬件目的国家的识别码
5 bNumDescriptors 1 数字 支持的附属描述符数目
6 bDescriptorType 1 常量 HID相关描述符的类型,见下表
7 wDescriptorLength 2 数字 报告描述符的总长度
9 bDescriptorType 1 常量 用于识别描述符类型的常量,使用有一个以上描述符的设备
10 wDescriptorLength 2 数字 描述符总长度,使用在有一个以上描述符的设备
HID相关描述符类型定义
描述符类型值 HID相关描述符类型
0x21 HID描述符
0x22 报表描述符
0x23 实体描述符
2.报告描述符
HID设备的报告描述符比较复杂,也比较难理解。
报告描述符的语法不同于USB标准描述符,它是以项目(item)方式排列而成,没有固定长度。HID的报告描述符已经不是简单的描述某个值对饮过的固定意义了,它已经能够组合出很多种情况,而且需要PC上的HID驱动程序提供parser解释器来对描述符的设备情形进行重新解释,进而组合生成本HID硬件设备独特的数据流格式,所以可以把它理解为“报告描述符脚本语言”更为贴切。我们使用“报告描述符”专用脚本语言,让用户来自己定义它们的HID设备都有什么数据,以及这些数据各个位(bit)都有什么意义。
有关报告描述符的详细信息可以参考USB HID协议,USB协会提供了一个HID描述符编辑工具称作HID Descriptor Tool,用它可以方便生成我们的报告描述符。
一个USB HID设备可以包含多种功能的报告描述符合集,这样可以实现复合设备,如带鼠标功能的USB键盘,这种复合键盘可以通过在报告描述符里包含鼠标和键盘两种报告实现,两个报告用报告ID来区分。
3.实体描述符
实体描述符被用来描述设备的行为特性。实体描述符是可选的描述符,HID设备可以根据其本体的设备特性选择是否包含实体描述符。HID的实体描述符结构如下表:
偏移量 域 大小 说明
0 bDesignator 1 用来指定本体的那一部分影响项目,见下表
1 bFlags 1 位指定标志
位0~4:Effort
位5~7:Qualifier,见下表
| 表7、bDesignator取值含义表 | ||||
| bDesignator取值 | 含义 | bDesignator取值 | 含义 | |
| 0x00 | 无 | 0x15 | 小指 | |
| 0x01 | 手 | 0x16 | 头 | |
| 0x02 | 眼球 | 0x17 | 肩 | |
| 0x03 | 眉 | 0x18 | 腰骨 | |
| 0x04 | 眼皮 | 0x19 | 腰 | |
| 0x05 | 耳 | 0x1A | 大腿 | |
| 0x06 | 鼻 | 0x1B | 膝盖 | |
| 0x07 | 嘴 | 0x1C | 小腿 | |
| 0x08 | 上唇 | 0x1D | 足 | |
| 0x09 | 下唇 | 0x1E | 脚 | |
| 0x0A | 颚 | 0x1F | 脚跟 | |
| 0x0B | 颈 | 0x20 | 拇指 | |
| 0x0C | 上臂 | 0x21 | 大拇指 | |
| 0x0D | 手肘 | 0x22 | 第二指 | |
| 0x0E | 前臂 | 0x23 | 第三指 | |
| 0x0F | 手腕 | 0x24 | 第四指 | |
| 0x10 | 手掌 | 0x25 | 小拇指 | |
| 0x11 | 拇指 | 0x26 | 眉 | |
| 0x12 | 食指 | 0x27 | 脸 | |
| 0x13 | 中指 | 0x28~0xFF | 保留 | |
| 0x14 | 无名指 |
| 表8、Qualifier取值含义 | ||||
| Qualifier取值 | 含义 | Qualifier取值 | 含义 | |
| 0x00 | 无 | 0x04 | 其中之一 | |
| 0x01 | 右 | 0x05 | 中间 | |
| 0x02 | 左 | 0x06 | 保留 | |
| 0x03 | 两者同时 | 0x07 | 保留 |
USB HID类命令(请求)
| 偏移量 | 域 | 大小 | 说明 |
| 0 | bmRequestType | 1 |
HID设备类请求特性如下: 因而,针对HID的设备类请求,仅仅10100001和00100001有效 |
| 1 | bRequest | 1 | HID类请求(参考表10) |
| 2 | wValue | 2 | 高字节说明描述符的类型(参考表5),而低字节为非0值时被用来选定实体描述符。 |
| 4 | wIndex | 2 | 2字节数值,根据不同的bRequest有不同的意义 |
| 6 | wLength | 2 | 该请求的数据段长度 |
| 数值 | HID类请求描述符 | 注释 |
| 0x01 | GET_REPORT | |
| 0x02 | GET_IDLE | |
| 0x03 | GET_PROTOCOL | 仅仅适应于支持启动功能的HID设备(Boot Device) |
| 0x09 | SET_REPORT | |
| 0x0A | SET_IDLE | |
| 0x0B | SET_PROTOCOL | 仅仅适应于支持启动功能的HID设备(Boot Device) |
USB主机在请求HID设备的配置描述符时,设备需要按照顺序返回下面几种描述符:配置描述符, 接口描述符, HID描述符, 端点描述符。HID描述符里又包含了其附属的描述符的类型和长度(如报告描述符),然后主机再根据HID描述符的信息请求其相关的描述符。
USB HID 协议入门的更多相关文章
- USB HID复合设备实例—键盘+鼠标
实现这种USB HID复合设备有两种方法,在<USB HID协议入门>一节已经讲到其中一种方法,说一个USB HID设备可以包含多种功能的报告描述符合集,这样可以实现复合设备,如带鼠标功能 ...
- USB 设备类协议入门【转】
本文转载自:http://www.cnblogs.com/xidongs/archive/2011/09/26/2191616.html 一.应用场合 USB HID类是比较大的一个类,HID类设备属 ...
- USB HID报告及报告描述符简介
在USB中,USB HOST是通过各种描述符来识别设备的,有设备描述符,配置描述符,接口描述符,端点描述符,字符串描述符,报告描述符等等.USB报告描述符(Report Descriptor)是HID ...
- USB传输协议。——Arvin
问题一:USB的传输线结构是如何的呢? 答案一:一条USB的传输线分别由地线.电源线.D+.D-四条线构成,D+和D-是差分输入线,它使用的是3.3V的电压(注意哦,与CMOS的5V电平不同),而电源 ...
- 史上最全USB HID开发资料
史上最全USB HID开发资料 史上最全USB HID开发资料,悉心整理一个月,亲自测试. 涉及STM32 C51 8051F例子都有源码,VC上位机例子以及源码,USB协议,HID协议,USB抓包工 ...
- 蓝牙HID协议笔记
1.概述 The Human Interface Device (HID)定义了蓝牙在人机接口设备中的协议.特征和使用规程.典型的应用包括蓝牙鼠标.蓝牙键盘.蓝牙游戏手柄等.该协议改编自USB ...
- USB HID介绍【转】
本文转载自:http://blog.csdn.net/leo_wonty/article/details/6721214 HID是一种USB通信协议,无需安装驱动就能进行交互,在学习HID之前,先来复 ...
- USB HID描述符【转】
本文转载自: USB是个通用的总线,端口都是统一的.但是USB设备却各种各样,例如USB鼠标,USB键盘,U盘等等,那么USB主机是如何识别出不同的设备的呢?这就要依赖于描述符了.USB的描述符主要有 ...
- Windows与自定义USB HID设备通信说明.
1 . 所使用的典型 Windows API CreateFile ReadFile WriteFile 以下函数是 DDK 的内容: HidD_SetFeature HidD_GetFeatur ...
随机推荐
- CSS画出的各种形状图
利用CSS可以画出各种需要的图形目录[1]矩形[2]圆形[3]椭圆[4]直角三角形[5]正三角形[6]平行四边形[7]梯形[8]六角星[9]六边形[10]五角星简单图形 矩形div{ width: 1 ...
- C++视频课程小结(3)
C++远征之封装篇(上) 章节介绍: 每章小结: 第一章:课程介绍. 按照惯例是章节的总介绍,内容明显多了很多(为了做作业我还要赶进度的说),主要说了:类和对象是本章的主角,然后还有很多配角,像数据成 ...
- HDU 4870Rating(推公式)
有关这个题的高斯消元的方法已经在我的另一篇博客中给出http://www.cnblogs.com/gj-Acit/p/3888382.html 这里介绍一个很吊的解法,复杂度降到了O(n),以下转自h ...
- LRESULT与wParam和lParam的问题
在微软vc提供的头文件中有定义在winnt.h中typedef long LONG;在windef.h中typedef LONG LRESULT; 所以LRESULT就是long,也就是长整形之所以取 ...
- myeclipse 8.5安装freemarker插件方法
1. 下载freemarker最新版本,目前本人下载时最新版本是:freemarker-ide-0.9.14.zip, ide版本的freemarker.jar版本太低,可以替换成高级版本,并修改me ...
- PHP高级应用视频教程大全学习
php 是一种服务器端的,嵌入html的脚本语言.php区别其他像客户端java的地方是它的代码在服务器端执行.php能做什么?最低水平,php可以做任何其他cgi程序所能做的事,例如收集表格数据,生 ...
- redis的文件事件处理器
前言 C10K problem提出了一个问题,如果1w个客户端连接到server上,间歇性的发送消息,有哪些好的方案? 其中的一种方案是,每个线程处理多个客户端,使用异步I/O和就绪通 ...
- C++学习之const整理总结
1什么是const? (const类型)常类型是指使用类型修饰符const说明的类型,常类型的变量或对象的值是不能被更新的.(但可以偷梁换柱进行更新) 2为什么引入const? const 推出的初始 ...
- Ehcache(08)——可阻塞的Cache——BlockingCache
http://haohaoxuexi.iteye.com/blog/2119737 可阻塞的Cache—BlockingCache 在上一节我们提到了显示使用Ehcache锁的问题,其实我们还可以隐式 ...
- SCCM 2007 R2部署、操作详解系列之概念
站点类型 在安装站点时,您决定它将是主站点还是辅助站点.然后,在安装其他站点时,您可以选择将其安排到层次结构关系中,以便父站点管理子站点,中央站点收集所有站点信息,从而进行集中式管理.也可以根据业务和 ...