nrf52832学习笔记(4)修改蓝牙名称,掉电不丢失

2023-05-16

这篇主要介绍如何在手机端修改设备参数,比如设备名称,且实现掉电不丢失。
思路:把需要修改的参数发送给设备,设备根据uuid来分辨是参数,并保存在flash中,重启服务,这样下次上电修改不会丢失。
1.flash的操作
pstorage.c中是官方提供操作flash的库函数,下面介绍几个要用的

说明:初始化flash模块,在调用flash模块之前必须先调用他一次
uint32_t pstorage_init(void);
说明:注册flash接口
[in] p_module_param 注册参数
[out] p_block_id 注册成功时标识flash存储块
uint32_t pstorage_register(pstorage_module_param_t p_module_param,
                           pstorage_handle_t *       p_block_id);                        
说明:根据块编号(block_num)获得你要操作的地址(p_block_id)
[in]  p_base_id 注册成功时标识flash存储块(基块ID)
[in]  block_num块编号,第一块编号为零
[out] p_block_id ,block_num编号块对应的地址
uint32_t pstorage_block_identifier_get(pstorage_handle_t * p_base_id,
                                       pstorage_size_t     block_num, 
                                       pstorage_handle_t  * p_block_id);
说明:在指定位置更新写入存储相应大小的数据
[in] p_dest 更新数据的目的地址
[in] p_src 待写入数据buff首地址
[in] size,写入长度
[in] offset,存储地址的相应偏移量
uint32_t pstorage_update(pstorage_handle_t * p_dest,
                         uint8_t * p_src,
                         pstorage_size_t   size,
                         pstorage_size_t    offset);
说明:在指定位置读取存储区相应大小的数据
[in] p_dest 读取数据的源地址
[in] p_src 读取存放数据buff首地址
[in] size,读取长度
[in] offset,读取数据的源地址的相应偏移量
uint32_t pstorage_load(pstorage_handle_t * p_dest,
                         uint8_t * p_src,
                         pstorage_size_t   size,
                         pstorage_size_t    offset);

第一步,在系统的派发函数里注册官方提供的flash的callback

static void sys_evt_dispatch(uint32_t sys_evt)
{
	//这个函数时在 pstorage 模块中实现的
	pstorage_sys_event_handler(sys_evt);
}

第二步,flash初始化

void flash_init(void)
{
	 uint32_t err_code;
	
	 err_code = pstorage_init();    //初始化flash
     APP_ERROR_CHECK(err_code);	
	
	 pstorage_module_param_t module_param;
     module_param.block_count = 1; // 申请了一个块
     module_param.block_size = 512;//(最小要求是 16)
	 module_param.cb = flash_callback;// //操作回调
	
     err_code =pstorage_register(&module_param, &block_id);//注册申请
	 APP_ERROR_CHECK(err_code);
}

flash_callback我理解是相应操作成功、失败、完成、未完成的判断依据(可以根据op_code分辨哪种状态机,根据result分辨成功失败)如下

static void flash_callback(pstorage_handle_t * handle,uint8_t op_code,uint32_t result,uint8_t * p_data,uint32_t data_len)
{
  switch(op_code)
	{
		case PSTORAGE_UPDATE_OP_CODE:
			if (result == NRF_SUCCESS)
				{
					printf("update end");
					advertising_init();//重新启动广播
				}
		break;
	}
}

这里只判断PSTORAGE_UPDATE_OP_CODE操作成功(result == NRF_SUCCESS)则打印输出update end

2.怎么判断是操作蓝牙名称呢?
可以根据uuid,GAP GATT这种服务的uuid都是SIG定义好的固定的
ble_types.h中80行可以看到设备名称uuid是0x2A00

/* GATT specific UUIDs */
#define BLE_UUID_GATT                                 0x1801 /**< Generic Attribute Profile. */
#define BLE_UUID_GATT_CHARACTERISTIC_SERVICE_CHANGED  0x2A05 /**< Service Changed Characteristic. */
/* GAP specific UUIDs */
#define BLE_UUID_GAP                                  0x1800 /**< Generic Access Profile. */
#define BLE_UUID_GAP_CHARACTERISTIC_DEVICE_NAME       0x2A00 /**< Device Name Characteristic. */
#define BLE_UUID_GAP_CHARACTERISTIC_APPEARANCE        0x2A01 /**< Appearance Characteristic. */
#define BLE_UUID_GAP_CHARACTERISTIC_PPF               0x2A02 /**< Peripheral Privacy Flag Characteristic. */
#define BLE_UUID_GAP_CHARACTERISTIC_RECONN_ADDR       0x2A03 /**< Reconnection Address Characteristic. */
#define BLE_UUID_GAP_CHARACTERISTIC_PPCP              0x2A04 /**< Peripheral Preferred Connection Parameters Characteristic. */
/** @} */

手机连接设备后,对BLE_UUID_GAP_CHARACTERISTIC_DEVICE_NAME属性(uuid 0x2A00)写操作,设备判断是不是对这个uuid写,是的话就把写数据保存在flash中,这样下次重启就可以加载flash数据作为设备名称

static void name_change(ble_evt_t * p_ble_evt)
{
   ble_gatts_evt_write_t *p_evt_write=&p_ble_evt->evt.gatts_evt.params.write;
   //判断是对BLE_UUID_GAP_CHARACTERISTIC_DEVICE_NAME这个uuid进行写操作
   if((p_evt_write->uuid.uuid==BLE_UUID_GAP_CHARACTERISTIC_DEVICE_NAME) 
		  && (p_ble_evt->header.evt_id== BLE_GATTS_EVT_WRITE))
		  
	{
			printf("name change \r\n");
			device_name[0] = 0xaa;
			//写的长度
			device_name[1] = p_evt_write->len;
			//写的数据
			memcpy(device_name+2, p_evt_write->data, p_evt_write->len);
			//保存在flash中
			pstorage_update(&my_name_addr, device_name, NAME_SIZE, 0 );
	}
}

然后在蓝牙派发函数ble_evt_dispatch里包含name_change

gap_params_init函数里要对从flash加载的数据进行判断有没有手机下发的设备名字,有就用手机下发的,没有就用默认的
在这里插入图片描述

本文内容由网友自发贡献,版权归原作者所有,本站不承担相应法律责任。如您发现有涉嫌抄袭侵权的内容,请联系:hwhale#tublm.com(使用前将#替换为@)

nrf52832学习笔记(4)修改蓝牙名称,掉电不丢失 的相关文章

随机推荐

  • np.max()、np.argmax()、np.maximum()、np.min()、np.argmin()、np.minimum()、np.sum()

    numpy专题 最值 求和 最大值np max np argmax np maximum 求和np sum 网上已经有很多对于这几个函数的讲解资料 xff0c 但总感觉讲得有些乱 xff0c 特别是对于高维数组 xff0c 如果指定了某个轴
  • Cortex-M3 (NXP LPC1788)之EEPROM存储器

    EEPROM是一种非易失性存储器 xff0c 主要用于存储相对少量的数据 xff0c 如存储一些系统的配置信息 通过系统的EEPROM控制模块可以轻松的进行EERPOM的存储控制 要正确使用EEPROM需要配置掉电寄存器EEPWRDWN确定
  • sqlalchemy.exc.ArgumentError: Could not parse rfc1738 URL from string

    错误信息 sqlalchemy exc ArgumentError Could not parse rfc1738 URL from string 原 flask sqlacodegen mysql root 64 127 0 0 1 fo
  • 面试题汇总:网络编程

    1 tcp和udp的区别 xff1f xff08 1 xff09 TCP面向连接 xff08 如打电话要先拨号建立连接 xff09 UDP是无连接的 xff0c 即发送数据之前不需要建立连接 xff1b xff08 2 xff09 TCP提
  • CentOS7 安装学之思开源考试系统Mysql版

    环境介绍 序号项目版本1操作系统CentOS Linux release 7 9 2009 Core 2redis7 0 03Mysqlmysql Ver 8 0 29 for Linux on x86 64 MySQL Community
  • Cisco catalyst 交换机升级步骤

    交换机升级步骤 1 准备一个FAT32的U盘 2 到cisco官网上下载交换机镜像 3 将U盘插到交换机上 xff0c 登入交换机concole输入dir usbflash0 xff1a 找到该镜像 xff0c 注意镜像不要放在中文目录下
  • 【性能】【内存】zram解读

    1 背景 nbsp 通过压缩长时间不在前台的进程来节省内存占用 不会像swap一样频繁操作闪存 也可以减少IO操作节省资源 延长闪存寿命 不过内存压缩是一种用时间换空间 的方式 cpu解压缩过程也是需要消耗少量cpu资源 尽管当前andro
  • wifi连接过程抓包

    下面是一次wifi连接过程发送数据的抓包 xff0c 有些包没抓到 xff0c 但还是比较全的 1 4包 xff0c 探测请求 响应过程 STA发出探测请求包Probe ReqAP做出回应 xff0c 发出探测响应包Probe Rsp 5
  • mbedtls学习(6)RSA算法

    RSA算法 RSA算法是一种非对称加密算法 xff0c 特点时加密解密算法不同且加密解密密钥不同 xff0c 即一般公钥加密 xff0c 私钥解密 下面时RSA算法关键参数 n 模数 xff0c 位长度为1024比特或者2048比特e 公开
  • LVGL lv_label标签控件(5)

    lv label 相关API在lv label h中 文本模式 span class token keyword enum span span class token punctuation span span class token co
  • LVGL lv_page页面控件(23)

    lv page 页面控件 xff0c 是由2个lv cont容器控件构成 xff0c 其中一个容器作为lv page页面控件的背景层 xff0c 另一个容器作为lv page页面控件的载体 xff0c 此载体存放其他任何子对象 xff0c
  • FreeRTOS消息队列、信号量、互斥量、递归互斥量实现步骤

    文章目录 消息队列消息队列结构读队列步骤写队列步骤 作用 信号量信号量结构 获取信号量释放信号量 互斥量 xff08 锁 xff09 互斥量结构 获取互斥量释放互斥量 递归互斥量 xff08 递归锁 xff09 获取递归互斥量释放递归互斥量
  • GDB调试宏

    参考 GDB需要调试宏只需用 g3选项编译 g 默认选项 xff0c 同 g2 g0 不生成任何调试信息 xff0c 和编译时不加 g 是一样的 g1 生成最少量的调试信息 xff0c 这些信息足够用来通过backtrace查看调用栈符号信
  • GDB格式化打印结构体

    参考 GDB pretty print set print pretty on GDB 打印数组索引 set print array span class token operator span indexes on 例子 span cla
  • 8080接口

    文章目录 简介引脚写时序读时序 简介 8080接口是由英特尔设计 xff0c 是一种并行 异步 半双工通信协议 xff0c 作用是用于外扩RAM ROM xff0c 后面也用于LCD接口 引脚 写时序 先拉低选中器件 xff0c 如果要写入
  • Centos 7离线安装最新版mysql

    测试环境 CentOS Linux release 7 9 2009 Core 1 准备工作 下载离线安装包 xff1a 1 1 浏览器打开地址 xff1a https dev mysql com downloads mysql 1 2 选
  • C语言UDP socket编程

    C语言UDP socket编程 UDP 服务器步骤如下 xff1a 1 创建等链接套接字fd 61 socket 2 绑定待链接套接字bind fd 服务器ip和端口 3 等待信息recvfrom fd 对端地址 UDP 客户端步骤如下 x
  • MQTT学习笔记(4)报文分析之PUBLISH

    PUBLISH xff08 发布消息 xff09 含义 xff1a 客户端到服务端或者服务端到客户端发布消息控制报文 xff0c 是双向的 一 固定报头 DUP 重发标志 当DUP被设置为0 xff0c 表示客户端或者服务器是第一次发送这个
  • MQTT学习笔记(6)搭建本地MQTT服务器

    目前主流的Broker有以下3个 xff1a Mosquitto xff1a https mosquitto org VerneMQ xff1a https vernemq com EMQTT xff1a http emqtt io 我们使
  • nrf52832学习笔记(4)修改蓝牙名称,掉电不丢失

    这篇主要介绍如何在手机端修改设备参数 xff0c 比如设备名称 且实现掉电不丢失 思路 xff1a 把需要修改的参数发送给设备 xff0c 设备根据uuid来分辨是参数 xff0c 并保存在flash中 xff0c 重启服务 xff0c 这