當(dāng)前位置:首頁(yè) > 公眾號(hào)精選 > 嵌入式藝術(shù)
[導(dǎo)讀]本篇主要講了BLE的Link Layer,包括鏈路層定義的角色和狀態(tài),空中接口數(shù)據(jù)包的通信格式以及各個(gè)字段的含義,方便我們?nèi)シ治鯨OG和定位問(wèn)題。



前言

經(jīng)過(guò)Physical Layer的定義,通信所需的物理通道已經(jīng)okay了,即40個(gè)RF Channel(后面統(tǒng)一使用Physical Channel指代)

此時(shí)Link Layer可以粉墨登場(chǎng)了,它主要的功能,就是在這些Physical Channel上收發(fā)數(shù)據(jù),與此同時(shí),不可避免的需要控制RF收發(fā)相關(guān)的參數(shù)。除此之外,還要做到:

  • Physical Layer僅僅提供了有限的40個(gè)Physical Channel,而B(niǎo)LE中參與通信的實(shí)體的數(shù)量,肯定不是這個(gè)數(shù)量級(jí)。Link Layer需要解決Physical Channel的共享問(wèn)題

  • 通信是兩個(gè)實(shí)體之間的事情,對(duì)這兩個(gè)實(shí)體來(lái)說(shuō),它們希望看到一條為自己獨(dú)享的傳輸通道(就是我們所熟悉的邏輯鏈路,Logical Link)。這也是Link Layer需要解決的

  • Physical Channel是不可靠的,任何數(shù)據(jù)傳輸都可能由于干擾等問(wèn)題而損毀、丟失,這對(duì)有些應(yīng)用來(lái)說(shuō),是接受不了的。因此Link Layer需要提供校驗(yàn)、重傳等機(jī)制,確保數(shù)據(jù)傳輸?shù)目煽啃裕?/span>


狀態(tài)(state)和角色(role)的定義

BLE協(xié)議在Link Layer層抽象出5種狀態(tài):

  • Standby State:待機(jī)狀態(tài),不發(fā)送數(shù)據(jù),也不接收數(shù)據(jù)。該狀態(tài)可以由任何狀態(tài)進(jìn)入,也可以切換到除Connection狀態(tài)外的任意一種狀態(tài)。

  • Advertising State:廣播狀態(tài),可以發(fā)送,監(jiān)聽(tīng),響應(yīng)廣播通道包,由Standby狀態(tài)進(jìn)入。

  • Scanning State:掃描狀態(tài),能夠監(jiān)聽(tīng)廣播設(shè)備發(fā)送的廣播包,由Standby狀態(tài)進(jìn)入。

  • Initiating State:初始化狀態(tài),監(jiān)聽(tīng)指定設(shè)備的廣播通道包,并且響應(yīng)廣播包,并發(fā)送連接請(qǐng)求,以便和廣播設(shè)備建立連接。當(dāng)連接成功后,Initiater和對(duì)應(yīng)的Advertiser都會(huì)切換到Connection狀態(tài)。該狀態(tài)由Standby狀態(tài)進(jìn)入。

  • Connection State:和某個(gè)實(shí)體建立了單獨(dú)通道的狀態(tài),在通道建立之后,由Initiating State或Advertising State進(jìn)入。通道斷開(kāi)后,會(huì)重新回到Standby狀態(tài)。

進(jìn)入Connect State后,又定義了兩種角色:

  • Master Role:由Initiating State進(jìn)入的Connect State,連接成功后,變成了Master Role。

  • Slave Role:由Advertising State進(jìn)入的Connect State,連接成功后,變成了Slave Role。



空中接口數(shù)據(jù)包

該章節(jié)官方文檔定位:Core5.0 P2562

狀態(tài)和角色定義完成后,剩下的事情就簡(jiǎn)單了,主要包括兩類:

  • 提供某一狀態(tài)下,和其它實(shí)體對(duì)應(yīng)狀態(tài)之間的數(shù)據(jù)交換機(jī)制;

  • 根據(jù)上層實(shí)體的指令,以及當(dāng)前的實(shí)際情況,負(fù)責(zé)狀態(tài)之間的切換。

BLE協(xié)議中,這些事情是由一個(gè)叫做空中接口數(shù)據(jù)包(Air Interface Packets)的家伙負(fù)責(zé)。


Air Interface Packets定義了一種包的格式,主要用于描述LE Uncoded PHY、advertising channel和data channel的通信格式。


包的格式如下

3.1 Preamble字段

Preamble前導(dǎo)碼:是0和1的交替序列,當(dāng)物理通道為L(zhǎng)E 1M PHY時(shí),前導(dǎo)碼為1Byte;當(dāng)前導(dǎo)碼為L(zhǎng)E 2M PHY時(shí),前導(dǎo)碼為2Byte。

格式如下


3.2

Access Address字段

Access Address:對(duì)于所有在廣播通道發(fā)送的數(shù)據(jù)包,其值都為0x8E89BED6。一旦鏈路層處于Initiating State狀態(tài)時(shí),會(huì)生成一個(gè)新的Access Address用于連接。該Access Address為一個(gè)4Byte的值。

藍(lán)牙使用Access Address來(lái)標(biāo)識(shí)不同的設(shè)備,Access Address可以是一個(gè)公共的地址,也可以是一個(gè)隨機(jī)的地址,無(wú)論是哪一種類型的地址,均為48bits長(zhǎng)度。

  • 公共地址:官方定義的一些規(guī)范,通用的地址,這里不做解釋。

  • 隨機(jī)地址:可能是靜態(tài)地址,或者是私有地址。


3.2.1靜態(tài)地址

態(tài)地址一般都是隨機(jī)生成的,但是需要滿足下面的幾點(diǎn)規(guī)則:

  • 地址的兩個(gè)最高有效位應(yīng)該等于1

  • 隨機(jī)地址部分,至少有一位為0

  • 隨機(jī)地址部分,至少有一位為1

大多數(shù)的設(shè)備(手機(jī))都是在上電之后,初始化一次靜態(tài)地址,一旦初始化后,靜態(tài)地址就不變了;重新上電后,會(huì)生成新的靜態(tài)地址。


3.2.2私有地址

私有地址又分為:不可解析私有地址和可解析的私有地址。


① 不可解析的私有地址

不可解析私有地址,遵守以下生成規(guī)則:

  • 地址的兩個(gè)最高有效位應(yīng)該等于0

  • 隨機(jī)地址部分,至少有一位為0

  • 隨機(jī)地址部分,至少有一位為1

  • 不能與公共地址有沖突


② 可解析的私有地址

可解析的私有地址,說(shuō)直白點(diǎn)就是帶加密算法所生成的。設(shè)備需要有Local Identity Resolving Key (IRK)或者the Peer Identity Resolving Key (IRK)這兩個(gè)密鑰,生成24bit的號(hào)碼,

可解析的私有地址,遵守以下規(guī)則:

  • 地址的兩個(gè)最高有效位為0和1

  • 隨機(jī)地址部分,至少有一位為0

  • 隨機(jī)地址部分,至少有一位為1

總結(jié):最高有效位的前兩位,代表了設(shè)備地址的類型


3.3PDU字段

Air Interface Packets整體的包結(jié)構(gòu)我們已經(jīng)熟知,下面主要分析以下PDU字段。

PDU:分為兩種,廣播通道上傳輸Advertising Channel PDU;數(shù)據(jù)通道上傳輸Data Channel PDU,長(zhǎng)度為2-257字節(jié)


3.3.1Advertising Channel PDU

廣播通道PDU,包括Advertising PDUScanning PDU、Initiating PDU三種類型。

廣播通道的PDU,由16bit的數(shù)據(jù)頭和1-255Byte的可變大小數(shù)據(jù)組成。

16bit數(shù)據(jù)頭組成如下

  • PDU Type字段的類型有多種,如下

PDU Type有多種,文章定位:core 5.0 P2567,可自行查閱。

  • ChSel:該位為1,支持LE Channel Selection Algorithm,即LE通道選擇算法,反之,不支持。

  • TxAdd:該位為0,表明Payload的AdvA字段為公共的;該位為1,表明Payload的AdvA字段為隨機(jī)的。

  • Length:該字段表明了Payload的長(zhǎng)度

官方文檔定位:core 5.0 P2569


常見(jiàn)的Advertising PDU

  • ADV_IND:該P(yáng)DU用于連接和掃描無(wú)定向的廣播事件。

  • ADV_DIRECT_IND:該P(yáng)DU用于連接和掃描定向的廣播事件。

  • ADV_NONCONN_IND:該P(yáng)DU用于不可連接和不可掃描的非定向廣播事件


常見(jiàn)的Scaning PDU

  • SCAN_REQ:該P(yáng)DU為發(fā)送掃描請(qǐng)求

  • SCAN_RSP:該P(yáng)DU包括了廣播者的地址和返回的掃描響應(yīng)數(shù)據(jù)。


常見(jiàn)的Initiating PDU

  • CONNECT_IND:該P(yáng)DU用于建立連接

LLData域有對(duì)應(yīng)了一些鏈路層參數(shù)的設(shè)置,可以詳細(xì)看Core 5.0 P2578

每一種PDU Type,都會(huì)定義自己的Payload組成。


3.3.2Data Channel PDU

數(shù)據(jù)通道PDU的格式,包括16bit的Header,可變大小的Payload,以及消息完整性檢查MIC.

包的格式如下

Header包括

LLID:該字段標(biāo)識(shí)了這個(gè)包為L(zhǎng)L Data PDU或者LL Control PDU

NESN:下次期望的序列號(hào)

根據(jù)LLID字段,Data Channel PDU又分為L(zhǎng)L Data PDU和LL Control PDU兩種類型。


  • LL Data PDU:該P(yáng)DU用于發(fā)送鏈路層的數(shù)據(jù)。

當(dāng)LLID為01b時(shí),并且Length=0時(shí),表示一個(gè)Empty PDU。

當(dāng)LLID為10b時(shí),則Length不能設(shè)置為0。


  • LL Control PDU:該P(yáng)DU用于控制鏈路層的連接。

Opcode操作碼也有多種:

每一種操作碼對(duì)應(yīng)不同的數(shù)據(jù)長(zhǎng)度。詳細(xì)可見(jiàn)core5.0 P2589


3.4

CRC字段

CRC字段:在鏈路層包的最后,校驗(yàn)所有的PDU數(shù)據(jù),大小長(zhǎng)度為3Byte。

如果PDU數(shù)據(jù)加密,則CRC將會(huì)計(jì)算加密后的PDU數(shù)據(jù)。

CRC算法采用多項(xiàng)式求和的形式進(jìn)行,感興趣的可以了解。Core 5.0 P2601



4總結(jié)

本篇主要講了BLE的Link Layer,包括鏈路層定義的角色和狀態(tài),空中接口數(shù)據(jù)包的通信格式以及各個(gè)字段的含義,方便我們?nèi)シ治鯨OG和定位問(wèn)題。



本站聲明: 本文章由作者或相關(guān)機(jī)構(gòu)授權(quán)發(fā)布,目的在于傳遞更多信息,并不代表本站贊同其觀點(diǎn),本站亦不保證或承諾內(nèi)容真實(shí)性等。需要轉(zhuǎn)載請(qǐng)聯(lián)系該專欄作者,如若文章內(nèi)容侵犯您的權(quán)益,請(qǐng)及時(shí)聯(lián)系本站刪除。
換一批
延伸閱讀

9月2日消息,不造車的華為或?qū)⒋呱龈蟮莫?dú)角獸公司,隨著阿維塔和賽力斯的入局,華為引望愈發(fā)顯得引人矚目。

關(guān)鍵字: 阿維塔 塞力斯 華為

倫敦2024年8月29日 /美通社/ -- 英國(guó)汽車技術(shù)公司SODA.Auto推出其旗艦產(chǎn)品SODA V,這是全球首款涵蓋汽車工程師從創(chuàng)意到認(rèn)證的所有需求的工具,可用于創(chuàng)建軟件定義汽車。 SODA V工具的開(kāi)發(fā)耗時(shí)1.5...

關(guān)鍵字: 汽車 人工智能 智能驅(qū)動(dòng) BSP

北京2024年8月28日 /美通社/ -- 越來(lái)越多用戶希望企業(yè)業(yè)務(wù)能7×24不間斷運(yùn)行,同時(shí)企業(yè)卻面臨越來(lái)越多業(yè)務(wù)中斷的風(fēng)險(xiǎn),如企業(yè)系統(tǒng)復(fù)雜性的增加,頻繁的功能更新和發(fā)布等。如何確保業(yè)務(wù)連續(xù)性,提升韌性,成...

關(guān)鍵字: 亞馬遜 解密 控制平面 BSP

8月30日消息,據(jù)媒體報(bào)道,騰訊和網(wǎng)易近期正在縮減他們對(duì)日本游戲市場(chǎng)的投資。

關(guān)鍵字: 騰訊 編碼器 CPU

8月28日消息,今天上午,2024中國(guó)國(guó)際大數(shù)據(jù)產(chǎn)業(yè)博覽會(huì)開(kāi)幕式在貴陽(yáng)舉行,華為董事、質(zhì)量流程IT總裁陶景文發(fā)表了演講。

關(guān)鍵字: 華為 12nm EDA 半導(dǎo)體

8月28日消息,在2024中國(guó)國(guó)際大數(shù)據(jù)產(chǎn)業(yè)博覽會(huì)上,華為常務(wù)董事、華為云CEO張平安發(fā)表演講稱,數(shù)字世界的話語(yǔ)權(quán)最終是由生態(tài)的繁榮決定的。

關(guān)鍵字: 華為 12nm 手機(jī) 衛(wèi)星通信

要點(diǎn): 有效應(yīng)對(duì)環(huán)境變化,經(jīng)營(yíng)業(yè)績(jī)穩(wěn)中有升 落實(shí)提質(zhì)增效舉措,毛利潤(rùn)率延續(xù)升勢(shì) 戰(zhàn)略布局成效顯著,戰(zhàn)新業(yè)務(wù)引領(lǐng)增長(zhǎng) 以科技創(chuàng)新為引領(lǐng),提升企業(yè)核心競(jìng)爭(zhēng)力 堅(jiān)持高質(zhì)量發(fā)展策略,塑強(qiáng)核心競(jìng)爭(zhēng)優(yōu)勢(shì)...

關(guān)鍵字: 通信 BSP 電信運(yùn)營(yíng)商 數(shù)字經(jīng)濟(jì)

北京2024年8月27日 /美通社/ -- 8月21日,由中央廣播電視總臺(tái)與中國(guó)電影電視技術(shù)學(xué)會(huì)聯(lián)合牽頭組建的NVI技術(shù)創(chuàng)新聯(lián)盟在BIRTV2024超高清全產(chǎn)業(yè)鏈發(fā)展研討會(huì)上宣布正式成立。 活動(dòng)現(xiàn)場(chǎng) NVI技術(shù)創(chuàng)新聯(lián)...

關(guān)鍵字: VI 傳輸協(xié)議 音頻 BSP

北京2024年8月27日 /美通社/ -- 在8月23日舉辦的2024年長(zhǎng)三角生態(tài)綠色一體化發(fā)展示范區(qū)聯(lián)合招商會(huì)上,軟通動(dòng)力信息技術(shù)(集團(tuán))股份有限公司(以下簡(jiǎn)稱"軟通動(dòng)力")與長(zhǎng)三角投資(上海)有限...

關(guān)鍵字: BSP 信息技術(shù)
關(guān)閉