0
  • 聊天消息
  • 系统消息
  • 评论与回复
登录后你可以
  • 下载海量资料
  • 学习在线课程
  • 观看技术视频
  • 写文章/发帖/加入社区
会员中心
创作中心

完善资料让更多小伙伴认识你,还能领取20积分哦,立即完善>

3天内不再提示

科普一下什么是USB的描述符

单片机匠人 来源:单片机匠人 作者: 黄忠老师 2021-12-02 14:41 次阅读

USB只是一个总线,只提供一个数据通路而已。USB总线驱动程序并不知道一个设备具体如何操作,有哪些行为。具体的一个设备实现什么功能,要由设备自己来决定。那么,USB主机是如何知道一个设备的功能以及行为呢?这就要通过描述符来实现了。那么什么是USB的描述符呢?其实就是一些传递的协议信息,比如设备的类型、厂商ID、产品ID、端点情况、版本号等信息。

既然描述符是协议信息,那么不同的版本也会有所不同,比如USB1.1协议定义的标准描述符有设备描述符、配置描述符、接口描述符、端点描述符、字符串描述符、类特殊描述符以及厂商自定义的描述符。那么USB2.0协议中又增加了两个新的标准描述符有设备限定符描述符和其他速度配置描述符。随着USB协议版本的提升,大家知道都是为了提升速度和可靠度,让用户有更快更高效的体验。那么USB1.1是全速设备,现在我们一起看下USB1.1协议定义的描述符吧。

一个USB设备只有一个设备描述符。设备描述符里决定了该设备有多少种配置,每种配置都有一个配置描述符;而在每个配置描述符中又决定了该配置里有多少个接口,每个接口都有一个接口描述符;在接口描述符里又定义了该接口有多少个端点,每个端点都有一个端点描述符;端点描述符定义了端点的大小、类型等。

如果有类特殊描述符,它跟在相应的接口描述符之后。由此可以看出,USB的描述符之间的关系是一层一层的,最上一层是设备描述符,接下来是配置描述符,再下来是接口描述符,最下面是端点描述符。在主机获取描述符时,首先获取设备描述符,接着再获取配置描述符,然后根据配置描述符中的配置集合的总长度,一次将配置描述符、接口描述符、类特殊描述符(如果有)、端点描述符一次读回。对于字符串描述符,是单独获取的。主机通过发送获取字符串描述符的请求以及描述符的索引号、语言ID来获取对应的字符串描述符。

l 设备描述符主要记录的信息有:设备所使用的USB协议版本号、设备类型、端点0的最大包大小、厂商ID(VID)和产品ID(PID)、设备版本号、厂商字符串索引、产品字符串索引、设备序列号索引、可能的配置数等。

l 配置描述符主要记录的信息有:配置所包含的接口数、配置的编号、供电方式、是否支持远程唤醒、电流需求量等。

l 接口描述符主要记录的信息有:接口的编号、接口的端点数、接口所使用的类、子类、协议等。

l 端点描述符主要记录的信息有:端点号及方向、端点的传输类型、最大包长度、查寻时间间隔等。

l 字符串描述符主要是提供一些方便人们阅读的信息,它不是必需的。

说了半天,也许你还没搞清楚到底设备、配置、接口、端点等这些是什么东西。不要急,这些东西的确是有点晕人。特别是刚接触时,这么多的内容很容易让人搞混,或者似乎是懂了,然后再想想,似乎又没懂……这些所说的设备,就是一个实实在在的USB设备,例如一个USB鼠标。设备有一个设备地址,USB主机依靠这个设备地址来访问设备。而在设备内部还会分的更细。

它会分出一些端点出来,例如端点0、端点1等。就是说,如果USB主机要和USB设备通信,光有设备地址是不够的,还需要一个端点地址。有了设备地址和端点地址,就能准确地对端点发送和读取数据了。好比你要去找8号教学楼的605教室,8号楼就是设备地址,而605教室就是端点地址。而配置和接口,是为了更方便地管理端点而抽象出来的概念。一个设备可以有多个配置,但是同一时刻只能有一个配置有效。每个配置下又可以有多个接口。当我们需要不同的功能时,只要选择不同的配置即可。

拿刚才的教学楼来说,我们可以把它分成两个配置:平时上课用和考试用。考试用时,全部的教室都拿来作考场(即该配置下只有一个接口,接口下有很多端点---教室);而平时上课用时,分成两类(即该配置下有两个接口,每个接口下有一些端点---教室):教师休息室和上课的课室。教师休息室和课室是不能共用的(这在USB中也是如此,同一个端点号不能出现在同一个配置下的两个或者更多个不同的接口中)。但是平时用来做课室或者休息室的教室,考试时都可以拿来作考场(这在USB中也是如此,同一个端点号可用在不同的配置中)。

具有多个接口并由接口来实现功能的设备把它叫做USB复合设备,例如一个USB音频设备,它具有一个音频控制接口,另外还可能具有一到多个音频流或MIDI流接口。在主机端会把USB复合设备的每个接口当作一个功能设备来看待。像常见的USB鼠标、U盘等,通常是单一的设备,即一个设备下只有一个配置描述符、一个接口描述符。

总结一下:由端点构成一个接口(或者反过来说,接口是端点的集合),由接口又构成一个配置(反过来说,配置是接口的集合),再由配置构成一个设备(设备是配置的集合)。学习USB,一定要把这些关系理清楚了,才能按照需要构造出一个合格的USB设备。如果一个设备的各种描述符成功返回了,那么可以说已经成功了大半。相反,只要描述符出现一点问题,哪怕只是一个bit的错误,都可能造成设备无法识别或者无法正常工作。

编辑:jq

声明:本文内容及配图由入驻作者撰写或者入驻合作网站授权转载。文章观点仅代表作者本人,不代表电子发烧友网立场。文章及其配图仅供工程师学习之用,如有内容侵权或者其他违规问题,请联系本站处理。 举报投诉
  • usb
    usb
    +关注

    关注

    60

    文章

    7939

    浏览量

    264491
  • 通信
    +关注

    关注

    18

    文章

    6027

    浏览量

    135951
  • MIDI
    +关注

    关注

    0

    文章

    75

    浏览量

    15658

原文标题:什么是USB的描述符?

文章出处:【微信号:gh_e7f294a514ca,微信公众号:单片机匠人】欢迎添加关注!文章转载请注明出处。

收藏 人收藏

    评论

    相关推荐

    esp32-s2-soala-v1.2如何获取摄像头描述符

    descriptors from PC side,eg. run `lsusb -v` in linux, 请问我该如何获得所需usb描述符
    发表于 06-27 06:48

    二维PDMA可以使用描述符链吗?

    我正在尝试使用二维描述符连锁。 编写了些二维描述符链的代码。 但我有些疑问,比如 1.二维 PDMA 可以使用描述符链吗? 2.如果
    发表于 05-31 08:16

    制作了usb小pcb,在pc上总是显示请求usb设备描述符失败,为什么?

    我按照cyusb3-kit003电路图 自己制作了usb小pcb但是在pc上总是显示请求usb设备描述符失败,我测量了所有供电以及配置管脚都是正确的。
    发表于 05-29 07:46

    FX3无法设置最小/最大比特率描述符值,为什么?

    我正试图通过 FX3 以 5200*3900 分辨率、15fps 的速度从我的 fpga 传输视频数据流,但无法设置最小/最大比特率描述符值,因为描述符大小只有 32 位。 描述符的预期值应该是
    发表于 05-21 06:36

    STM32 USB的字符串描述符不能显示是哪里的问题?

    最近用STM32做了USB 的HID类设备,设备描述符中有指定厂商字符串索引、产品字符串索引、序列号索引。在获取字符串的代码部分也发现确实执行了,但是插上电脑后却没有我想要的字符串,有哪位高手能指点
    发表于 04-30 08:13

    STM32CUBEMX配置生成的个HID设备,电脑提示设备描述符请求失败,为什么?

    如题,win10。 用最新的 STM32CUBEMX 配置生成的 个HID设备编译正常。时钟48MHz 也正常 电脑提示 设备描述符请求失败 有没有遇到类似问题的朋友?
    发表于 04-10 06:05

    STM32F103在官方USB的MSC程序基础上修改为CDC+MSC的组合设备,出现设备描述符请求失败的原因?

    STM32F103在官方USB的MSC程序基础上修改为CDC+MSC的组合设备,出现设备描述符请求失败问题;抓包发现PC主机配置描述符数据和设置的数据不
    发表于 04-07 06:34

    CDC+MSC设备连接不了PC,显示设备描述符请求失败的原因?

    USB组合设备:CDC+MSC,设备连接不了PC,显示设备描述符请求失败;用网上其它成功的例程测试,不是该情况就是只能使用U盘无法用虚拟串口,请问这是什么问题呢
    发表于 04-03 06:44

    USB OTG发送设备描述符失败是什么原因呢?

    能收到SETUP包,并解析数据跑到发送设备描述符,给FIFO写数据也正确,但波形上就发了个数据出去,这会是什么原因呢?
    发表于 03-11 06:29

    CYUSB3014设备描述符路变成2路,windows不识别是怎么解决?

    使用CyUSB3014+WM8960(音频Codec),来实现USB声卡的功能,通过修改的USB设备描述符, 变成两路音频,发现windows不识别。之前的1路是没问题。(见附件one channel and two chann
    发表于 02-28 07:38

    为FX3应用程序实现可变USB配置描述符,开始编译程序时报错怎么解决?

    我正在尝试为我的 FX3 应用程序实现可变 USB 配置描述符,以允许在不同条件包含不同的功能。 为此,我创建了个 uint8_t 指针并使用 malloc 分配正确的内存量,然后
    发表于 02-26 06:58

    CYUSB3KIT-003开发板cyfxusbuart例程,配置描述符无效枚举失败的原因?

    系统:win11 驱动已正常安装,出厂默认例程在I2C启动及USB启动均可正常运行。 选择USB启动,下载cyfxusbuart固件后,设备管理器显示配置描述符无效。 请问是否为驱
    发表于 02-23 06:02

    USB字符串描述符里面的序列号字符串到底是什么东西?

    在设备描述符里面,有个表示序列号字符串描述符的编号,请问这个序列号字符串的描述符是什么东西呢? 厂商字符串和设备字符串都能理解,而且在电脑的“设备与打印机”里面都找到了。但请问这个
    发表于 01-24 08:06

    在Win,如何获取对应插入的USB设备描述符呢?

    各位大佬,请问在Win,如何获取对应插入的USB设备描述符呢?
    发表于 01-24 07:33

    请问SPI DMA描述符列表如何单次触发?

    },{ SpiTxDesptr[0], X, X,X,X}}; 其中X代表些配置信息。 请问如何数据流可实现,单次触发SPIDMA描述符个元素,手动触发三次 不断手动轮询实现。 即 手动
    发表于 01-12 08:07