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

从ellisys空口分析蓝牙耳机回连手机失败案例

问题背景:

前两天同事发现我们现在做的项目,耳机在跟某些特定类型安卓手机(尤其是比较新的手机)回连会失败,然后我帮他分析了一些log,记录如下:
回连失败所做步骤如下:

  1. 手机和耳机进行正常的蓝牙配对连接,手机蓝牙界面能看到配对连接成功的设备。
  2. 耳机入盒,手机和耳机断开蓝牙连接,手机蓝牙界面看到设备断开。
  3. 耳机出盒发起回连,发现手机最终会把耳机在蓝牙界面删除,并且报“authentication failure”错误。

我让同事帮忙抓了一份ellisys空口,打开分析一下发生了什么:

问题分析:

手机主动发起连接配对:

在这里插入图片描述
如上图所示:

  • 手机会主动发起paging (ID packet),此时手机作为主设备会设置FHS。
  • 手机和耳机分别进行:
    LMP Version Exchange (Central: 5.4 › Peripheral: 5.4) ,
    LMP Features Exchange (45 Features › 45 Features),
    LMP Extended Features Exchange (SSP Host, LE Host, SC Host › SSP Host, LE Host, SC Host),
    LMP Extended Features Exchange (SC Controller, Ping › SC Controller, Ping),
    注意此时手机和耳机都是支持SC(Secure Connection)的。
  • 接着就会建立LMP连接:LMP Host Connection (Accepted),LMP Setup Complete

在这里插入图片描述
如上图,接下来会交互:

  • 手机会enable AFH:
    LMP Set AFH (Ch=43, 0x0F5E33A, as CLK[27-0]: 0x1EBC674, AFH enabled)
    LMP Channel Classification Request (AFH Reporting Enabled)
  • 手机获取耳机时钟精度:LMP Timing Accuracy Transaction (250 ppm, Jitter=0 us)
  • 耳机告诉手机最大传输slot 为5:LMP Max Slot (5 slots = 3.125 ms)
  • 手机设置包类型:LMP Packet Type Table (2/3Mbps › Accepted)
  • 手机告诉耳机最大传输slot为5:LMP Max Slot (5 slots = 3.125 ms)
  • 手机设置传输速率:
    LMP Preferred Rate (BR=No FEC, Size=Use 5-slot packets, EDR=Use 2 Mbps packets, Size=Use 1-slot packets)。
    LMP Preferred Rate (BR=FEC, Size=Use 1-slot packets, EDR=Use 2 Mbps packets, Size=Use 5-slot packets)
  • 手机设置链路超时时间为5s:LMP Supervision Timeout (8’000 slots = 5.000 s (5.000 s))
  • 耳机获取手机的时钟精度:
    LMP Timing Accuracy Request
    LMP Timing Accuracy Response (45 ppm, Jitter=0 us)

在这里插入图片描述
如上图所示,接下来会进行:

  • 手机和耳机进行IO Capability交互:
    LMP IO Capability Request (DisplayYesNo, No OOB Authentication, MITM Protection Required – Dedicated Bonding)
  • 手机和耳机的公钥交互:LMP Encapsulated P-256 Public Key
  • 手机和耳机第一阶段相互随机数验证:LMP Simple Pairing Confirmation (A6 23 E8 6E C3 7B CD C3 7A EE 04 47 CF E5 94 6E)
  • 手机和耳机相互DHKEY Check:LMP DH Key Check (91 7F 69 33 47 CA 76 3E B3 69 74 B4 8E 70 8F 1E)
  • 手机和耳机进行第二阶段的随机数校验:LMP Secure Authentication Transaction (0x0A67C2A9)
  • 手机请求进入加密模式:LMP Encryption Mode Request (Encryption)
  • 手机发起加密:LMP Start Encryption Request (ED 52 7E 99 B2 28 C8 87 27 85 B4 99 68 84 ED 4C)

在这里插入图片描述
如上图,接下来会进行:

  • SMP OVER BREDR:通过CTKD方式生成LE连接的
    LTK SMP Pairing Feature Exchange (Display Only, No Bonding › Display Only, Bonding, SC)。
    SMP Transport Specific Key Distribution
  • 进行SDP查询。
  • 各种Profile的建立,比如A2DP, HFP等等。

耳机关盒断开连接

在这里插入图片描述
如上图,耳机会发送一个LMP Detach (Remote User Terminated Connection)来告诉手机链路断开。

耳机发起回连

在这里插入图片描述
如上图,耳机发起回连,这个时候耳机会主动发起Paging ID,并且耳机发起FHS决定时钟。注意红色框里面耳机发起的LMP Extended Features Request (SSP Host, LE Host) ,和手机回复的:LMP Extended Features Response (SSP Host, LE Host, SC Host)。这里耳机请求里SC Host不见了。
在这里插入图片描述
如上图,接下来手机主动发起:LMP Extended Features Request (SSP Host, LE Host, SC Host),然而耳机依旧回复:LMP Extended Features Response (SSP Host, LE Host)。至此手机跟耳机无法达成一致的加密方法,手机只能主动断开连接:LMP Detach (Authentication Failure)。

至此整个问题的分析结束。

相关文章:

  • npm包之serve-favicon
  • Day 14 训练
  • 华为首款鸿蒙电脑正式亮相
  • 开发函数踩坑记 sum(1) over(partition by stock_code order by trade_date asc)
  • 2022年8月,​韩先超对中移信息进行微服务架构原理(Docker+k8s+DevOps+Go等)培训
  • HuggingFace与自然语言处理(从框架学习到经典项目实践)[ 01 API操作 ]
  • 【嵌入式开发-SPI】
  • C——操作符详解
  • 【统计学基础】随机抽样的特点
  • WiseAD:基于视觉-语言模型的知识增强型端到端自动驾驶——论文阅读
  • android手机中使用usb hid硬件esp32-s3模拟鼠标和触控板来实现模拟点击、模拟滑动等操作(免费送源代码)
  • 【JAVA】十三、基础知识“接口”精细讲解!(三)(新手友好版~)
  • 【已解决】WORD域相关问题;错误 未找到引用源;复制域出错;交叉引用域到底是个啥
  • PyTorch 入门与核心概念详解:从基础到实战问题解决
  • swagger3融入springboot
  • XML语言
  • 前端实战中的单例模式:以医疗药敏管理为例
  • 从一城一云到AI CITY,智慧城市进入新阶段
  • OpenCV 中用于背景分割的一个类cv::bgsegm::BackgroundSubtractorLSBP
  • 【数据融合实战手册·应用篇】“数字孪生+视频融合”让智慧城市拥有空间感知
  • 汪明荃,今生不负你
  • 不主动上门检查,上海已制定14个细分领域“企业白名单”甄别规则
  • 中俄领导人将讨论从俄罗斯经蒙古至中国天然气管道项目?外交部回应
  • 长三角多地重启游轮跨市游,“恢复苏杭夜航船”呼声又起
  • 第四轮伊美核问题谈判预计5月11日举行
  • “注胶肉”或已泛滥?这几种肉,再爱吃也要管住嘴