BLE入门03

虽然BLE空中包(packet)涉及BLE协议栈 link layer,L2CAP,SMP和ATT等各层次,但link layer跟空中包格式关系最紧密,掌握了BLE packet的格式,就很容易理解BLE link layer协议的工作原理,因此文章取名“详解BLE空中包格式—兼BLE link layer协议解析”

BLE Packet格式

BLE链路层(link layer)只定义了一种packet(空中包)格式,如下所示:

而且PDU(protocol data unit,协议数据单元)前两个字节固定为LL header(1个字节长)和payload length(1个字节长,又称data length),即上面的Packet可以展开为:

preamble(前导帧)为1个字节,根据Access Address第一个Bit,有两种取值情况:0x55或者0xAA(纯PHY层行为),如下所示:

Access Address用来标示接收者ID或者空中包身份,如前所示,BLE只有一种packet格式,根据Access Address的不同,又区分两种Packet类型:广播包和数据包:

- 广播包Access Address 固定为 0x8E89BED6

广播包只能在广播信道(channel)上传输,即只能在37/38/39信道上传输(注:从蓝牙5.0开始广播包可以在其它信道上传输)。广播包发送给附近所有的observer(扫描者)。

- 数据包Access Address为一个32bit的随机值

由Initiator生成。数据包,其实是数据信道上的空中包的简称,数据包只在数据信道上传输,即除37/38/39之外的其余37信道(BLE总共占用40个信道)。每建立一次连接,重新生成一次Access address。数据包是给连接通信使用的,即用于master和slave之间通信的。

- CRC为24bit,初始向量为:

蓝牙广播包

蓝牙广播包,全名蓝牙广播通道(channel)空中包,即在蓝牙广播通道上传输的空中包,为两种空中包的一种,其具体格式如下所示:

Advertising Header 即前述的LL header,长度为一个字节,其每bit定义如下所示:

PDU Type为3bit,具体定义如下。可以看出扫描PDU和发起连接PDU都属于广播包。

注:CONNECT_REQ也可写作CONNECT_IND

TxAdd/RxAdd,各占1bit,表示随后的Device Address字段代表的蓝牙MAC地址类型,值0代表Public地址,值1代表Random地址。

Payload length定义如下所示,所以广播包PDU最长37个字节。

Device Address,广播包中的强制字段,俗称蓝牙MAC地址,如果是广播包,则是advertiser的MAC地址;如果是scan包或者连接请求包,则是scanner的MAC地址。蓝牙device address为6个字节,这样Advertising data最长为:37-6 = 31B,这就是广播包数据最长只能31个字节的由来。如前所述,device address分public和random两种,定义如下所示:

Random device address又有三种类型,定义如下所示:

Advertising data我会另写一篇文章来详述,这里就不再介绍了。

如下为一个完整的真实的广播包示例,注意:BLE空中包采用小端模式

AAD6BE898E600E3B75AB2A02E102010504FF5900538EC7B2

-AA – 前导帧(preamble)

-D6BE898E – 访问地址(access address)

-60 – LL帧头字段(LL header)

-0E – 有效数据包长度(payload length)

-3B75AB2A02E1– 广播者设备地址(advertiser address)

-02010504FF590053 – 广播数据

-8EC7B2 – CRC24值

注:上述广播包是蓝牙4.x格式,蓝牙5.0广播包除了包含上述格式外(记住:蓝牙5是跟蓝牙4.x兼容的!),还有一些新的定义,以后我也会写一篇关于蓝牙5广播的文章来专门阐述蓝牙5扩展广播包。

参考:

https://mp.weixin.qq.com/s/okNk1pin3ph7pLMKqLZthQ

©著作权归作者所有,转载或内容合作请联系作者
【社区内容提示】社区部分内容疑似由AI辅助生成,浏览时请结合常识与多方信息审慎甄别。
平台声明:文章内容(如有图片或视频亦包括在内)由作者上传并发布,文章内容仅代表作者本人观点,简书系信息发布平台,仅提供信息存储服务。

相关阅读更多精彩内容

  • BLE协议栈主要由如下几部分组成: PHY层(Physical layer物理层) PHY层用来指定BLE所用的无...
    张志中阅读 5,052评论 0 4
  • BLE广告和信标 (原文) BLE广告是蓝牙低功耗最重要的方面之一。 了解如何正确使用广告可以帮助你降低功耗,加快...
    公子小水阅读 9,071评论 1 3
  • BLE 概览 第一章 什么是低功耗蓝牙(Bluetooth Low Energy) 低功耗蓝牙是一项新技术,它不但...
    一只爱运动的猪阅读 4,346评论 0 1
  • 简介 用简单的话来定义tcpdump,就是:dump the traffic on a network,根据使用者...
    保川阅读 11,193评论 1 13
  • 简介 用简单的话来定义tcpdump,就是:dump the traffic on a network,根据使用者...
    JasonShi6306421阅读 5,033评论 0 1

友情链接更多精彩内容