BLE Mesh蓝牙组网技术详细解析之Access Layer访问层(六)

目录

一、什么是BLE Mesh Access Layer访问层?

二、Access payload

2.1 Opcode

三、Access layer behavior

3.1 Access layer发送消息的流程

3.2 Access layer接收消息的流程

3.3 Unacknowledged and acknowledged messages

3.3.1 Unacknowledged message

3.3.2 Acknowledged message

3.4 Example message sequence charts

3.4.1 Acknowledged Get

3.4.2 Acknowledged Set

3.4.3 Unacknowledged Set

3.4.4 Acknowledged set with periodic publishing

四、资料获取


一、什么是BLE Mesh Access Layer访问层?

BLE Mesh Access Layer是蓝牙Mesh协议栈的一部分,它主要负责以下几个方面的功能

  • 定义应用数据的格式,例如Opcode和参数字段。
  • 定义并控制在上层传输层中执行的应用数据的加密和解密,使用AppKey或DeviceKey作为密钥。
  • 在将数据上传到模型层之前,对来自上层传输层的数据进行验证,判断其是否适用于该网络和应用,例如检查地址和AppKey是否匹配。
  • 在将数据下发到上层传输层之前,根据模型层的指令,填充源地址、目的地址、TTL等字段,以及设置重传参数。

二、Access payload

Field Name

Size (octets)

Notes

Opcode

1, 2, or 3

Operation Code

Parameters

0 to 379

Application Parameters

  • Opcode:1字节、2字节或3字节的操作码,用于标识消息的类型和含义。
  • Parameters:一个可变长度的参数字段,用于携带消息的具体内容。参数字段的长度由Opcode和上层传输层的PDU的长度共同决定,最大为379字节,取决于Opcode的长度

一个access payload最多可以发送32个片段,每个片段12字节。这意味着最大值 包括TransMIC在内的字节数是384

对于4字节的TransMIC,access payload最大大小是380字节,因此对于单个字节的操作码,参数字段最多可以达到379字节。对于2字节的操作码,参数字段最多可以有378个字节。对于一个3字节的操作码,parameters字段最多可以有377个字节。

传输层可以将消息分割成多段PDU,以便在网络层上传输。下表显示了根据包的数量和TransMIC的大小而定的最大有用的应用包大小。

Number of Packets

Maximum useful access payload size (octets)

32 bit TransMIC

64 bit TransMIC

1

11 (unsegmented)

n/a

1

8 (segmented)

4 (segmented)

2

20

16

3

32

28

n

(n×12)-4

(n×12)-8

32

380

376

2.1 Opcode

  • 1字节操作码:由SIG定义,用于标准的模型消息,例如Generic OnOff Set,Generic Level Get等。1字节操作码的第一位为0,剩下的7位表示具体的操作码值。
  • 2字节操作码:由SIG定义,用于扩展的模型消息,例如Scene Store,Scene Delete等。2字节操作码的第一位为1,第二位为0,剩下的14位表示具体的操作码值。
  • 3字节操作码:由供应商定义,用于自定义的模型消息,例如Vendor Model Status,Vendor Model Indication等。3字节操作码的第一位为1,第二位为1。其中的2个字节被指定为厂商ID(CID),该部分在表中以“z”表示。在整个mesh网络中,每个厂商ID最多支持64个厂商操作码。用户可用的只有6位(xxxxxx),因此总共是64个操作码。

Opcode Format

Notes

0xxxxxxx (excluding 01111111)

1-octet Opcodes

01111111

Reserved for Future Use

10xxxxxx xxxxxxxx

2-octet Opcodes

11xxxxxx zzzzzzzz zzzzzzzz

3-octet Opcodes

三、Access layer behavior

3.1 Access layer发送消息的流程

  • 首先,访问层接收到来自模型层的消息,消息包含操作码(Opcode)和有效载荷(Payload)。操作码是用于标识消息的类型和含义的一个字节或多个字节的值,有效载荷是消息的主要内容,包含了模型的状态值、参数、属性等信息。
  • 然后,访问层根据下发来的模型ID找到对应的存储信息,包括源地址(SRC)、目的地址(DST)、应用密钥(AppKey)等。源地址是该模型对应的元素的单播地址,目的地址是该模型设置的发布地址,应用密钥是该模型绑定的用于加密和解密的密钥。
  • 接着,访问层将消息和存储信息一起传递给上层传输层,上层传输层会根据应用密钥对消息进行加密和认证,生成一个传输层数据单元(Upper Transport PDU),并为每个消息分配一个序列号(SEQ)用于防护中继/重放攻击。
  • 然后,上层传输层将传输层数据单元和其他信息传递给下层传输层,下层传输层会根据消息的长度决定是否需要对消息进行分段,如果需要分段,会生成多个分段的传输层数据单元(Segmented Upper Transport PDU),并为每个分段分配一个分段索引(SEG)用于重组消息。
  • 接着,下层传输层将分段的传输层数据单元和其他信息传递给网络层,网络层会根据网络密钥(NetKey)对分段的传输层数据单元进行加密和混淆,生成一个网络层数据单元(Network PDU),并为每个网络层数据单元分配一个网络标识符(IVI)用于识别网络。
  • 然后,网络层将网络层数据单元和其他信息传递给承载层,承载层会根据承载类型(Advertising Bearer或GATT Bearer)对网络层数据单元进行封装,生成一个承载层数据单元(Bearer PDU),并通过底层的BLE协议栈将承载层数据单元发送出去。
  • 最后,承载层会根据消息的类型(Acknowledged Message或Unacknowledged Message)决定是否需要对消息进行重传,如果需要重传,会根据重传参数(重传次数、重传间隔等)进行重传,直到收到应答消息或达到重传次数上限为止。
/*源自开源协议栈NimBLE*/
static int model_send(struct bt_mesh_model *model,struct bt_mesh_net_tx *tx, bool implicit_bind,struct os_mbuf *msg,const struct bt_mesh_send_cb *cb, void *cb_data)
{BT_DBG("net_idx 0x%04x app_idx 0x%04x dst 0x%04x", tx->ctx->net_idx,tx->ctx->app_idx, tx->ctx->addr);BT_DBG("len %u: %s", msg->om_len, bt_hex(msg->om_data, msg->om_len));if (!bt_mesh_is_provisioned()) {BT_ERR("Local node is not yet provisioned");return -EAGAIN;}if (net_buf_simple_tailroom(msg) < 4) {BT_ERR("Not enough tailroom for TransMIC");return -EINVAL;}if (msg->om_len > BT_MESH_TX_SDU_MAX - 4) {BT_ERR("Too big message");return -EMSGSIZE;}if (!implicit_bind && !model_has_key(model, tx->ctx->app_idx)) {BT_ERR("Model not bound to AppKey 0x%04x", tx->ctx->app_idx);return -EINVAL;}return bt_mesh_trans_send(tx, msg, cb, cb_data);
}int bt_mesh_model_send(struct bt_mesh_model *model,struct bt_mesh_msg_ctx *ctx,struct os_mbuf *msg,const struct bt_mesh_send_cb *cb, void *cb_data)
{struct bt_mesh_net_tx tx = {.sub = bt_mesh_subnet_get(ctx->net_idx),.ctx = ctx,.src = bt_mesh_model_elem(model)->addr,.xmit = bt_mesh_net_transmit_get(),.friend_cred = 0,};return model_send(model, &tx, false, msg, cb, cb_data);
}

3.2 Access layer接收消息的流程

  • 首先,访问层从承载层接收到来自底层低功耗蓝牙协议栈的消息,消息包含操作码(Opcode)和有效载荷(Payload)。操作码是用于标识消息的类型和含义的一个字节或多个字节的值,有效载荷是消息的主要内容,包含了模型的状态值、参数、属性等信息。
  • 然后,访问层根据消息中的网络密钥索引(NetKeyIndex)和应用密钥索引(AppKeyIndex)找到对应的网络密钥(NetKey)和应用密钥(AppKey),并将消息传递给上层传输层。上层传输层会根据网络密钥和应用密钥对消息进行解密和认证,还原出原始的操作码和有效载荷。
  • 接着,访问层根据消息的目的地址(DST)字段,找到当前节点中订阅了该地址或者元素地址为该地址的所有模型,再判断该消息与该模型是否绑定了同一个应用密钥,满足了要求再上报至模型层,模型再进行操作码和有效载荷的检查。
/*BLE Mesh访问层接收数据子函数*/
/*源自开源协议栈NimBLE*/
void bt_mesh_model_recv(struct bt_mesh_net_rx *rx, struct os_mbuf *buf)
{struct bt_mesh_model *models, *model;const struct bt_mesh_model_op *op;u32_t opcode;u8_t count;int i;BT_DBG("app_idx 0x%04x src 0x%04x dst 0x%04x", rx->ctx.app_idx,rx->ctx.addr, rx->ctx.recv_dst);BT_DBG("len %u: %s", buf->om_len, bt_hex(buf->om_data, buf->om_len));if (get_opcode(buf, &opcode) < 0) {BT_WARN("Unable to decode OpCode");return;}BT_DBG("OpCode 0x%08x", (unsigned) opcode);for (i = 0; i < dev_comp->elem_count; i++) {struct bt_mesh_elem *elem = &dev_comp->elem[i];struct net_buf_simple_state state;/* SIG models cannot contain 3-byte (vendor) OpCodes, and* vendor models cannot contain SIG (1- or 2-byte) OpCodes, so* we only need to do the lookup in one of the model lists.*/if (BT_MESH_MODEL_OP_LEN(opcode) < 3) {models = elem->models;count = elem->model_count;} else {models = elem->vnd_models;count = elem->vnd_model_count;}op = find_op(models, count, opcode, &model);if (!op) {BT_DBG("No OpCode 0x%08x for elem %d", opcode, i);continue;}if (!model_has_key(model, rx->ctx.app_idx)) {continue;}if (!model_has_dst(model, rx->ctx.recv_dst)) {continue;}if (buf->om_len < op->min_len) {BT_ERR("Too short message for OpCode 0x%08x", opcode);continue;}/* The callback will likely parse the buffer, so* store the parsing state in case multiple models* receive the message.*/net_buf_simple_save(buf, &state);op->func(model, &rx->ctx, buf);net_buf_simple_restore(buf, &state);}
}

3.3 Unacknowledged and acknowledged messages

  • 消息的类型:消息可以分为需要应答的消息(Acknowledged Message)和不需要应答的消息(Unacknowledged Message)。需要应答的消息要求接收端回复一个状态消息作为应答,不需要应答的消息则不需要回复。
  • 消息的目标地址:消息可以发送到单播地址(Unicast Address)、组播地址(Group Address)或虚拟地址(Virtual Address)。目标地址决定了消息的发布和订阅方式,以及消息的中继和重传机制。
  • 消息的操作码(Opcode):操作码是用于标识消息的类型和含义的一个字节或多个字节的值。操作码的长度和值由消息的第一位和第二位决定,操作码的值可以是预定义的或者厂商自定义的。
  • 消息的有效载荷(Payload):有效载荷是消息的主要内容,包含了模型的状态值、参数、属性等信息。有效载荷的长度和格式由操作码和模型定义决定。

3.3.1 Unacknowledged message

unAcknowledged Message是一种不需要接收端回复应答的消息。它的定义如下

  • unAcknowledged Message的操作码(Opcode)的第一位(bit 7)必须为0,表示操作码的长度为一个字节。
  • unAcknowledged Message的有效载荷(Payload)的长度和格式由操作码和模型定义决定,通常包含了目标状态(Target State)或查询参数(Query Parameters)等信息。
  • unAcknowledged Message的发送端(Client Model)会在发送消息后不等待接收端(Server Model)的应答消息(Status Message),而是直接结束消息发送过程。

3.3.2 Acknowledged message

Acknowledged Message是一种需要接收端回复一个状态消息作为应答的消息。它的定义如下

  • Acknowledged Message的操作码(Opcode)的第一位(bit 7)必须为0,表示操作码的长度为一个字节。
  • Acknowledged Message的有效载荷(Payload)的长度和格式由操作码和模型定义决定,通常包含了目标状态(Target State)或查询参数(Query Parameters)等信息。
  • Acknowledged Message的发送端(Client Model)会在发送消息后等待一段时间(Acknowledged Message Timeout),如果在这段时间内没有收到接收端(Server Model)的应答消息(Status Message),则会重发消息,直到收到应答消息或达到重发次数上限(Acknowledged Message Retransmissions)为止。

3.4 Example message sequence charts

3.4.1 Acknowledged Get

Acknowledged Get是一种用于从服务器端请求状态信息的消息类型。它属于Acknowledged MSG的一种,也就是说,当服务器端收到这个消息后,需要回复一个对应的Status消息,告诉客户端当前的状态值。这样可以保证客户端和服务器端的状态同步,也可以避免消息丢失或重复的问题。

例如,如果客户端想要知道一个灯的亮度,它可以发送一个Generic Level Get消息,这是一种Acknowledged Get消息,它的Opcode是0x8205。服务器端收到这个消息后,会回复一个Generic Level Status消息,它的Opcode是0x8206,它的Payload包含了当前的亮度值。

 

3.4.2 Acknowledged Set

Acknowledged Set是一种用于向服务器端发送状态设置请求的消息类型。它也属于Acknowledged MSG的一种,也就是说,当服务器端收到这个消息后,需要回复一个对应的Status消息,告诉客户端状态是否设置成功。这样可以保证客户端和服务器端的状态同步,也可以避免消息丢失或重复的问题。

例如,如果客户端想要设置一个灯的亮度,它可以发送一个Generic Level Set消息,这是一种Acknowledged Set消息,它的Opcode是0x8207。它的Payload包含了要设置的亮度值和一个可选的Transition Time和Delay参数,用于控制灯的渐变效果。服务器端收到这个消息后,会回复一个Generic Level Status消息,它的Opcode是0x8206,它的Payload包含了当前的亮度值。

 

3.4.3 Unacknowledged Set

Unacknowledged Set是一种用于向服务器端发送状态设置请求的消息类型。它不属于Acknowledged MSG,也就是说,当服务器端收到这个消息后,不需要回复一个对应的Status消息,也不会把当前状态的改变后的结果通过Publish地址向四周广播。这样可以减少网络层的负载,提高传输效率,但也可能导致客户端和服务器端的状态不同步,或者消息丢失或重复的问题。

例如,如果客户端想要设置一个灯的亮度,它可以发送一个Generic Level Set Unacknowledged消息,这是一种Unacknowledged Set消息,它的Opcode是0x8208。它的Payload包含了要设置的亮度值和一个可选的Transition Time和Delay参数,用于控制灯的渐变效果。服务器端收到这个消息后,不会回复任何消息,也不会广播当前的亮度值。

 

3.4.4 Acknowledged set with periodic publishing

Acknowledged set with periodic publishing是一种用于向服务器端发送状态设置请求并启用周期性状态发布的消息类型。它属于Acknowledged MSG的一种,也就是说,当服务器端收到这个消息后,需要回复一个对应的Status消息,告诉客户端状态是否设置成功,并且按照设定的时间间隔和发布地址,定期广播当前的状态值。这样可以保证客户端和服务器端的状态同步,也可以让其他订阅了发布地址的节点获取服务器端的状态信息。

例如,如果客户端想要设置一个灯的亮度,并且让灯每隔5秒钟发布一次当前的亮度值,它可以发送一个Generic Level Set消息,这是一种Acknowledged Set消息,它的Opcode是0x8207。它的Payload包含了要设置的亮度值和一个可选的Transition Time和Delay参数,用于控制灯的渐变效果。它还需要配置灯的发布地址和发布周期,比如发布地址为0xC000(所有节点的组播地址),发布周期为5秒。服务器端收到这个消息后,会回复一个Generic Level Status消息,它的Opcode是0x8206,它的Payload包含了当前的亮度值。同时,服务器端会每隔5秒钟向0xC000地址发送一个Generic Level Status消息,让其他节点知道当前的亮度值

 

四、资料获取

通过点击以下链接,您可以获取BLE Mesh模块原理图、源代码以及开发资料。链接地址将为您提供详细的文件资料,以供您进行参考和使用。

如果您在使用过程中遇到任何问题或疑虑,欢迎加我QQ ,一起探讨技术问题,我的QQ号是986571840,加的时候请注明CSDN。

BLE Mesh蓝牙组网模块 - 硬创社 (jlc.com)icon-default.png?t=N7T8https://x.jlc.com/platform/detail/001d23cba7b64b0d9df5b9b69720fadb

感谢各位用户点赞、分享、在看,这些行为让知识得以更加广泛地传播,从而让更多人受益。

请在转载作品时注明出处,严禁抄袭行为。
 

 

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

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

相关文章

php安装扩展event 提示 No package ‘openssl‘ found 解决方法

在使用pecl编译安装最新版event模块的时候提示 No package openssl found , 可是本机是安装了openssl的, 编译时找不到, 大概率就是环境配置的问题了, 增加 OPENSSL_CFLAGS OPENSSL_LIBS环境变量即可解决. 异常提示信息: checking for openssl > 1.0.2... no configure: …

在pycharm中jupyter连接上了以后显示无此库,但是确实已经安装好了某个库,使用python可以跑,但是使用ipython就跑不了

今天遇到一个事情&#xff0c;就是用pycharm的jupyter时&#xff0c;连接不上&#xff0c;后来手动连接上了以后&#xff0c;发现环境好像不对。 一般来说&#xff0c;这里会是python3&#xff0c;所以里面的环境也是普通python的环境&#xff0c;并没有我下载的库&#xff0c;…

Python学习笔记之(一)搭建Python 环境

搭建Python 环境 1. 使用工具准备1.1 Python 安装1.1.1 下载Python 安装包1.1.2 安装Python 1.2 VScode 安装1.2.1 下载VScode安装包1.2.2 给VScode安装Python 扩展 2. 第一次编写Python 程序 本篇文章以Windows 系统为例。 1. 使用工具准备 1.1 Python 安装 1.1.1 下载Pytho…

虹科方案|从困境到突破:TigoLeap方案引领数据采集与优化

导读&#xff1a;在数字化工厂和智能制造的时代&#xff0c;数据已经成为优化机器和流程的关键。然而&#xff0c;如何高效地收集和处理这些数据&#xff0c;特别是在开发、部署和生产阶段&#xff0c;仍是企业面临的一大挑战。虹科TigoLeap平台&#xff0c;作为一款引领行业变…

k8s快速搭建

VMware16Pro虚拟机安装教程VMware16.1.2安装及各版本密钥CentOS7.4的安装包:提取码&#xff1a;lp6qVMware搭建Centos7虚拟机教程 搭建完一个镜像 关机 拍摄一个快照,克隆两个作为子节点 0. 环境准备 在开始之前&#xff0c;部署Kubernetes集群机器需要满足以下几个条件&#…

每周一算法:倍增法查找位置

倍增法 倍增法&#xff08;Binary Lifting&#xff09;&#xff0c;顾名思义&#xff0c;就是利用“以翻倍的速度增长”的思想来解决问题的一类算法。 下面介绍如何使用倍增法在有序的序列中查找满足条件的位置。 题目描述 给定一个单调不降的序列&#xff0c;以及 m m m个…

78 Python开发-多线程FuzzWaf异或免杀爆破

这里写目录标题 本课知识点:学习目的:演示案例:Python开发-简单多线程技术实现脚本Python开发-利用FTP模块实现协议爆破脚本Python开发-配合Fuzz实现免杀异或Shell脚本 涉及资源: 本课知识点: 协议模块使用&#xff0c;Request爬虫技术&#xff0c;简易多线程技术&#xff0c;…

基于EPICS modbus模块的单通道电压监测项目

先介绍在本项目中使用到的硬件&#xff1a; 1&#xff09;开发板&#xff1a;为香橙派Zero2&#xff0c;安装系统如下&#xff1a; Distributor ID: Ubuntu Description: Ubuntu 22.04.2 LTS Release: 22.04 Codename: jammy 2&#xff09; USB转485模块&…

Apache的配置与应用

目录 1、Apache简介 2、Apache连接保持 3、Apache的访问控制 3.1、客户机地址限制 3.2、用户授权限制 &#xff08;1&#xff09;创建用户认证数据文件 &#xff08;2&#xff09;添加用户授权配置 &#xff08;3&#xff09;验证用户访问授权 4、Apache日志分割 4…

贝莱德等巨头将通过最终考验!ETF获批是涨是跌?交易数据背后的博弈信号已经显现!

还记得摩根大通&#xff08;(J.P.Morgan&#xff09;首席执行长杰米-戴蒙&#xff08;Jamie Dimon&#xff09;说「如果他是政府&#xff0c;他就会关闭比特币」&#xff0c;加密货币的唯一「真正用途是犯罪、贩毒、洗钱和避税」吗&#xff1f; 然而&#xff0c;最新消息显示&a…

后缀自动机超详细

后缀自动机 1.关于 e n d p o s endpos endpos 理解含义 假设字符串s是字符串S的一个子串&#xff0c;则 e n d p o s ( s ) endpos(s) endpos(s)表示s在S中的所有结束位置&#xff0c;如在字符串 a b c a b c a b abcabcab abcabcab中&#xff0c; e n d p o s ( a b ) 2 …

域名授权验证系统PHP源码,盗版追踪、双重授权和在线加密功能,附带安装教程

源码介绍 PHP域名授权验证系统是一个功能强大的系统&#xff0c;提供了多项功能来保护你的域名和软件的合法性。它包括盗版追踪、域名IP双重授权、在线加密等功能&#xff0c;同时还提供了PHP授权验证更新系统的完整版&#xff0c;方便你进行一键更新和生成自助授权。 盗版追…