蓝牙耳机打电话流程hci.log解析

转载于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耳机端

 

蓝牙耳机打电话流程hci.log解析_第1张图片

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部分

蓝牙耳机打电话流程hci.log解析_第2张图片

image.png

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

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

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

 

蓝牙耳机打电话流程hci.log解析_第3张图片

disconnect SCO

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



 

你可能感兴趣的:(C)