0
  • 聊天消息
  • 系统消息
  • 评论与回复
登录后你可以
  • 下载海量资料
  • 学习在线课程
  • 观看技术视频
  • 写文章/发帖/加入社区
会员中心
创作中心

完善资料让更多小伙伴认识你,还能领取20积分哦,立即完善>

3天内不再提示

GAP层和GATT层,SM层完成应用层数据交互和加密解密!

丫丫119 来源:未知 作者:肖冰 2019-09-20 10:59 次阅读
加入交流群
微信小助手二维码

扫码添加小助手

加入工程师交流群

实验用到的工具:

蓝牙主机:TI BTool + CC2540 dongle

蓝牙从机:CC2541模块

抓包工具:TI Sniffer + CC2540 dongle

手机工具:BLE调试工具箱 (无线技术联盟微信公众号关联的蓝牙测试工具)

01

连接请求

TI的Btool是个非常好用的PC主机小工具,其部分界面如下所示,在Discover/Connect界面,可以配置不同的连接参数,选择扫描以及根据扫描到的广播设备有选择性的进行连接。多说一句whitelist,什么是whitelist?这个和微信公众号的白名单一样,是得到主机授权的从机设备,当选择只扫描whitelist的设备时(前提是已经在主机上添加了whitelist设备),主机只会扫描过滤在whitelist里面的设备。

从下图截获的控制数据包可以看到,主机端在广播扫描之后发出一条CONNECT_REQ的指令,附带LL data,开启了主从设备连接的过程的第一步。TI的工具做的比较人性化,可以从该条语句的注释可以看到

Adv PDU Header Type的值为5,对应Spec的值是CONNECT_REQ。

在指令后面标注出发起端(主机)和从机端的Mac地址,然后是LL data。

这一条指令严格来说也是属于广播范畴,其数据格式说明可以参考上一篇文章。

展开CONNECT_REQ包,其数据包格式可分为前导,接入地址,数据包,CRC效验,详细规范如下:

PDU数据包分可分为两个部分,Header部分是指令(CONNECT_REQ),payload是详细LL data,拉出LL Data来看,如下图所示:

下面对LL Data格式详细说明:

AA:连接中的两设备的接入地址,如下图所示,

CRCInit:CRC 初始化

WinSize:主机发送第一包数据的时间窗口

Winoffset:主机发送第一包数据的偏移时间

WinSize和Winoffset是配和使用,主机在发起CONNECT_REQ开始的Winoffset+1.25ms内准备和从机建立连接,这段时间被称为连接建立准备时间,WinSize是主机第一包数据发送的时间窗口范围。

Interval:蓝牙连接间隔时间。

Latency:连接延迟,主多次请求才唤醒从机交互一次数据。

Timeout:超时断开连接。

ChM:跳频表,主机根据信道情况给出一张跳频表,约定和从机可用的信道(0-36信道),0表示该信道不可用,1表示该信道可用。

Hop:跳频阶跃,hop是一个5~16的值。

SCA:休眠时钟校正范围。

跳频算法介绍:

跳频算法用于数据连接时候,数据信道为37个,跳频公式如下: unmappedChannel = (lastUnmappedChannel + hopIncrement) mod 37

fn+1=(fn+hop) mod 37

hop是一个5~16的值,每次调频之后中心频率加hop值 mod 37。因为都是正整数,这个表达式在软件中非常容易实现,软件中通过求余运算便能完成运算,协议规定第一次连接事件中fn=0,fn+1=(0+hop) mod 37,也就是hop信道编号。

02

连接事件

连接请求发出之后,开始进入连接状态,空中数据包如下所示,由绿色部分转变为黄色部分。

进入蓝牙连接状态,连接状态的数据包格式如下所示,PUD数据包包含两个部分,头字说明和数据包,头字说明里面有几种类型,分别在LLID里面详细规定,NESN和SN控制主从发送的数据包是否被正确接收。

LLID:数据包类型格式

NESN:下一个数据包序列

SN:数据包序列

NESN和SN是配合使用,他们的作用是来标识主从是否正确交互。如主从交互所示,主发心跳包或者数据时,标记NESN和SN给从机,从机在接收到主机标识的NESN和SN之后,回传NESN和SN+1给主,主接收到和之前发送的相差1表示之前数据正确传输,如果主机接收到的回传值是非(NESN和SN+1),表示数据可能在空中存在都是,此时需要重传。

03

数据交互

从机发起了MTU更新:

可以发现该LL Data出现橙黄色部分,抓包工具对数据进行的解析,橙黄部分表示从机要求更新MTU的大小,然后和主机相互约束一个MTU的值,后面数据包的格式及按照新约定的MTU大小来传输数据。

总结

用一张图作为总结,整个链路层的连接的流程图如下所示:

所以要想连接一个蓝牙设备,主设备只需要做几个动作,自身初始化,扫描周边设备,对特点设备发出连接请求,开始交换数据。

到此低功耗蓝牙就相互连接上了,后面应用层数据交互和加密解密就要交给GAP层和GATT层,SM层来完成,我们下次再讲解。

声明:本文内容及配图由入驻作者撰写或者入驻合作网站授权转载。文章观点仅代表作者本人,不代表电子发烧友网立场。文章及其配图仅供工程师学习之用,如有内容侵权或者其他违规问题,请联系本站处理。 举报投诉
  • SMS
    SMS
    +关注

    关注

    0

    文章

    80

    浏览量

    29353
  • GAP
    GAP
    +关注

    关注

    0

    文章

    15

    浏览量

    8625
收藏 人收藏
加入交流群
微信小助手二维码

扫码添加小助手

加入工程师交流群

    评论

    相关推荐
    热点推荐

    不止于4!华秋PCB 6板爆款重磅上线

    4之后,再看6上月,华秋PCB推出了4板爆款,以“真香”价格引爆市场。今天,华秋PCB怀着更大的诚意,为您带来承诺中的下一站——「华秋PCB6板爆款」正式登场!不止于降价,我们
    的头像 发表于 11-12 07:33 199次阅读
    不止于4<b class='flag-5'>层</b>!华秋PCB 6<b class='flag-5'>层</b>板爆款重磅上线

    应用层外设进行数据传输,是否应该调用rt_device_create,rt_device_register等函数呢?

    假如我要在应用层用一个新的usart2串口传输数据,那我应该是怎么做? 1.在工程未编译前将usart2加上,即定义宏BSP_USING_UART2,利用RT-Thread在硬件初始化
    发表于 10-11 06:29

    使用罗德与施瓦茨CMX500的吞吐量应用层测试方案

    5G NR(New Radio)吞吐量应用层测试是评估5G网络性能的一个重要方面,它主要关注的是在实际应用条件下,用户能够体验到的数据传输速率。这种测试通常包括了对下行链路和上行链路的吞吐量进行测量,以确保网络可以满足各种应用场景的需求,比如高清视频流、虚拟现实、增强现实
    的头像 发表于 09-02 13:56 7609次阅读
    使用罗德与施瓦茨CMX500的吞吐量<b class='flag-5'>应用层</b>测试方案

    多层板的历史、特点和关键技术

    多层板的制作方式是在绝缘基板或传统板件(双面板、多层板)表面交替制作绝缘、导电间连接孔,通过多次叠加形成所需层数的多层印制板。
    的头像 发表于 08-15 16:38 1338次阅读

    混合压PCB板的成本如何控制?

    RO4350B),非关键区域使用FR-4,可降低40%材料成本6。 ‌ 铜箔厚度动态调整 ‌ 电源局部使用2oz厚铜,其他区域保持1oz,节省铜材用量50%的同时确保性能6。 二、设计阶段降本 ‌ 层数精简 ‌ 通过优化布线将8
    的头像 发表于 08-15 11:33 662次阅读

    如何从PCB焊盘移除阻焊和锡膏

    使用焊盘属性中 Solder Mask Expansion 的 “ Tented ” 选项:该选项会移除所有阻焊,导致焊盘顶层 / 底层的阻焊无开口(即完全覆盖)。阻焊扩展值为正值时表示向外扩展,若需要阻焊
    的头像 发表于 07-22 18:07 4467次阅读
    如何从PCB焊盘移除阻焊<b class='flag-5'>层</b>和锡膏<b class='flag-5'>层</b>

    基于SM4的文件加密解密功能实现(ECB模式)

    : ​​ 相关技术实现思路如下: 一、SM4加密解密 大部分的代码官网都有,我这里先介绍一下我的开发中踩坑的记录 如果看官方文档里的代码,你会发现,他对于加密
    发表于 06-29 13:21

    感知、传输应用层一体化:工控一体机厂家聚徽详解集成技术方案

    过程的全面智能化与高效化。本文将深入探讨工控一体机中感知、传输应用层一体化的集成技术方案,剖析其工作原理、技术优势以及实际应用案例。 一、工控一体机概述 工控一体机是一种专为工业环境设计的计算机设备,具备高可
    的头像 发表于 05-27 14:35 806次阅读

    PCB的EMC设计(一):的设置与排布原则

    PCB的电磁兼容性(EMC)设计首先要考虑的设置,这是因为单板层数的组成、电源和地层的分布位置以及平面的分割方式对EMC性能有着决定性的影响。为昕MarsPCBlayerstack层数
    的头像 发表于 05-17 16:17 1003次阅读
    PCB的EMC设计(一):<b class='flag-5'>层</b>的设置与排布原则

    接收方数据解封装解析

    OSI 参考模型 应用层----对应用程序提供接口 表示----进行数据格式的转换,以确保一个系统生成的应用层数据能够被另外一个系统的应用层
    的头像 发表于 02-14 17:51 812次阅读
    接收方<b class='flag-5'>数据</b>解封装解析

    什么是原子刻蚀

    本文介绍了什么是原子刻蚀(ALE, Atomic Layer Etching)。 1.ALE 的基本原理:逐精准刻蚀  原子刻蚀(ALE)是一种基于“自限性反应”的纳米加工技术,其特点是以单
    的头像 发表于 01-20 09:32 1173次阅读
    什么是原子<b class='flag-5'>层</b>刻蚀

    带屏蔽的网线怎么接

    带屏蔽的网线接线过程需要细致操作以确保良好的电气连接和屏蔽效果。以下是具体的接线步骤: 一、准备工具和材料 剥线钳 压线钳 屏蔽水晶头 侧线仪(用于测试连接) 带屏蔽的网线 二、剥线和整理 剥去
    的头像 发表于 01-15 10:33 3701次阅读

    在OSI模型中哪一负责处理加密解密数据

    OSI模型是一个七的网络通信框架,每一都承担着特定的职责,以确保数据能够从源头顺利传输到目的地。从底部的物理开始,这一负责在物理媒介
    的头像 发表于 12-26 15:27 1935次阅读

    MultiGABSE-AU物理PMA子及PMD子的相关机制

    在之前的文章中,我们介绍了IEEE 802.3cz[1]协议,MultiGABSE-AU物理中XMII、PCS子以及两个可选功能的相关内容,本篇将介绍MultiGABSE-AU物理PMA子
    的头像 发表于 12-23 10:20 1687次阅读
    MultiGABSE-AU物理<b class='flag-5'>层</b>PMA子<b class='flag-5'>层</b>及PMD子<b class='flag-5'>层</b>的相关机制

    网线没有屏蔽有影响吗

    ,这可能导致数据传输错误、信号衰减、速率下降等问题。在电磁干扰严重的环境中,这种影响尤为明显。 二、信号传输质量下降 屏蔽不仅可以防止外部干扰,还可以减少网线本身的电磁辐射,从而保护信号的完整性。没有屏蔽的网
    的头像 发表于 12-11 10:01 2468次阅读