USB网络控制通讯NCM
+ -

NCM 数据接口描述符

2025-07-08 0 0

1. 数据接口的双重配置

NCM设备的数据接口必须实现两个交替设置(Alternate Setting)

Alternate Setting 端点配置 网络流量 典型用途
0(默认) 无端点 ❌ 禁止 省电模式/配置阶段
1(工作模式) Bulk IN + Bulk OUT端点 ✔️ 允许 正常数据传输

2. 描述符关键字段

所有交替设置必须包含以下相同属性:

bInterfaceClass    = 0x0A      // CDC数据类
bInterfaceSubClass = 0x00       // 必须为0
bInterfaceProtocol = 0x01       // 表示NTB协议(见表4-3)

3. 端点配置规则(Alternate Setting 1)

  • Bulk IN端点

    • 方向:Device → Host
    • 用于接收来自设备的网络数据
    • 必须支持最大包大小≥64字节(USB2.0)或≥512字节(USB3.0)
  • Bulk OUT端点

    • 方向:Host → Device
    • 用于发送网络数据到设备
    • 包大小要求同IN端点

4. 实现示例

描述符集合结构

// Alternate Setting 0(无端点)
InterfaceDescriptor = {
    bLength            : 0x09,
    bDescriptorType    : 0x04,
    bInterfaceNumber   : 0x01,      // 数据接口编号
    bAlternateSetting  : 0x00,      // 设置0
    bNumEndpoints      : 0x00,      // 无端点
    bInterfaceClass    : 0x0A,      // CDC数据类
    bInterfaceSubClass : 0x00,      // 必须为0
    bInterfaceProtocol : 0x01,      // NTB协议
    iInterface         : 0x00       // 无字符串描述符
}

// Alternate Setting 1(带端点)
InterfaceDescriptor = {
    bLength            : 0x09,
    bDescriptorType    : 0x04,
    bInterfaceNumber   : 0x01,      // 与设置0相同接口编号
    bAlternateSetting  : 0x01,      // 设置1
    bNumEndpoints      : 0x02,      // 两个端点
    ...                             // 其他字段同设置0
}

BulkInEndpoint = {
    bLength          : 0x07,
    bDescriptorType  : 0x05,
    bEndpointAddress : 0x81,       // EP1 IN
    bmAttributes     : 0x02,       // Bulk
    wMaxPacketSize   : 0x0040,     // 64字节(USB2.0)
    bInterval        : 0x00        // 忽略
}

BulkOutEndpoint = {
    ...                            // 类似配置
    bEndpointAddress : 0x01        // EP1 OUT
}

5. 主机操作流程

  1. 初始状态

    • 设备默认使用Alternate Setting 0(无数据传输)
  2. 激活网络功能

    usb_set_interface(dev, data_iface_num, 1);  // 切换到Alternate Setting 1
    
  3. 错误恢复

    • 传输错误时,主机可切回设置0再重新切回1重置状态

6. 设计原理

  • 节能需求:设置0允许设备在不传输数据时关闭端点电路
  • 协议兼容性:固定协议代码01h确保主机识别NTB格式
  • 灵活性:端点数量/参数可根据设备能力调整(需满足USB规范)

7. 开发者注意事项

  1. 端点编号限制

    • 避免与通信接口的中断端点冲突
    • 示例安全配置:
      Communication IF: Interrupt EP 0x83 (EP3 IN)
      Data IF: Bulk EP 0x01 (OUT), 0x82 (IN)
      
  2. USB3.0优化

    wMaxPacketSize = 0x0400;  // 1024字节(SuperSpeed)
    bmAttributes |= 0x08;     // 启用流控(Streams)
    
  3. 描述符验证工具
    使用USB-IF的USB Descriptor Validator检查合规性

此设计通过硬件级的配置切换,实现了NCM设备在低功耗高性能模式间的平衡,同时保持与主机驱动的标准化交互。

0 篇笔记 写笔记

UVC 扩展单元描述符
扩展单元描述符允许硬件设计者定义任意一组控制接口,使类驱动程序可以在设备与供应商提供的主机软件之间进行通讯控制。扩展单元描述符ID由bUnitID字段中的值唯一标识描述符。同一视频功能内的任何其他单元或终端不得具有相同的功能ID。guidExtensionCode字段包含特定于供应商的代码,该代......
USB 设置描述符SetDescriptor
ID请求码说明7SET_DESCRIPTOR修改设备中有关的描述符,或者增加新的描述符SetDescriptoret用于设置USB的描述符,在SetDescriptor请求的数据阶段,主机将向USB设备发送指定的描述符类型 。bmRequestType(1)bRequest(1)wValue(2)w......
USB超高速 超高速端点伴随描述符
在接口中描述的每个超高速端点都紧跟着一个超高速端点伴侣描述符( EndpointCompanion descriptor)。这个描述符包含只给超高速端点定义的附加端点特性。这个描述符总是 作 为 配 置 描 述 符 信 息 的 一 部 分 在GetDescriptor(Configuration) ......
UVC 描述符描述符布局
USB设备的描述符用于向主机报告其设备的属性信息,UVC设备属于USB设备的一种,故和通用的USB设备一样,也包含设备描述符、配置描述符、接口描述符、端点描述符和字符串描述符。UVC设备在也定义了一些特有的描述符,用于对USB视频设备的扩展。这些特有的UVC描述符和通用的USB描述符,共同组成了UV......
USB音箱 UAC设备描述符分析
这里看到,USB规范采用的是USB1.1版本,不过字符串中又显示的是”USB2.0 Device”,所以这里就有点迷~关于设备描述符各字段的详细解释,详见USB规范中设备描述符一节。从bDeviceClass,bDeviceSubClass和bDeviceSubClass都被置为0来看,这是一个典......
USB超高速 精密时间测量描述符
精密时间测量描述符(Precision Time Measurement)应由支持PTM能力的所有集线器和设备实现。OffsetFieldSizeValueDescription0bLength1数字描述符长度1bDescriptorType1常量描述符的类型,这里为DEVICE CAPABILIT......
UVC 相机终端描述符
相机端点描述符使用bTerminalID来标识其惟一的ID,所有的请求必须使用此ID。wTerminalType用来描述相关的物理实体的信息。typedef struct _CAMERA_TERMINAL_DESCRIPTOR UINT8 bLength; UINT8 bDescr......
UVC Windows下UVC摄像头数据分析
这里我们分析一款UVC摄像头来进行数据分析。环境:win10 x64工具:bushound,usbviewer将摄像头插入PC后,打开usbviewer工具,可以看到关于此摄像头的相关信息。可以看到,这个摄像头其实是一个USB复合设备,所以其对应的系统驱动为USBCCGP,然后再由USB复合设......
UAC 类特定音频控制接口头描述符
UAC类特定音频控制头接口描述符这个名字有点绕,其实这个描述符是前接标准的音频控制接口描述符,后续关于音频控制的所有相关描述符,起着承上起下的作用。当然也可以认为是音频控制相关描述符的前导。这是因为UAC类特定音频控制接口描述符含有一个关键的字段wTotalLength,用于包含音频控制所有接口描述......
UVC的版本区别之处理单元描述符
UVC规范自发布到现在,已经有UVC1.0,UVC1.1和UVC1.5三个版本了。在Windows环境下,支持的最广泛的是UVC1.0,从Win7开始支持UVC1.1,从Win8开始支持UVC1.5.我们常用的UVC摄像头一般为了支持更加广泛的操作系统,一般情况下UVC的固件是UVC1.0,但随着固......
UVC 颜色匹配描述符
颜色匹配描述符是一个可选描述符,这是一个与图像成像时色域相关的参数。对于未压缩的视频格式,必须使用颜色匹配描述符bt709是srgb色域。色域是对一种颜色进行编码的方法,也指一个技术系统能够产生的颜色的总和。在计算机图形处理中,色域是颜色的某个完全的子集。颜色子集最常见的应用是用来精确地代表一......
HID 触摸屏的报表描述符
讲道理,这个触摸屏的报告描述符是我从网上搜索的一段代码,这个触摸屏的报告内容本人也进行了测试。测试是通过本站编写的虚拟触摸屏驱动实现的。0x05, 0x0d, // USAGE_PAGE (Digitizers) 0 0x......
USB音箱 UAC配置描述符分析
该USB音箱的配置描述符和普通USB设备描述符结构体一致,并无特别区别。该配置描述符的总长度(包括后续的所有其它描述符)为110字节,这里相对华为耳机的要少了很多,这是因为少了像麦克风和HID。从配置描述符的字段bmAttributes来看,并不支持远程唤醒功能。 ------------......
UVC 选择器单元描述符
UVC Selector Unit Descriptor 是指 USB Video Class (UVC) 设备的一种描述符类型,用于描述 UVC 设备的功能和特性。Selector Unit Descriptor 提供了选择单元的信息,选择单元通常用于控制 UVC 设备上的不同输入源或输出源。具体......
华为UAC耳机 配置描述符
配置描述符的大小其实不光包括配置描述符自身,也包括后续的所有描述符。这里我们只先介绍一下配置描述符,后续的接口描述符和其它UAC相关描述符在后续一节介绍。配置描述符的内容如下: ------------------ Configuration Descriptor --------------......
关注公众号
  • HID人机交互
  • Linux&USB
  • UAC音频
  • TYPE-C
  • USB规范
  • USB大容量存储
  • USB百科
  • USB网络控制通讯NCM
  • USB周边
  • UVC摄像头
  • Windows系统USB
  • 音视频博客
  • 取消
    感谢您的支持,我会继续努力的!
    扫码支持
    扫码打赏,你说多少就多少

    打开支付宝扫一扫,即可进行扫码打赏哦

    您的支持,是我们前进的动力!