当前位置: 首页 > news >正文

Linux蓝牙之宽带语音(WBS)

Linux蓝牙之宽带语音(WBS) | DD'NotesLinux蓝牙之宽带语音(WBS)1. 概述1.1 什么是WBSWBS(Wideband Speech,宽带语音)是蓝牙技术联盟(SIG)定义的一种高质量语音传输技术,也称为蓝牙宽带语音或HD Voice。它使用 mSBC 编码 在 eSCO(增强同步连接)链路上提供16kHz采样率的语音传输,相比传统的窄带语音(NBS,8kHz采样率)显著提升了通话质量。 1.2 技术背景 特性 窄带语音(https://notes.z-dd.online/2026/06/15/Linux%E8%93%9D%E7%89%99%E4%B9%8B%E5%AE%BD%E5%B8%A6%E8%AF%AD%E9%9F%B3%EF%BC%88WBS%EF%BC%89/

Linux蓝牙之宽带语音(WBS)
1. 概述
1.1 什么是WBS
WBS(Wideband Speech,宽带语音)是蓝牙技术联盟(SIG)定义的一种高质量语音传输技术,也称为蓝牙宽带语音或HD Voice。它使用 mSBC 编码 在 eSCO(增强同步连接)链路上提供16kHz采样率的语音传输,相比传统的窄带语音(NBS,8kHz采样率)显著提升了通话质量。

1.2 技术背景
特性 窄带语音(NBS) 宽带语音(WBS)
采样率 8kHz 16kHz
频率范围 300Hz-3400Hz 50Hz-7000Hz
编码算法 CVSD mSBC
语音质量 MOS 3.0-3.5 MOS 3.5-4.0
蓝牙版本 Bluetooth 1.x+ Bluetooth 2.1+(HFP 1.6+)
1.3 应用场景
蓝牙免提通话(HFP):车载蓝牙、蓝牙耳机
VoIP通话:通过蓝牙设备进行网络语音通话
语音助手:Siri、Google Assistant、Alexa等
助听设备:高质量音频传输
2. 技术原理
2.1 mSBC编码
mSBC(modified Sub-Band Coding)是WBS的核心编码算法:

CODE
输入PCM音频(16kHz, 16bit)

子带分解(4个子带)

自适应量化

比特分配

输出mSBC比特流(60字节/帧)
2.2 SCO/eSCO传输
WBS使用透明模式(Transparent Mode)的eSCO链路传输:

CODE
┌─────────────────────────────────────────────────────────┐
│ eSCO链路参数 │
├─────────────────────────────────────────────────────────┤
│ 参数 │ T1配置 │ T2配置 │
├─────────────────────────────────────────────────────────┤
│ 包类型 │ EV3 │ 2EV3 │
│ 最大延迟 │ 8ms │ 13ms │
│ 重传次数 │ 2次 │ 2次 │
│ 空中传输速率 │ 64kbps │ 64kbps │
│ 带宽需求 │ 80kbps │ 80kbps │
└─────────────────────────────────────────────────────────┘
2.3 USB Alternate Settings
对于USB蓝牙适配器,WBS需要选择合适的 Alternate Settings(不重新枚举设备的情况下,动态切换不同的配置方案,例如改变端点的数量、类型、数据包大小或带宽需求):

CODE
┌─────────────────────────────────────────────────────────┐
│ USB Alternate Settings │
├─────────────────────────────────────────────────────────┤
│ ALT │ 包大小 │ 间隔 │ 用途 │
├─────────────────────────────────────────────────────────┤
│ ALT1 │ 17字节 │ 1ms │ NB语音/兼容 │
│ ALT3 │ 25字节 │ 7.5ms │ WBS备选 │
│ ALT6 │ 63字节 │ 7.5ms │ WBS首选 │
└─────────────────────────────────────────────────────────┘
3. Linux内核实现
下面我们来看看在linux中关于 WBS 的实现。

基于内核v7.1.0-rc6

3.1 代码架构
CODE
┌─────────────────────────────────────────────────────────┐
│ 用户空间 │
│ ┌─────────────────────────────────────────────────────┐│
│ │ BlueZ / PulseAudio / PipeWire ││
│ └─────────────────────────────────────────────────────┘│
└────────────────────────┬────────────────────────────────┘
│ MGMT API
┌────────────────────────┴────────────────────────────────┐
│ 内核空间 │
│ ┌─────────────────────────────────────────────────────┐│
│ │ net/bluetooth/mgmt.c ││
│ │ - set_wideband_speech() ││
│ └─────────────────────────────────────────────────────┘│
│ ┌─────────────────────────────────────────────────────┐│
│ │ net/bluetooth/hci_conn.c ││
│ │ - hci_setup_sync() / esco_param_msbc[] ││
│ └─────────────────────────────────────────────────────┘│
│ ┌─────────────────────────────────────────────────────┐│
│ │ net/bluetooth/sco.c ││
│ │ - SCO连接管理 ││
│ └─────────────────────────────────────────────────────┘│
│ ┌─────────────────────────────────────────────────────┐│
│ │ drivers/bluetooth/ ││
│ │ - btintel.c / btusb.c / btrtl.c / hci_qca.c ││
│ └─────────────────────────────────────────────────────┘│
└─────────────────────────────────────────────────────────┘
3.2 关键数据结构
C
/* WBS eSCO参数定义 - net/bluetooth/hci_conn.c:65-68 */
static const struct sco_param esco_param_msbc[] = {
{ EDR_ESCO_MASK & ~ESCO_2EV3, 0x000d, 0x02 }, /* T2 */
{ EDR_ESCO_MASK | ESCO_EV3, 0x0008, 0x02 }, /* T1 */
};

/* 空中模式定义 - include/net/bluetooth/hci_core.h:2508 */
#define SCO_AIRMODE_TRANSP 0x0003 /* 透明模式,用于mSBC */
#define SCO_AIRMODE_CVSD 0x0000 /* CVSD模式,用于NB语音 */
4. 支持流程分析
4.1 硬件支持检测
驱动程序在初始化时检测硬件是否支持WBS,并设置相应的quirk标志:

C
/* Intel设备 - drivers/bluetooth/btintel.c:3556-3559 */
if (!btintel_test_flag(hdev, INTEL_ROM_LEGACY_NO_WBS_SUPPORT))
hci_set_quirk(hdev, HCI_QUIRK_WIDEBAND_SPEECH_SUPPORTED);

/* USB设备 - drivers/bluetooth/btusb.c:4341-4342 */
if (id->driver_info & BTUSB_WIDEBAND_SPEECH)
hci_set_quirk(hdev, HCI_QUIRK_WIDEBAND_SPEECH_SUPPORTED);

/* Realtek设备 - drivers/bluetooth/btrtl.c:1310-1320 */
switch (btrtl_dev->project_id) {
case CHIP_ID_8822C:
case CHIP_ID_8852A:
case CHIP_ID_8852B:
case CHIP_ID_8852C:
case CHIP_ID_8851B:
case CHIP_ID_8922A:
case CHIP_ID_8852BT:
case CHIP_ID_8761C:
hci_set_quirk(hdev, HCI_QUIRK_WIDEBAND_SPEECH_SUPPORTED);
break;
}

/* Qualcomm设备 - drivers/bluetooth/hci_qca.c:2553-2555 */
if (data->capabilities & QCA_CAP_WIDEBAND_SPEECH)
hci_set_quirk(hdev, HCI_QUIRK_WIDEBAND_SPEECH_SUPPORTED);
4.2 用户空间配置
用户空间通过MGMT API控制WBS功能:


作者: Shell
链接: https://notes.z-dd.online/2026/06/15/Linux%E8%93%9D%E7%89%99%E4%B9%8B%E5%AE%BD%E5%B8%A6%E8%AF%AD%E9%9F%B3%EF%BC%88WBS%EF%BC%89/
来源: DD'Notes
著作权归作者所有。商业转载请联系作者获得授权,非商业转载请注明出处。

。。。 。。。


更多请关注我的博客:https://notes.z-dd.online/

或我的:


http://www.jsqmd.com/news/1110968/

相关文章:

  • 空洞骑士模组管理器终极指南:Scarab让你的游戏体验焕然一新
  • 当预算与交期面临挑战:一种高性价比车载数采架构的可行性与能力解析
  • Hermes 上手指南:AI 编程工作流的新选择,用真实案例讲清边界
  • 2026年了,别再让客服团队被“成本”和“效率”两座大山压垮了
  • Vue withDefaults 转 React:VuReact 怎么处理?
  • 苹果发布 iOS 26.5.2 系统:二十多项安全修复,AI 助力发现内存损坏漏洞
  • Meta限制使用Claude Code和Codex:防“蒸馏陷阱”,省钱又避险!
  • 深圳两家企业同日称估值破200亿,“最像特斯拉”的智平方能否撑起高估值?
  • 8个Illustrator自动化脚本:告别重复劳动,让创意效率翻倍
  • AI时代人才的培养和成长
  • 3分钟掌握Windows实时屏幕翻译神器:Translumo完全配置指南
  • C++23新特性在CLion中的实战体验:从配置到高能语法落地
  • 拯救你的数字书库:novel-downloader小说下载器完整使用指南
  • Ink:用 React 写命令行界面
  • 3步轻松下载B站大会员4K视频:bilibili-downloader终极指南
  • 【Java毕业设计】基于 SpringBoot 的便民找律师法律服务管理系统的设计与实现 基于 SpringBoot 的律师信息展示与案件对接系统(源码+文档+远程调试,全bao定制等)
  • Windows 11优化终极指南:使用Win11Debloat一键提升系统性能
  • 22 点后,我靠这个 AI 工具成了“夜间天才程序员“
  • PEO113-PVP44-PS45三嵌段共聚物PS45-PVP44-PEO113
  • Three.js 精灵标签教程
  • Obsidian系列7:如何管理笔记1-文件夹 标签 书签的使用
  • Java 类加载机制:双亲委派、打破与热替换的实战
  • 干细胞研究获新突破 新规促规范
  • 451. Java 正则表达式 - Matcher 的 start(), end(), matches() 和 lookingAt()
  • 如何解决区域创新部门在政策资金投放中的“撒胡椒面”问题?
  • 港股AI新股成“韭菜镰刀”:上市拉高、配股、入港股通后暴跌,散户成最终买单者
  • 彻底解决 OpenClaw 杀毒拦截、路径报错、网关离线全套方案(含安装包)
  • 如何快速获取网盘直链:LinkSwift网盘下载助手完整指南
  • 从吃灰到生产力:用Armbian让旧电视盒子重获新生
  • GPT-4稀疏激活真相:万亿参数如何实现2%动态路由