實驗用到的工具:
藍牙從機:CC2541模塊
抓包工具:TI Sniffer + CC2540 dongle
手機工具:BLE調(diào)試工具箱 (無線技術(shù)聯(lián)盟微信公眾號關(guān)聯(lián)的藍牙測試工具)
01
—
連接請求
TI的Btool是個非常好用的PC主機小工具,其部分界面如下所示,在Discover/Connect界面,可以配置不同的連接參數(shù),選擇掃描以及根據(jù)掃描到的廣播設(shè)備有選擇性的進行連接。多說一句whitelist,什么是whitelist?這個和微信公眾號的白名單一樣,是得到主機授權(quán)的從機設(shè)備,當(dāng)選擇只掃描whitelist的設(shè)備時(前提是已經(jīng)在主機上添加了whitelist設(shè)備),主機只會掃描過濾在whitelist里面的設(shè)備。
從下圖截獲的控制數(shù)據(jù)包可以看到,主機端在廣播掃描之后發(fā)出一條CONNECT_REQ的指令,附帶LL data,開啟了主從設(shè)備連接的過程的第一步。TI的工具做的比較人性化,可以從該條語句的注釋可以看到
Adv PDU Header Type的值為5,對應(yīng)Spec的值是CONNECT_REQ。
在指令后面標(biāo)注出發(fā)起端(主機)和從機端的Mac地址,然后是LL data。
這一條指令嚴(yán)格來說也是屬于廣播范疇,其數(shù)據(jù)格式說明可以參考上一篇文章。
展開CONNECT_REQ包,其數(shù)據(jù)包格式可分為前導(dǎo),接入地址,數(shù)據(jù)包,CRC效驗,詳細(xì)規(guī)范如下:
PDU數(shù)據(jù)包分可分為兩個部分,Header部分是指令(CONNECT_REQ),payload是詳細(xì)LL data,拉出LL Data來看,如下圖所示:
下面對LL Data格式詳細(xì)說明:
AA:連接中的兩設(shè)備的接入地址,如下圖所示,
CRCInit:CRC 初始化
WinSize:主機發(fā)送第一包數(shù)據(jù)的時間窗口
Winoffset:主機發(fā)送第一包數(shù)據(jù)的偏移時間
WinSize和Winoffset是配和使用,主機在發(fā)起CONNECT_REQ開始的Winoffset+1.25ms內(nèi)準(zhǔn)備和從機建立連接,這段時間被稱為連接建立準(zhǔn)備時間,WinSize是主機第一包數(shù)據(jù)發(fā)送的時間窗口范圍。
Interval:藍牙連接間隔時間。
Latency:連接延遲,主多次請求才喚醒從機交互一次數(shù)據(jù)。
Timeout:超時斷開連接。
ChM:跳頻表,主機根據(jù)信道情況給出一張?zhí)l表,約定和從機可用的信道(0-36信道),0表示該信道不可用,1表示該信道可用。
Hop:跳頻階躍,hop是一個5~16的值。
SCA:休眠時鐘校正范圍。
跳頻算法介紹:
跳頻算法用于數(shù)據(jù)連接時候,數(shù)據(jù)信道為37個,跳頻公式如下: unmappedChannel = (lastUnmappedChannel + hopIncrement) mod 37
fn+1=(fn+hop) mod 37
hop是一個5~16的值,每次調(diào)頻之后中心頻率加hop值 mod 37。因為都是正整數(shù),這個表達式在軟件中非常容易實現(xiàn),軟件中通過求余運算便能完成運算,協(xié)議規(guī)定第一次連接事件中fn=0,fn+1=(0+hop) mod 37,也就是hop信道編號。
02
—
連接事件
連接請求發(fā)出之后,開始進入連接狀態(tài),空中數(shù)據(jù)包如下所示,由綠色部分轉(zhuǎn)變?yōu)辄S色部分。
進入藍牙連接狀態(tài),連接狀態(tài)的數(shù)據(jù)包格式如下所示,PUD數(shù)據(jù)包包含兩個部分,頭字說明和數(shù)據(jù)包,頭字說明里面有幾種類型,分別在LLID里面詳細(xì)規(guī)定,NESN和SN控制主從發(fā)送的數(shù)據(jù)包是否被正確接收。
LLID:數(shù)據(jù)包類型格式
NESN:下一個數(shù)據(jù)包序列
SN:數(shù)據(jù)包序列
NESN和SN是配合使用,他們的作用是來標(biāo)識主從是否正確交互。如主從交互所示,主發(fā)心跳包或者數(shù)據(jù)時,標(biāo)記NESN和SN給從機,從機在接收到主機標(biāo)識的NESN和SN之后,回傳NESN和SN+1給主,主接收到和之前發(fā)送的相差1表示之前數(shù)據(jù)正確傳輸,如果主機接收到的回傳值是非(NESN和SN+1),表示數(shù)據(jù)可能在空中存在都是,此時需要重傳。
03
—
數(shù)據(jù)交互
從機發(fā)起了MTU更新:
可以發(fā)現(xiàn)該LL Data出現(xiàn)橙黃色部分,抓包工具對數(shù)據(jù)進行的解析,橙黃部分表示從機要求更新MTU的大小,然后和主機相互約束一個MTU的值,后面數(shù)據(jù)包的格式及按照新約定的MTU大小來傳輸數(shù)據(jù)。
總結(jié)
用一張圖作為總結(jié),整個鏈路層的連接的流程圖如下所示:
所以要想連接一個藍牙設(shè)備,主設(shè)備只需要做幾個動作,自身初始化,掃描周邊設(shè)備,對特點設(shè)備發(fā)出連接請求,開始交換數(shù)據(jù)。
到此低功耗藍牙就相互連接上了,后面應(yīng)用層數(shù)據(jù)交互和加密解密就要交給GAP層和GATT層,SM層來完成,我們下次再講解。
-
SMS
+關(guān)注
關(guān)注
0文章
78瀏覽量
28570 -
GAP
+關(guān)注
關(guān)注
0文章
15瀏覽量
8307
發(fā)布評論請先 登錄
相關(guān)推薦
評論