首先 通过工具打开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耳机端
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部分
Frame 556 设置SCO命令
下面开始执行event
Frame 560 建立 SCO 完毕
目前为止所有交互都已经完成 进入通话
最后挂断电话
Frame 588 HF发出AT命令 +CHUP 挂断电话
Frame 589 AG收到挂断消息
Frame 584 AG汇报自身状态 已经没有电话了
断开SCO在HCI Frame 602
以上就是整个接听到挂断HCI log流程