目录

①初始化及配网过程中出错

②发送模型返回错误代码

③发送方成功,接收方丢包

①初始化及配网过程中出错

1-1.返回错误代码-16,表示给dataflash分配的单个扇区的空间不够,需要加大CONFIG_MESH_SECTOR_SIZE_DEF。

1-2.返回错误代码-2,表示重复配网。对于运用到自配网的例程,烧录代码时没有清空dataflash,易见此错误。更改配网信息,直接调用bt_mesh_provision()不能覆盖原有的网络信息,会报错-2;需要调用bt_mesh_reset重置一下节点,再调用bt_mesh_provision()函数来配网;或者擦除datafalsh后,调用SYS_ResetExecute()复位一下从头运行配网。

1-3.配网连接关闭,返回原因9,表示超时。检查一下信号是否正常,若信号良好的情况下必定复现,检查一下配网器与未配网设备再app_mesh_config.h中的CONFIG_MESH_UNSEG_LENGTH_DEF宏是否一致。如果需要兼容标准mesh协议,CONFIG_MESH_UNSEG_LENGTH_DEF需要设置为7。

1-4.启用了flash存储功能后,dataflash中保存的网络信息,会在运行到blemesh_on_sync过程中的settings_load函数时恢复。如果发现代码运行到settings_load时进入了死循环,通常意味着dataflash被篡改,检查一下是否有代码破坏了dataflash中保存的数值。如果dataflash被误修改,排查一下原因后再烧录时清空dataflash或者再代码中擦除datafalsh即可。

在代码中,mesh初始化之前,调用EEPROM_READ函数,可以打印flash中保存的配网信息情况。打印出的是已经解密的内容,可以查看保存的数值是否正确。默认mesh协议栈占用的dataflash首地址从0开始,占用3个扇区,每个扇区大小4K,配网信息只占用最前面的部分,即默认保存在dataflash首地址起往后的200个字节内。

settings_load函数中没有判断配网信息是否合法的过程,可以在运行到settings_load前自行添加判断。比如说对于自配网代码,在codeflash中保存一个数值,如果dataflash中的网络信息与codefalsh中的数值不一致,则清空dataflash,重新配网。再比如说配网时规定好了net key带有奇偶校验(奇偶校验附加数据保存在另外的dataflash区域),那恢复前检查一下net key是否复合原先的奇偶校验。最保险还是用一个定时器来监控,类似看门狗,长时间卡死就清空dataflash然后复位。

②发送模型返回错误代码

常见错误代码可以在《沁恒低功耗蓝牙MESH软件开发参考手册.pdf》中7.1.2小节查到。

2-1.返回错误代码-1,表示找不到发送参数或者参数非法。

如果发送方是非配网器的节点,检查一下模型的app key是否成功绑定。可以在代码中读dataflash打印出来看看数值是否正常,如上,或者利用ISP工具读dataflash查看是否保存网络信息。保存网络信息的数据的起始位置由CONFIG_MESH_NVS_ADDR_DEF这个宏决定,默认是0。可以利用ISP工具读dataflash查看实际写在dataflash中的数值。不过由于涉及加密,实际写的数值与应用层看到的数值不同,右边解密后的ascii码只能看出有没有保存,实际写的的数值是否正确直接看hex是看不出的。

如果发送方是配网器,还需要再关注一下串口打印,或者轮询app_nodes结构体数组的node_addr成员,检查一下有没有给目标地址配网,有可能找不到目标地址。

2-2.返回错误代码-4,表示当前已有一个流程正在执行,需要等待其执行完毕。

2-3.返回错误代码-7,表示发送缓存已满。上层每调用单次发送,会占用一个Net数据缓存,底层发送完成后自动释放。可以调大app_mesh_config.h中的CONFIG_MESH_ADV_BUF_COUNT_DEF或者等待底层发送完成后再发下一则消息。

2-4.返回错误代码-9,表示内存占用已满,需要扩大给蓝牙库分配的大小即BLE_MEMHEAP_SIZE,注意该值会占用ram,也不宜过大。

③发送方成功,接收方丢包

建议两蓝牙mesh节点的布置距离在100m以内,如果距离太远且没有中继,或者TTL数值不够没有中继到,或者干扰太大,真的没收到包,那没办法在代码层面处理。如果收发双方距离适当,检查接收方是否真的“丢包”,就需要查看一些底层参数。蓝牙mesh不走连接,所有通信数据最终都走广播发出,需要一套机制来过滤消息,故存在有底层能够解析消息包,但被判断无需上报的情况。

3-1.检查一下发送方的seq num是否正常,发消息时的seq num是否在前一则消息的seq num上+1。接收方会记录发送方的历史消息的seq num,若接收方判断此刻收到的消息的seq num不比缓存的历史消息的seq num大,则判断其为过往消息,不再处理,也就不会上报。最新EVT中包含有查询seq num和设置seq num的接口函数。设置目标seq num时,除了要小于0xb0e500外,还要比当前seq num数值大。

3-2.检查一下接收方的tid,与seq num类似,每则消息都需要tid值自+1。如果收到消息时的tid一直解析为同一个数值,该消息会被判断为重复消息而不上报。可以在app_vendor_model_srv.c 中打印tid值。如果一直重复,需要检查一下发送方发消息时的发送参数是否设置有误。

3-3.IV值不同步也会造成接收方不再上报消息。待配网节点,需要配网器为其配网时,设置IV值为正在工作的网络中的IV值;待自配网节点,需要第三方介入,获取一下当前网络中的IV值,传递给自配网节点后进行自配网。最新EVT中包含了获取IV值的接口函数。若发现某一方的IV值与网络中的不一致,需要重新配网以设置IV值。

蓝牙mesh组网实践(常见调试问题整理)的更多相关文章

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

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

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

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

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

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

  4. Tengine HTTPS原理解析、实践与调试【转】

    本文邀请阿里云CDN HTTPS技术专家金九,分享Tengine的一些HTTPS实践经验.内容主要有四个方面:HTTPS趋势.HTTPS基础.HTTPS实践.HTTPS调试. 一.HTTPS趋势 这一 ...

  5. 《Visual C++ 2010入门教程》系列六:VC2010常见调试技术

    <Visual C++ 2010入门教程>系列六:VC2010常见调试技术   犹豫了好久,最终还是决定开始这一章,因为我不清楚到底有没有必要写这样的一章,是应该在这里说明一些简单的调试方 ...

  6. PHP 中使用ajax时一些常见错误总结整理

    这篇文章主要介绍了PHP 中使用ajax时一些常见错误总结整理的相关资料,需要的朋友可以参考下 PHP作为后端时,前端js使用ajax技术进行相互信息传送时,经常会出错误,对于新手来说有些手足无措.总 ...

  7. CSS常见布局问题整理

    实现div的水平居中和垂直居中 多元素水平居中 实现栅格化布局 1. 实现div的水平居中和垂直居中 实现效果: 这大概是最经典的一个题目了,所以放在第一个. 方法有好多, 一一列来 主要思路其实就是 ...

  8. 蓝牙mesh介绍

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

  9. 解密蓝牙mesh系列

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

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

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

随机推荐

  1. JS原生上传文件,读取文件格式,控制文件只可以上传某些格式,并使用fileReader转换格式

    本文为代码片段记录,方便后期使用哇! <!DOCTYPE html> <html lang="en"> <head> <meta char ...

  2. MAC实用操作记录---使用命令执行文件上传下载解压打包与解包

    1.使用命令执行文件上传下载 https://www.cnblogs.com/sugartang/p/12743470.html 2.提示:打不开xx软件,在 OS X 安装软件打不开提示" ...

  3. Java 进阶P-7.2+P-7.3

    控制反转 很长一段时间里,我对控制反转和依赖注入这两个概念很模糊,闭上眼睛想一想,总有一种眩晕的感觉.但为了成为一名优秀的 Java 工程师,我花了一周的时间,彻底把它们搞清楚了. 紧耦合 在我们编码 ...

  4. Qt添加自定义控件

    由于在自带的控件中没有发现滚动选择时间的控件,所以参考网上别人写的控件做了一点修改. 先看效果: 上代码: TimeScroll.h QT_BEGIN_NAMESPACE namespace Ui { ...

  5. 【分析笔记】展讯 RDA8810PL 平台 Camera 驱动分析和移植(Android 4.4 )

    前言概述 因以下原因,导致不得不通过代码分析来学习如何在该平台下进行摄像头驱动移植 香橙派开发商(迅龙软件)仅提供能跑起来的源代码.固件,以及简单的编译文档,不提供其它技术支持 baidu.googl ...

  6. 洛谷P1365 期望dp

    题目描述 一个o/x序列的得分为其中每个o的极大连续子段长度的平方和,比如ooxxxxooooxxx,分数就是 \(2 \times 2 + 4 \times 4 = 4 +16=20.\) 现给定一 ...

  7. evil 控制窗口大小,比快捷键方便

    下面是vim原本的支持的键 可以用于 emacs evil ,evil 用这个比用快捷键还方面些 1.纵向调整 :res[ize] num 指定当前窗口为num列num行 :res[ize] +num ...

  8. activiti03 SSM使用activity

    1.添加依赖 <!--activity依赖--> <dependency> <groupId>org.activiti</groupId> <ar ...

  9. ASP.NET Core - 请求管道与中间件

    1. 请求管道 请求管道是什么?请求管道描述的是一个请求进到我们的后端应用,后端应用如何处理的过程,从接收到请求,之后请求怎么流转,经过哪些处理,最后怎么返回响应.请求管道就是一次请求在后端应用的生命 ...

  10. P31_全局配置 - window - 设置上拉触底的距离

    window 设置上拉触底的距离 概念:上拉触底是移动端的专有名词,通过手指在屏幕上的上拉滑动操作,从而加载更多数据的行为. 设置步骤: app.json -> window -> 为 o ...