经典蓝牙(BR/EDR)设备连接过程分析

一、Inquiry过程

Host发送HCI Inquiry命令,等控制器收到远程设备的Inquiry Response之后,发送HCI Event给Host。Host对Event数据进行分析,待Host 收到Inquiry Complete响应后,整个Inquiry过程结束。
Host收到应答后可以发送HCI inquiry cancel取消Inquiry或等待Inquiry时间到达自动结束。
Inquiry过程,截图来自Core_V5.0.pdf
经典蓝牙(BR/EDR)设备连接过程分析_第1张图片
经典蓝牙(BR/EDR)设备连接过程分析_第2张图片
经典蓝牙(BR/EDR)设备连接过程分析_第3张图片
经典蓝牙(BR/EDR)设备连接过程分析_第4张图片

二、连接过程

在蓝牙核心文档中,连接过程如下:
经典蓝牙(BR/EDR)设备连接过程分析_第5张图片
上图表示Connection establishment 和 detachment 过程,总共需9个不同的过程。有些过程不是必须的比如授权和加密过程。有些过程是必须的,比如ConnectionRequest 和Setup Complet过程。
接下来将具体介绍每个流程:

1、create connection(必选)

Host发送HCI_Create_Connection命令给Controller,然后Controller通过指定的蓝牙地址去page设备。
经典蓝牙(BR/EDR)设备连接过程分析_第6张图片

2、FeaturesExchange(可选)

LM将会去进行exchange feature,获取对方的特性信息,Controller之间的交互。
经典蓝牙(BR/EDR)设备连接过程分析_第7张图片

3、ConnectionRequest(必选)

主Controller LM发送LMP_host_connection_req请求,远程设备LM确认请求,远程设备可能接受也可能拒绝请求。
经典蓝牙(BR/EDR)设备连接过程分析_第8张图片

4、根据设备情形分类

a.远程Host拒绝连接,连接将会被终止

经典蓝牙(BR/EDR)设备连接过程分析_第9张图片

b、远程设备接受连接

经典蓝牙(BR/EDR)设备连接过程分析_第10张图片

c、远程设备接收连接,并请求为Master

经典蓝牙(BR/EDR)设备连接过程分析_第11张图片

5、交换特性

和远程设备交换特性,当AFH(Adaptive FrequencyHopping 自适应跳频)被确认可用后。主设备将会发送LMP_set_AFH 和LMP_channel_classification_req请求。
经典蓝牙(BR/EDR)设备连接过程分析_第12张图片

6、授权

若需要授权,控制器将会为这个连接向host请求Link Key。在HCI中能看到Link key request的事件。
经典蓝牙(BR/EDR)设备连接过程分析_第13张图片

7、Link key

a、如果链接需要授权且没有公用的link key

接下来将会是pairing过程。LM会向host请求link key,如果host给的是Negative 回复,LM将会向host请求PIN。Host端请求结束后,随后远程端也会产生PIN请求。链接的授权都是基于请求到的PIN。最后两端都会将link Key通知到各自的host保存,为以后的链接使用。所以配对过程实际上是获取Link Key的过程!
在HCI中能看到Link key获取结束时,Link key Notification事件。紧跟着的就是授权完成的事件:Authentication Complete。
Note:在配对音箱时HCI中也是negative的回复,但是没有pincode的请求?在另一篇博客中将会单独介绍,加深印象。 如下HCI:
在这里插入图片描述
经典蓝牙(BR/EDR)设备连接过程分析_第14张图片

b、两端有共用的link key

如果两端有共用的link key存在,那么不需要配对过程!LM向host请求link key时,如果得到的是positive回复,将会直接使用回复的link key进行授权。
经典蓝牙(BR/EDR)设备连接过程分析_第15张图片

8、加密

一旦完成配对和授权,就会开始加密。下图显示的是设置一个加密的点对点连接。
经典蓝牙(BR/EDR)设备连接过程分析_第16张图片

9、连接建立完成

两端的LM都会向各自的host发送LMP_setup_complete事件。通过LMP_setup_complete事件将底层的连接handle发送给上层,到此为止建立的链接才可以用来发送上层的数据。

在我的测试平台中发现没有此项消息,handle是通过Authentication Complete Event上传上来的。
经典蓝牙(BR/EDR)设备连接过程分析_第17张图片
至此蓝牙设备已经在物理通道上建立了链接,但上层应用若需要在设备之间通信,那么还需要在L2CAP层次建立连接,L2CAP 的CID(通道ID)好比是计算机的端口号,在访问网络时每个应用程序会对应不同的端口号。在L2CAP层中也类似,对应过来的是每个协议/profile实列对应L2CAP层的一个CID。

三、L2CAP层的连接

下图为从其它博客上截图,具体找不到了,挺火的一篇:
经典蓝牙(BR/EDR)设备连接过程分析_第18张图片
HCI log如下,主要就这几条交互:
经典蓝牙(BR/EDR)设备连接过程分析_第19张图片

接下来就是SDP服务发现协议了。

你可能感兴趣的:(蓝牙)