目录

蓝牙mesh协议中有不少数据需要存储dataflash,以记录网络中的数据。一些数据只需要配网时保存进dataflash,比如说本节点的网络地址、各类密钥等;另一些数据需要在运行中动态更新,比如说消息序列号(seq num)等。

在芯片作为发送方时,在新增发送消息数达到seq保存步长时会保存相关数据,作用是在断电后重新上电时会将根据dataflash中的消息序列号,再加上一个保存步长来恢复为当前消息序列号,保证此值大于此节点先前发送的消息的序列号,以免被消息接收方判断为过往消息。默认seq保存步长为60(在app_mesh_config.h中由宏CONFIG_MESH_SEQ_STORE_RATE_DEF设置)。作为发送方,每次保存12个字节,一块4K的扇区可以保存约341次,但考虑到其他数据的开销,实际要比341小一些。

在芯片作为接收方时,设置宏CONFIG_MESH_ALLOW_RPL_CYCLE为FALSE时,在接收到某一节点A的消息数达到rpl保存步长时需要保存相关数据,作用是在断电重新上电时恢复发送地址、序列号等数值,以帮助判断发送方的消息是否过期。默认rpl保存步长为60(在app_mesh_config.h中由宏CONFIG_MESH_RPL_STORE_RATE_DEF设置)。作为接收方,针对节点A每次保存16个字节,需要通信的节点数量越多,占用flash大小也越大,flash保存频率也越高,也可按上述方式估算扇区保存次数。若设置宏CONFIG_MESH_ALLOW_RPL_CYCLE为TRUE,则不再保存节点A的网络信息到falsh中,只在ram中保留,在断电并上电ram重置后,会有遭到重放攻击的风险。

鉴于dataflash有其擦写寿命,协议栈在存满n-1块扇区后,会收集整理数据,整合到另一块扇区。比如说宏配置了使用8块扇区,已存满7块扇区,协议栈会整理7块扇区中的数据,整合到第8块dataflash中。整理dataflash过程中涉及到字符串比对、拷贝等操作,故代码运行的时间越长,dataflash中保存的数据量以及数据间差异越大,整理dataflash用到的时间就越多。

最新EVT中,在app_mesh_config.h中有宏可进行配置,如下图,默认使用前3*4K的dataflash空间。

如果用户需要更改首地址,在dataflash头部存放用户数据,注意首地址要与NVS扇区存储大小对齐,比如NVS扇区存储大小设为2K,NVS存储首地址可为2K、4K、6K…。

若使用到了BLKE且配对绑定保存置为true,那么配对绑定的信息保存在dataflash尾部,具体位置见config.h中的BLE_SNV_ADDR。

需要注意的是在mesh代码中使用看门狗。582/573看门狗溢出计时最长可达约557ms,但整理一块4K大小的扇区,耗时最长可达1s,而整理dataflash又在协议栈中完成,故在使用到看门狗时,主循环中可能来不及喂狗。解决方法有二,一是减小整理dataflash所需的时间,适合需要保存的数据较少的情况,可以将保存的扇区数量以及扇区大小减小,最小以初始化不报错为准;二是拉长看门狗复位的超时时长,可以通过在看门狗中断中计数的方式,比如说溢出计数到10才复位,这样可以有5.5s的时长留给dataflash整理,延长看门狗复位的时间。

看门狗的使用可以参考博客:CH573 CH582 CH579 看门狗使用 - debugdabiaoge - 博客园 (cnblogs.com)

小贴士:①seq保存步长与rpl保存步长不是必须一致,可以按需调整。

②保存dataflash时没有用户层提示,保存dataflash的时间点需要根据发包频率与步长设置来估算,在跑一些实时性较高的代码时需要评估一下延时。

③整理dataflash的过程中,涉及到操作flash的库,会关闭总中断,可能不会及时触发包括看门狗在内的中断,但标志会保存,操作完dataflash后会触发中断。

④整理dataflash的过程中若突然断电打断了dataflash的整理,不会对上电重启时恢复的配网信息造成影响,因为在整理好dataflash数据前会保留旧的扇区,擦写好新的扇区才会擦除旧扇区。

蓝牙mesh组网实践(dataflash的占用与管理)的更多相关文章

  1. SIG蓝牙mesh笔记2_mesh组成

    目录 SIG 蓝牙 mesh 组成 mesh网络概述 网络和子网 设备和节点 devices & nodes 入网 mesh中的几个概念 智能插座例子 SIG 蓝牙 mesh 组成 mesh网 ...

  2. [蓝牙前沿应用] 照明即平台 —— 通过蓝牙增强服务提高照明投资回报率(蓝牙MESH、定位AoA、AoD)

      1.照明即平台(LAAP) 随着照明设施向LED转型,他们也在利用类似于蓝牙MESH的技术,创建一个可连接的照明平台,作为他们建筑的中枢神经系统.这些系统除了提供先进的照明控制,还建立了一个增强版 ...

  3. 常见无线组网分析(NB-IOT组网和Mesh组网)

      NB-IOT LoRa Zigbee WIFI 蓝牙 组网方式 基于现有蜂窝组网 基于LoRa网关 基于Zigbee网关 基于无线路由器 居于蓝牙Mesh的网关 网络部署方式 节点 节点 + 网关 ...

  4. 蓝牙mesh介绍

    了解一下关于蓝牙Mesh的知识. 蓝牙mesh网络使用,并且依赖于低功耗蓝牙(BLE).低功耗蓝牙技术是蓝牙mesh使用的无线通信协议栈. 蓝牙BR / EDR能够实现一台设备到另一台设备的连接和通信 ...

  5. 解密蓝牙mesh系列

    解密蓝牙mesh系列 https://mp.weixin.qq.com/s/KdVhkgcmHIboA0xPFqFCgQ 1.NRF52832 & NRF52840 BLE mesh 协议栈 ...

  6. 蓝牙mesh网络技术的亮点

    蓝牙mesh网络技术的亮点 The highlights of Bluetooth mesh networking technology 导言 蓝牙是当今最主要的低功耗无线技术之一,对无线设备用户和开 ...

  7. 关于蓝牙Mesh您必须知道的七件事

    蓝牙技术联盟于7月19日正式宣布,蓝牙(Bluetooth)技术开始全面支持Mesh网状网络.全新的Mesh功能提供设备间多对多传输,并特别提高构建大范围网络覆盖的通信能力,适用于楼宇自动化.无线传感 ...

  8. 蓝牙5.0芯片NRF52810和NRF52832可进行mesh组网

    提供智能化mesh照明解决方案,在现有传统灯具的基础上,插入NRF52832/52810的照明Mesh模块,可以迅速升级现有的传统灯具,配合手机APP和服务器系统,使每一盏灯成为物联网的一个智能节点, ...

  9. SIG蓝牙mesh笔记3_网络结构

    目录 3. Mesh Networking 3.1 Bearers 承载层 3.2 Network Layer 网络层 3.2.3 Address validity 地址有效性 3.2.4 Netwo ...

  10. SIG蓝牙mesh笔记5_Provisionging

    目录 Bluetooth Mesh Provisioning Provisioning bearer layer Generic Provisioning PDU Bluetooth Mesh Pro ...

随机推荐

  1. java入门与进阶-P1.3+P1.4

    准备一个java编程软件 eclipse官网: Enabling Open Innovation & Collaboration | The Eclipse Foundation 他是一个免费 ...

  2. 你想成为.Net 7的技术高手吗?来这里看看

    前言: 你是否时常觉得,整天搞些Curd和增删改查.这些毫无意义的东西,完全是浪费生命.想要进阶,成为高手.却苦于找不到方法,没有一套系统性的东西. 有鉴于此,新建了一个群,方便大家一起交流和分享一些 ...

  3. Quartz.Net源码Example之Quartz.Examples

    Quartz.Examples 反射-Example批量执行 ​ 实现思路:定义一个统一的接口,需要实现的类全部实现该接口:通过反射获取实现该接口的实例并触发其中的方法. 定义统一的接口 // 所有要 ...

  4. springcloud11 spring cloud config

    1.spring cloud config是什么 官网:https://cloud.spring.io/spring-cloud-static/spring-cloud-config/2.2.1.RE ...

  5. P23_列表渲染

    列表渲染 wx:for 通过 wx:for 可以根据指定的数组,循环渲染重复的组件结构,语法示例如下: 默认情况下,当前循环项的索引用 index 表示:当前循环项用 item 表示. 手动指定索引和 ...

  6. 【KAWAKO】Pydub-某些函数的使用方法

    目录 EQ 源码 其中使用的_eq函数源码 测试代码 EQ 源码 seg:AudioSegment音频 focus_freq:需要调整的中心频率 bandwidth:调整的频率范围 channel_m ...

  7. JZOJ 5372. 【NOIP2017提高A组模拟9.17】猫

    题目大意 对于 \(m = [1,\lfloor \frac n 2 \rfloor]\) 要求在一个序列中恰好选出 \(m\) 个不相邻的数使得权值和最大 其中 \(1\) 的左边是 \(n\),\ ...

  8. 代码随想录算法训练营day02 | leetcode 977/209/59

    leetcode 977   分析1.0:   要求对平方后的int排序,而给定数组中元素可正可负,一开始有思维误区,觉得最小值一定在0左右徘徊,但数据可能并不包含0:遂继续思考,发现元素分布有三种情 ...

  9. 通过反射机制简化 JDBC ResultSet 实体类的注入

    提出问题 查询完某个表之后,一般都是把结果的每一个字段注入到一个实体类中.比如,数据库 users 表,查询出来的结果注入到 User 实体类中. 通过 while 遍历 ResultSet,把字段对 ...

  10. WebGPU 01之Hello Triangle

    1. 引言 WebGPU是什么? WebGPU 到底是什么? - Orillusion的回答 - 知乎 WebGPU与WebGL的对比? WebGL 与 WebGPU 比对 前奏 - 四季留歌 - 博 ...