蓝牙系列十五:协议栈GAP层分析

Generic Access Profile(通用访问规范) 它在用来控制设备连接和广播,用于提供蓝牙设备的通用访问功能,包括设备发现、连接、鉴权、服务发现等等。

GATT是建立连接后通信规范, 而蓝牙是通过GAP建立通信的。

GAP 使你的设备被其他设备可见,并决定了你的设备是否可以或者怎样与合同设备进行交互。

GAP 给设备定义了若干角色,其中主要的两个是:外围设备(Peripheral)和中心设备(Central)

    外围设备:这一般就是非常小或者简单的低功耗设备,用来提供数据,并连接到一个更加相对强大的中心设备。例如小米手环。
    中心设备:中心设备相对比较强大,用来连接其他外围设备。例如手机等。

下面这个图是BLE协议各层跟医院的各个科室的类比图:

每个医院的大堂都有些约定:

① 大堂里有医院的介绍,你可以根据它确定这个医院是否适合你;

② 有急救通道

③ 要挂号,挂号后你跟医院才建立了联系,才能去找医生看病。

重点在于:怎么确定医院(是否适合你)、怎么建立联系。

在BLE里,也有一些约定用来发现设备、连接设备,在GAP里定义这些约定。GAP是一个Profile(规范)。这个规范里,它要用到LL层、L2CAP层、SM层、ATT层、GATT层的功能。

想想这4个设备:

1. 超市每个货架那里有一个蓝牙设备,它不断向周边发出广告信息:你肯定不想连接它

2. 用电池供电的手环:平时它为了省电什么都不做,你要发现、连接它,首先要按一下按钮

3. 家里用插座供电的闹钟:它不需要省电,它可以一直发出广播信息。

4. 你的手机

上述设备的角色(Role)、所处的模式(Mode)、能执行的操作或规程(Procedure),由GAP定义。比如:

1. 货架上的蓝牙设备:

它的角色是:Broadcaster,广播者。只广播信息,别人不可能也没必要去连接它。

2. 手环:

它的角色是:Peripheral,外围设备。它可以处于这种模式:Limited Discoverable Mode,有限可发现模式。按下它的按钮的一小段时间里,可以用手机去发现它;超时之后,手机无法发现它。

对应的,手机的Role是Central,中央设备,它要执行这2种规程(Procedure)之一才能发现这个手环:

① Limited Discovery Procedure

② General Discovery Procedure

3. 闹钟:

它的角色是:Peripheral,外围设备。它可以处于这种模式:General Discoverable Mode,普通可发现模式,一直发出广播信号。

对应的,手机的Role是Central,中央设备,它要执行这种规程(Procedure)才能发现这个手环:General Discovery Procedure

4. 手机

即可能是Observer,也可能是Central。

当它去获得货架广告机的信息时,它是Observer;

当它去尝试连接手环、闹钟时,它是Central。

下面细说。

一、广播数据的格式定义:

在LL层里对广播包的格式有过定义,但是对于其中传输的广播数据,它的格式是在GAP中定义的。

对于ADV_IND类型的广播包,它的Payload也是在LL层定义的,如下:

但是,其中的AdvData格式是在GAP层定义的:

总结起来有2个概念:PDU Type、AD Type,如下:

1. LL层可以发出各种不同PDU Type的广播包,比如:可连接的、不可连接的等等

2. 某种PDU Type的广播包中,还可以进一步定义它的AD Type:

  在GAP中,可以设置广播类型(AD Type),比如Discoverable Mode

二、BLE GAP层中的角色(Role):

GATT层从数据的提供、使用者角度,提出了server、client的概念。

GAP则从数据的发起、接收者角度,提出了以下4个角色(Role)的概念:

1. Broadcaster,广播者

发出广播信号,可以没有无线接收器。

2. Observer,观察者

接收广播信号,可以没有无线发送器。

3. Peripheral,外围设备

可以跟其他设备建立连接,建立连接时它是被动的一方。

既含有无线发送器,也含有无线接收器。

4. Central,中央设备

可以跟其他设备建立连接,建立连接时它是主动的一方。

既含有无线发送器,也含有无线接收器。

这些角色在物理层、LL层上能进行的操作如下:

三、Broadcast Mode and Observation Procedure:

处于Broadcast Mode的设备,可以发出这2种事件之一:

① non-connectable and non-scannable undirected events

② non-connectable and non-scannable directed advertising events

怎么发出呢?在LL层规范里显示,是使用ADV_NONCONN_IND的广播包实现第①种事件的:

在上图中的ADV_NONCONN_IND的广播包里,广播数据中的AD Type要设置这2个位为0:

① LE General Discoverable Mode

② LE Limited Discoverable Mode

对于第②种事件,在LL层规范里也有描述,但是没有图。它是使用ADV_EXT_IND广播包实现来实现的。ADV_EXT_IND广播包是在BLE 5.0规范里才引入了,我们没有讲解它。

处于Broadcast Mode的设备发出的广播操作,别人怎样来接收它们?要使用Observation Procedure来接收。

Observation Procedure有2种方法:主动扫描(active scanning)、被动扫描(passive scanning)

四、Discoverability modes and procedures:

1. Non-Discoverable Mode

不可发现模式,这很少用到。

在这种模式下,其发出的广播包中的AD Type要设置这2个位为0:

① LE General Discoverable Mode

② LE Limited Discoverable Mode

问题就来了,既然“不想被别人发现”,为何还要发出广播包?

这完全是各个蓝牙设备都遵守这样的君子约定:

① 设备A发出广播报文,但是在其中的AD Type中表示自己是“不可发现”的

② 设备B的Controller,肯定可以接收到这个广播包,上传到Host,解析出其中的AD Type

③ 设备B的Host,是个“君子”,不在UI界面中显示设备A;但是也许设备B可以自动连接设备A。

2. Limited Discoverable Mode

有限可发现模式,为了省电,某些设备可能要先按一下按键,它才发出广播报文;并且过一段时间后,它就继续休眠。

我们使用手机查找蓝牙设备时,可能会列出很多个设备,处于“有限可发现模式”的设备应该显示在列表的最上面,因为它最紧迫。

在这种模式下,其发出的广播包中的AD Type要设置这个位为1:

LE Limited Discoverable Mode

3. General Discoverable Mode

一般可发现模式,跟“有限可发现模式”相比,它可以一直发出广播报文。

在这种模式下,其发出的广播包中的AD Type要设置这个位为1:

LE General Discoverable Mode

4. Limited Discovery Procedure

5. General Discovery Procedure

五、Connection modes and procedures:

1. Non-Connectable Mode

不可连接模式

2. Directed Connectable Mode

定向连接模式,

如果希望快速连接中央设备,外围设备可以使用该模式。

在该模式下,它发出ADV_DIRECT_ADV广播报文,直接发给指定的中央设备。

所以,该外围设备应该曾经与该中央设备建立过连接。

ADV_DIRECT_ADV广播报文的发送频率很快,该模式最多持续1.28S,之后控制器自动停止广播。

3. Undirected Connectable Mode

无向连接模式。

如果一个外围设备无需快速建立连接,或者打算尽可能地省电,则可以使用该模式。

它发出ADV_IND广播报文。

4. Auto Connection Establishment Procedure

自动连接建立规程。

中央设备使用该规程来设置控制器,从而向一个或多个外围设备,自动地建立连接。Host需要事先把想要连接的设备,写入“白名单”中。

它有个缺点:对所有的设备,都只能使用一套基本连接参数。

5. General Connection Establishment Procedure

一般连接建立规程。

这是我们常用的规程,先扫描出设备,选中某一个,然后使用“直接连接建立规程”去连接它。

6. Selective Connection Establishment Procedure

选择性连接建立规程。

Host先把想连接的设备放入Controller的“白名单”。正在广播的设备,只有在白名单上的才会被提交给Host。

Host决定是否连接该设备,并使用不同的参数去连接它。相比于“自动连接建立规程”,“选择性连接建立规程”可以使用不同的参数连接每一个设备。

7. Direct Connection Establishment Procedure

定向连接建立规程,直接去连接指定的设备。

8. Connection Parameter Update Procedure

连接参数更新规程。

参考 VOL6, Part B, 5.1 LINK LAYER CONTROL PROCEDURES

9. Terminate Connection Procedure

终止连接规程。

中央设备或外围设备都可以执行该规程,通过LL层向对方发出LL_TERMINATE_IND PDU就可以。

六、Security modes and procedures:

留待SM层再讲。

七、GAP服务:

每一个中央设备或外围设备中,都有一个GAP Service。

GAP Service中,至少有这2项Characteristic:

① Device Name,设备名字

② Appearance,中央设备根据它来显示一个图标、字符串等,用来形象地描述设备的功能。

本文来自互联网用户投稿,该文观点仅代表作者本人,不代表本站立场。本站仅提供信息存储空间服务,不拥有所有权,不承担相关法律责任。如若转载,请注明出处:http://www.mzph.cn/news/741033.shtml

如若内容造成侵权/违法违规/事实不符,请联系多彩编程网进行投诉反馈email:809451989@qq.com,一经查实,立即删除!

相关文章

边缘智能融合区块链:研究现状、应用及挑战

源自:信息与控制 作者:任晓旭 仇超 邓辉 戴子明 刘泽军 王晓飞 “人工智能技术与咨询” 发布 摘 要 边缘智能集网络、计算、存储和智能于一体,将智能推向网络边缘,为互联时代的低延迟关键计算开辟了道路。为进一步满足…

算法学习系列(四十):贡献法

目录 引言概念一、孤独的照片二、牛的基因学三、字串分值 引言 关于这个贡献法考的不是很多,主要题型是出现在需要枚举每一个组合这类题,出现的次数较多。没有固定的模板,就是一种思想,跟贪心一样,每个题都是不一样的…

Thymeleaf 基本使用

01、Thymeleaf 官网地址:Thymeleafhttps://www.thymeleaf.org/ 简介 Thymeleaf是一种服务器端Java模板引擎,用于将数据渲染为HTML、XML、JavaScript等格式,并在Web浏览器中呈现给用户。 具体来说,Thymeleaf充当着视图层的角色&…

C语言 ——注释

1.1 单行注释 - 语法:// 待注释的内容 - 位置:可放在代码后,称之为行尾注释; 也可放代码上一行,称作行上注释。 c // 这是单行注释文字 1.2 多行注释 - 语法:/* 待注释的内容 */ - 注意:多⾏…

考研C语言复习进阶(1)

目录 1. 数据类型介绍 1.1 类型的基本归类: 2. 整形在内存中的存储 2.1 原码、反码、补码 2.2 大小端介绍 3. 浮点型在内存中的存储 ​编辑 1. 数据类型介绍 前面我们已经学习了基本的内置类型: char //字符数据类型 short //短整型 int /…

前端之用HTML弄一个古诗词

将进酒 <!DOCTYPE html> <html lang"en"> <head><meta charset"UTF-8"><title>将进酒</title><h1><big>将进酒</big> 君不见黄河之水天上来</h1><table><tr><td ><img…

借助ChatGPT提高编程效率指南

PS: ChatGPT无限次数&#xff0c;无需魔法&#xff0c;登录即可使用,网页打开下面 一、借助ChatGPT提高编程效率指南 随着计算机技术的飞速发展&#xff0c;编程已经成为了现代社会中一个非常重要的技能。对于许多人来说&#xff0c;编程不仅是一项工作技能&#xff0c;而且是…

操作系统系列学习——操作系统之“树”

文章目录 前言操作系统之“树” 前言 一个本硕双非的小菜鸡&#xff0c;备战24年秋招&#xff0c;计划学习操作系统并完成6.0S81&#xff0c;加油&#xff01; 本文总结自B站【哈工大】操作系统 李治军&#xff08;全32讲&#xff09; 老师课程讲的非常好&#xff0c;感谢 【哈…

sqllab第五关通关笔记

知识点&#xff1a; 报错注入函数语法&#xff08;详见第二关笔记&#xff09;报错注入打印位数最多32位对于大于32位的数据最好使用截取函数进行控制&#xff1b;以保证输出完整mysql表中的重点数据库 information_schema &#xff08;mysql 5.0以上&#xff09; schemata …

每日一题 — 长度最小的子数组

LCR 008. 长度最小的子数组 - 力扣&#xff08;LeetCode&#xff09; 思路&#xff1a; 首先在暴力枚举的方法下&#xff0c;我们可以进行优化&#xff0c;让right不用从头开始&#xff0c;只需让left移动&#xff0c;进行判断。然后就是变成了同向双指针&#xff0c;也就是滑…

责任链模式-C#实现

责任链模式指的是——某个请求需要多个对象进行处理&#xff0c;从而避免请求的发送者和接收之间的耦合关系。 将这些对象连成一条链子&#xff0c;并沿着这条链子传递该请求&#xff0c;直到有对象处理它为止。 主要涉及两个角色&#xff1a; 抽象处理者角色&#xff08;Hand…

【测试开发学习历程】Linux用户管理+文件权限管理

目录 一、用户管理 &#xff08;一&#xff09;用户和用户组的基本概念 1.概念 2.设置原因 3.用户与用户组的关系 4.用户类型 &#xff08;二&#xff09;用户的创建、修改属性和删除用户 1.用户信息文件 2.创建用户 3.修改用户密码 4.修改用户信息 5.用户查询 6.…

MAMP Pro 站点404 Nginx 配置

MAMP Pro 站点配置 if (!-e $request_filename) {rewrite ^(.*)$ /index.php?s/$1 last;break; }

第十四届蓝桥杯C++B组编程题题目以及题解

a.冶炼金属&#xff08;二分&#xff09; 思路&#xff1a; 设任意一条冶炼记录投入金属数量为a,产出金属为b. 对于每一条冶炼记录我们都可以得到 一个转换率V的范围&#xff1a; b<a/v<b1即a/b< v <a/(b1) 为什么是b1呢&#xff1f;因为既然能产出b个金属&#xf…

实现的一个网页版的简易表白墙

实现的一个网页版的表白墙 实现效果 代码截图 相关代码 <!DOCTYPE html> <html lang"en"> <head><meta charset"UTF-8"><meta name"viewport" content"widthdevice-width, initial-scale1.0"><tit…

【Java】初级篇:基本语法

一、变量与运算符 标识符命名规则 由26个英文字母大小写、0-9、_或$组成&#xff1b;不可以以数字开头&#xff1b;不能单用关键字和保留字&#xff1b;区分大小写&#xff1b;不包含空格。 【包名&#xff1a;所有字母小写|类名、接口名&#xff1a;多单词组成时所有字母首字…

1.6数组

一.序言 数组是一组类型相同类型元素的集合&#xff0c;数组的定长的&#xff08;数组的长度一旦被定义&#xff0c;长度不可改变&#xff09;。 数组在内存当中是一块连续的空间&#xff0c;可以保存相同类型的多个元素。 二.一维数组 2.1.数组的创建 int arr1[10]; …

Android的UI渲染机制(一)

应用程序与Surface的关系&#xff0c;从应用程序的Activity开始&#xff0c;一路追踪到ViewRoot、WindowManager Service。 SurfaceFlinger则主要负责视图的显示&#xff0c;其管理多个surface进行图像合成。WindowManager Service由System_Server进程启动&#xff0c;SurfaceF…

IDEA 设置信息及插件同步配置

所需插件&#xff1a; 第一步&#xff1a;打开登录界面&#xff0c;进行登录 第二步&#xff1a;再次点击

Go——运算符,变量和常量,基本类型

一.运算符 Go语言内置的运算符有&#xff1a; 算术运算符 关系运算符 逻辑运算符 位运算符 赋值运算符 1.1 算术运算符 注意&#xff1a;(自增)和--(自减)在go语言中是单独的语句&#xff0c;并不是运算符。 1.2 关系运算符 1.3 逻辑运算符 1.4 位运算符 位运算符对整数在内存…