Flash KVStore¶
1 功能概述¶
本例程演示如何使用 KVStore 组件,对 SoC Flash 的 KVStore 分区进行 key 的读、写、覆盖、删除等操作。
2 环境准备¶
硬件设备与线材:
PAN107X EVB 核心板与底板各一块
JLink 仿真器(用于烧录例程程序)
USB-TypeC 线一条(用于底板供电和查看串口打印 Log)
杜邦线数根或跳线帽数个(用于连接各个硬件设备)
硬件接线:
将 EVB 核心板插到底板上
使用 USB-TypeC 线,将 PC USB 插口与 EVB 底板 USB->UART 插口相连
使用杜邦线将 EVB 底板上的 TX 引脚接至核心板 P16,RX 引脚接至核心板 P17
使用杜邦线将 JLink 仿真器的:
SWD_CLK 引脚与 EVB 底板的 P00 排针相连
SWD_DAT 引脚与 EVB 底板的 P01 排针相连
SWD_GND 引脚与 EVB 底板的 GND 排针相连
PC 软件:
串口调试助手(UartAssist)或终端工具(SecureCRT),波特率 921600(用于接收串口打印 Log)
3 编译和烧录¶
例程位置:<PAN10XX-NDK>\01_SDK\nimble\samples\component\flash_kvstore\keil_107x
双击 Keil Project 文件打开工程进行编译烧录。
4 例程演示说明¶
烧录完成后,芯片会通过串口打印例程 Log:
Try to load HW calibration data.. DONE. - Chip Info : 0x61 - Chip CP Version : 255 - Chip FT Version : 7 - Chip MAC Address : E11000014DE5 - Chip UID : B90801465454455354 - Chip Flash UID : 4250315A3538380B01FD8B435603EF78 - Chip Flash Size : 512 KB (Inc. 4KB Panchip Info Area) - Current Flash Map : +-------------------------+ <- Addr: 0x00000 | App Partition | | (480 KB) | +-------------------------+ <- Addr: 0x78000 | KVStore Partition | | ( 16 KB) | +-------------------------+ <- Addr: 0x7C000 | User Custom Partition | | ( 12 KB) | +-------------------------+ <- Addr: 0x7F000 | Panchip Info Area | | (4 KB, Hidden) | +-------------------------+ <- End : 0x80000 (512 KB) [I] App started.. [I] Try to write kv data, key="test_data", len=4 [I] kv_write_data[0]: 0x11 [I] kv_write_data[1]: 0x22 [I] kv_write_data[2]: 0x33 [I] kv_write_data[3]: 0x44 [I] KV write done, return code: 0x0 (KVSTORE_OK) [I] Try to read kv data, key:"test_data", len:4 [I] KV read done, return code: 0x0 (KVSTORE_OK) [I] Actual read length = 4 [I] kv_read_data[0]: 0x11 [I] kv_read_data[1]: 0x22 [I] kv_read_data[2]: 0x33 [I] kv_read_data[3]: 0x44 [I] Try to write kv data again, key:"test_data", len:3 [I] kv_write_data[0]: 0x55 [I] kv_write_data[1]: 0x66 [I] kv_write_data[2]: 0x77 [I] KV write done, return code: 0x0 (KVSTORE_OK) [I] Try to read kv data again, key:"test_data", len:10 [I] KV read done, return code: 0x0 (KVSTORE_OK) [I] Actual read length = 3 [I] kv_read_data[0]: 0x55 [I] kv_read_data[1]: 0x66 [I] kv_read_data[2]: 0x77 [I] Try to check if the key "test_data" exists.. [I] KV key check done, return code: 0x0 (KVSTORE_OK) [I] Try to delte the key "test_data".. [I] KV key delete done, return code: 0x0 (KVSTORE_OK) [I] Try to check again if the key "test_data" exists.. [I] KV key check done, return code: 0x9420005 (KVSTORE_ITEM_NOT_FOUND_ERROR)
由上述 Log 可知,本例程:
KVStore 区域被配置在 Flash 0x78000 地址,大小为 16KB
向 KVStore 区域先写入一个名为 test_data 的键值(Key-Value),然后分别尝试读取、更改、删除操作,并确认操作成功
KVStore 区域在 Flash 的具体位置和大小可通过 SDK Config (
sdk_config.h
) 进行配置。