转载于https://www.jianshu.com/p/05cf5a8e8453

首先 通过工具打开btsnoop_hci.log文件
具体工具可自行搜素
我用的是这一款Frontline Protocol Analysis System

Frontline Protocol Analysis System下载地址

关于Headset信息操作部分可以直接看Hands-Free

先简述一下蓝牙接通电话的流程

蓝牙的音频连接是A2DP协议
语音通话走的是SCO线路
所以在接电话时会把A2DP转化为SCO
为什么需要转SCO呢
因为a2dp协议不支持边播放边上传
SCO全称Synchronous Connection Oriented
这里有一片关于A2DP和SCO的文章不错可以看看
蓝牙物理链路类型:SCO和ACL链路与A2DP

关于Master/Slave

因为HCI是手机侧生成的
Master手机端
Slave耳机端
有的显示为AG/HF
AG手机端
HF耳机端

image.png

Frame 535 RING 表示已经开始来电,响铃
Frame 538 ATA ATA是耳机同意接听的标志
Frame 539 这个OK是手机端回应耳机我已经知道你同意接听电话了

关于+CIEV, AG向HF汇报自身的状态

比较常见的是:
+CIEV:1,1 接听电话
+CIEV:2,0 当前没有等待的电话需要处理
+CIEV:2,2 拨打电话
+CIEV:2,3 已拨通

Frame 545 +CIEV:1,1 AG有一个电话事件,接听电话
Frame 546 +CIEV:2,0 AG已经没有等待的电话需要处理,意思就是处理完成了

这个时候手机和耳机已经处理完毕接听电话的动作了

下面开始处理语音问题

需要说明的是SCO有两种codec,mSBC和CVSD
Frame 547 +BCS AG向HF查询支持的SCO codec
Frame 554 HF返回支持的codec
Frame 555 AG收到HF回复

下一步就是开始建立SCO连接了

详细内容可以看HCI部分

image.png

Frame 556 设置SCO命令
下面开始执行event
Frame 560 建立 SCO 完毕

目前为止所有交互都已经完成 进入通话

最后挂断电话
Frame 588 HF发出AT命令 +CHUP 挂断电话
Frame 589 AG收到挂断消息
Frame 584 AG汇报自身状态 已经没有电话了
断开SCO在HCI Frame 602

disconnect SCO

以上就是整个接听到挂断HCI log流程

蓝牙耳机打电话流程hci.log解析相关推荐

  1. android蓝牙耳机按键流程,蓝牙耳机按键在Android侧的处理流程

    目前大多数音频视频设备采用红外遥控器,由于距离.角度.障碍物等的影响,红外遥控器的应用受到了很大限制.蓝牙无线通信技术可以实现传统红外遥控全部应用功能,而且客服了红外遥控器的局限性.蓝牙音频视频遥控应 ...

  2. 经典蓝牙 蓝牙连接 - 从AIR LOG和HCI LOG分别分析蓝牙连接流程

    1.目录 文章目录 1.目录 2.LMP连接 3.从HCI LOG分析蓝牙连接流程 1.HCI_Inquiry 1.1 命令参数解析 1.1.1 LAP IAC 1.1.2 Inquiry_Lengt ...

  3. 工具分析HCI Log[FrontLineWireshark]

    Android 蓝牙学习 @# Android 蓝牙 文章目录 1. Frontline 分析HCI Log 2. Wireshark 打开HCI Log 3. Ellisys 1. Frontlin ...

  4. Android View 测量流程(Measure)完全解析

    前言 上一篇文章,笔者主要讲述了DecorView以及ViewRootImpl相关的作用,这里回顾一下上一章所说的内容:DecorView是视图的顶级View,我们添加的布局文件是它的一个子布局,而V ...

  5. [Machine Check机制]X86服务器Linux系统对于MCE的Log解析

    X86服务器Linux系统对于MCE的Log解析 Linux Log信息主要包括两部份内容: APEI的GHES(Generic Hardware Error Soure,通用硬件错误源)解析部分,对 ...

  6. CANOE Log 解析问题

    CANOE Log 解析问题 最近项目的耐久试验出现了,偶发性信号值变化,为了验证试验数据是否正确,使用CANOE记录了数据,接下来需要解决的问题就是如何从几十个G的海量的数据中找到异常数据. 尝试1 ...

  7. 小米手机抓取hci log

    目录 1.打开手机蓝牙 2.打开开发者选项 和 蓝牙日志开关 3 开始记录蓝牙日志 4. 测试蓝牙 5.操作完成取hci log 6 hci log路径 1.打开手机蓝牙 2.打开开发者选项 和 蓝牙 ...

  8. HTTP FLV交互流程及实例解析

    HTTP FLV交互流程及实例解析 文章目录 HTTP FLV交互流程及实例解析 HTTP FLV传输方式 HTTP FLV 抓包分析 结束语 HTTP FLV传输方式 前文已经介绍过,HTTP FL ...

  9. 华为手机获取hci log方法

    针对目前有些手机找不到btsnoop_hci.log情况,现在提供一个参考方案,实测适用huawei p20 1).让手机进入开发者模式,进入开发人员选项,打开蓝牙HCI日志收集,打开USB调试 2) ...

最新文章

  1. Python的必学技术——Jupyter Notebook
  2. 我在这里,等你的故事【小废回家看看】
  3. [转]tesseract OCR Engine overview字符识别学习
  4. CodeForces - 160D Edges in MST(思维+tarjan/树链剖分+线段树)
  5. 微信小程序云开发小项目“研岸日记”日记记录分享,源码分享
  6. 组织来了!特斯拉中国车友俱乐部开启官方认证
  7. 中国联通4G携号转网业务支撑的架构实践
  8. 打工人的健康修炼记:2021卷里求生(附报告下载)
  9. mysql添加序列触发器_在Oracle中创建自增序列之触发器
  10. python if __name__ == ' __main__'
  11. Mac如何用Boot Camp安装Windows 11?告诉你如何安装 能不能安装!
  12. php调用itchat,itchat接口使用示例
  13. 短信验证码平台应该怎么选择?
  14. 计算机原理 · 全加器
  15. NVME-MI 学习记录_1 框架
  16. PHP unlink的使用
  17. 【C初阶】第一篇——初识C语言(万字篇,带你敲响C语言的大门)
  18. 017利用颅内和头皮脑电图进行癫痫预测的卷积神经网络2018
  19. 本地计算机 上的 OracleOraDb11g_home1TNSListener 服务启动后停止
  20. python代码实现技术指标: 转债正股的乖离率

热门文章

  1. VS2008的破解方法
  2. POJ-2965-The Pilots Brothers\' refrigerator
  3. python unix timestamp_Python语言入门:简要分析python UNIX_TIMESTAMP时间处理方法
  4. 台式机性能超级计算机,超级计算机也DIY 科学家用显卡构建最快台式机
  5. Oracle创建本地连接
  6. Vue项目启动报错解决
  7. 从“弄潮儿”到“追风者”,康师傅还能引领市场吗?
  8. 项目中的自定义first table第一个表--人力资源考勤表
  9. java jjcc jjsdjj dd
  10. 最新实用版——JAVA使用POI替换Word模板中指定字符,并可插入图片。