cc2530 Zstack NV操作类似EEPROM 掉电不丢失(flash)

2024-01-21 08:08

本文主要是介绍cc2530 Zstack NV操作类似EEPROM 掉电不丢失(flash),希望对大家解决编程问题提供一定的参考价值,需要的开发者们随着小编来一起学习吧!

非易失性存储器(non Volatile,NV)是掉电不丢失存储器,类似于51和arm中的EEPROM,记录一些参数。在ZigBee协议栈中NV主要保存网络的配置参数,用户也可以使用。

协议栈在OSAL文件夹下有OSAL_Nv.c和OSAL_Nv.h文件

clip_image001

NV的操作函数主要有3个

1、 osal_nv_item_init(NV_USER_ID,2,NULL);

2、 osal_nv_write(NV_USER_ID,0,2,tempID);

3、 osal_nv_read(NV_USER_ID,0,2,rtempID);

即初始化、读、写函数。每次读写前都要调用初始化函数。每个函数的第一个参数都是ID。根据ID号的范围被划分几个区域,实现不同的应用其中0x0201-0xfff是给用户使用的。

在z-stack中,每一个参数的配置对应的是一个Nv条目(item),每一个item都有自己的ID,z-stack中使用的条目ID范围如下:

    0×0000                              保留

    0×0001~0×0020              操作系统抽象层(OSAL)

    0×0021~0×0040              网络层(NWK)

    0×0041~0×0060              应用程序支持子层(APS)

    0×0061~0×0080              安全(Security)

    0×0081~0x00A0             Zigbee设备对象(ZDO)

    0x00A1~0×0200             保留

    0×0201~0x0FFF              应用程序

    0×1000~0xFFFF              保留

这些地址的定义在zcomdef.h中。

clip_image002

clip_image003

因为底层协议栈已经写好,所以使用还是很容易,现在我要将2个字节的数据保存到NV中在读出来。

1、 首先定义一个item,我个人理解这个item是将底层的地址映射抽象出来的一个新地址,不管叫啥名,就是相当一个地址。在zcomdef.h 中添加item 主要地址范围0x0201-0xfff使用的不能再用。

clip_image005

2、 在头文件中包含#include "osal_Nv.h"

clip_image006

现在就可以在函数中调用3个函数了。

clip_image007

编译运行调试。

clip_image008

就是这么简单。

这篇关于cc2530 Zstack NV操作类似EEPROM 掉电不丢失(flash)的文章就介绍到这儿,希望我们推荐的文章对编程师们有所帮助!



http://www.chinasem.cn/article/628878

相关文章

Go异常处理、泛型和文件操作实例代码

《Go异常处理、泛型和文件操作实例代码》Go语言的异常处理机制与传统的面向对象语言(如Java、C#)所使用的try-catch结构有所不同,它采用了自己独特的设计理念和方法,:本文主要介绍Go异... 目录一:异常处理常见的异常处理向上抛中断程序恢复程序二:泛型泛型函数泛型结构体泛型切片泛型 map三:文

MySQL基本表查询操作汇总之单表查询+多表操作大全

《MySQL基本表查询操作汇总之单表查询+多表操作大全》本文全面介绍了MySQL单表查询与多表操作的关键技术,包括基本语法、高级查询、表别名使用、多表连接及子查询等,并提供了丰富的实例,感兴趣的朋友跟... 目录一、单表查询整合(一)通用模版展示(二)举例说明(三)注意事项(四)Mapper简单举例简单查询

Nginx概念、架构、配置与虚拟主机实战操作指南

《Nginx概念、架构、配置与虚拟主机实战操作指南》Nginx是一个高性能的HTTP服务器、反向代理服务器、负载均衡器和IMAP/POP3/SMTP代理服务器,它支持高并发连接,资源占用低,功能全面且... 目录Nginx 深度解析:概念、架构、配置与虚拟主机实战一、Nginx 的概念二、Nginx 的特点

MySQL 数据库进阶之SQL 数据操作与子查询操作大全

《MySQL数据库进阶之SQL数据操作与子查询操作大全》本文详细介绍了SQL中的子查询、数据添加(INSERT)、数据修改(UPDATE)和数据删除(DELETE、TRUNCATE、DROP)操作... 目录一、子查询:嵌套在查询中的查询1.1 子查询的基本语法1.2 子查询的实战示例二、数据添加:INSE

使用Python在PDF中绘制多种图形的操作示例

《使用Python在PDF中绘制多种图形的操作示例》在进行PDF自动化处理时,人们往往首先想到的是文本生成、图片嵌入或表格绘制等常规需求,然而在许多实际业务场景中,能够在PDF中灵活绘制图形同样至关重... 目录1. 环境准备2. 创建 PDF 文档与页面3. 在 PDF 中绘制不同类型的图形python

Java 操作 MinIO详细步骤

《Java操作MinIO详细步骤》本文详细介绍了如何使用Java操作MinIO,涵盖了从环境准备、核心API详解到实战场景的全过程,文章从基础的桶和对象操作开始,到大文件分片上传、预签名URL生成... 目录Java 操作 MinIO 全指南:从 API 详解到实战场景引言:为什么选择 MinIO?一、环境

在DataGrip中操作MySQL完整流程步骤(从登录到数据查询)

《在DataGrip中操作MySQL完整流程步骤(从登录到数据查询)》DataGrip是JetBrains公司出品的一款现代化数据库管理工具,支持多种数据库系统,包括MySQL,:本文主要介绍在D... 目录前言一、登录 mysql 服务器1.1 打开 DataGrip 并添加数据源1.2 配置 MySQL

Go语言中如何进行数据库查询操作

《Go语言中如何进行数据库查询操作》在Go语言中,与数据库交互通常通过使用数据库驱动来实现,Go语言支持多种数据库,如MySQL、PostgreSQL、SQLite等,每种数据库都有其对应的官方或第三... 查询函数QueryRow和Query详细对比特性QueryRowQuery返回值数量1个:*sql

Python操作Excel的实用工具与库openpyxl/pandas的详细指南

《Python操作Excel的实用工具与库openpyxl/pandas的详细指南》在日常数据处理工作中,Excel是最常见的数据文件格式之一,本文将带你了解openpyxl和pandas的核心用法,... 目录一、openpyxl:原生 Excel 文件操作库1. 安装 openpyxl2. 创建 Exc

Python实现Word文档自动化的操作大全(批量生成、模板填充与内容修改)

《Python实现Word文档自动化的操作大全(批量生成、模板填充与内容修改)》在职场中,Word文档是公认的好伙伴,但你有没有被它折磨过?批量生成合同、制作报告以及发放证书/通知等等,这些重复、低效... 目录重复性文档制作,手动填充模板,效率低下还易错1.python-docx入门:Word文档的“瑞士